Improve crashed test handling

This commit is contained in:
Raphael Michel
2018-12-05 16:16:50 +01:00
parent 0bdd14b47a
commit 128a185957

View File

@@ -1,6 +1,8 @@
import pytest
from xdist.dsession import DSession
CRASHED_ITEMS = set()
@pytest.mark.trylast
def pytest_configure(config):
@@ -11,18 +13,21 @@ def pytest_configure(config):
"""
def _handle_crashitem(self, nodeid, worker):
first = nodeid not in CRASHED_ITEMS
runner = self.config.pluginmanager.getplugin("runner")
fspath = nodeid.split("::")[0]
msg = "Worker %r crashed while running %r" % (worker.gateway.id, nodeid)
CRASHED_ITEMS.add(nodeid)
rep = runner.TestReport(
nodeid, (fspath, None, fspath), (), "failed", msg, "???"
nodeid, (fspath, None, fspath), (), "restarted" if first else "failed", msg, "???"
)
rep.node = worker
self.config.hook.pytest_runtest_logreport(report=rep)
# Schedule retry
self.sched.pending.append(self.sched.collection.index(nodeid))
for node in self.sched.node2pending:
self.sched.check_schedule(node)
if first:
self.sched.pending.append(self.sched.collection.index(nodeid))
for node in self.sched.node2pending:
self.sched.check_schedule(node)
DSession.handle_crashitem = _handle_crashitem