def report_process_crash(item, result): path, lineno = item._getfslineno() info = "%s:%s: running the test CRASHED with signal %d" %( path, lineno, result.signal) from _pytest import runner call = runner.CallInfo(lambda: 0/0, "???") call.excinfo = info rep = runner.pytest_runtest_makereport(item, call) return rep
def report_process_crash(item, result): path, lineno = item._getfslineno() info = ("%s:%s: running the test CRASHED with signal %d" % (path, lineno, result.signal)) from _pytest import runner call = runner.CallInfo(lambda: 0/0, "???") call.excinfo = info rep = runner.pytest_runtest_makereport(item, call) if result.out: rep.sections.append(("captured stdout", result.out)) if result.err: rep.sections.append(("captured stderr", result.err)) return rep
def report_process_crash(item, result): path, lineno = item._getfslineno() info = ("%s:%s: running the test CRASHED with signal %d" % (path, lineno, result.signal)) from _pytest import runner call = runner.CallInfo(lambda: 0/0, "???") call.excinfo = info rep = runner.pytest_runtest_makereport(item, call) if result.out: rep.sections.append(("captured stdout", result.out)) if result.err: rep.sections.append(("captured stderr", result.err)) return rep
def report_process_monitor(item, result): # TODO: generate WARNINGS to pytest report instead of FAILED _type = 'FATAL' if result.fatal else 'WARNING' info = ("Monitor process report {}:".format(_type)) call = runner.CallInfo(lambda: 0 / 0, "???") call.excinfo = info rep = runner.pytest_runtest_makereport(item, call) msg = '' if result.out: msg += '\n\t{}'.format(result.out) if result.err: msg += '\n\t{}'.format(result.err) rep.sections.append(("Monitor Message", msg)) return rep
def report_process_crash(item, result): from _pytest._code import getfslineno path, lineno = getfslineno(item) info = "%s:%s: running the test CRASHED with signal %d" % ( path, lineno, result.signal, ) from _pytest import runner # pytest >= 4.1 has_from_call = getattr(runner.CallInfo, "from_call", None) is not None if has_from_call: call = runner.CallInfo.from_call(lambda: 0 / 0, "???") else: call = runner.CallInfo(lambda: 0 / 0, "???") call.excinfo = info rep = runner.pytest_runtest_makereport(item, call) if result.out: rep.sections.append(("captured stdout", result.out)) if result.err: rep.sections.append(("captured stderr", result.err)) xfail_marker = item.get_closest_marker("xfail") if not xfail_marker: return rep rep.outcome = "skipped" rep.wasxfail = ("reason: {xfail_reason}; " "pytest-forked reason: {crash_info}".format( xfail_reason=xfail_marker.kwargs["reason"], crash_info=info, )) warnings.warn( "pytest-forked xfail support is incomplete at the moment and may " "output a misleading reason message", RuntimeWarning, ) return rep
def report_process_crash(item, result): try: from _pytest.compat import getfslineno except ImportError: # pytest<4.2 path, lineno = item._getfslineno() else: path, lineno = getfslineno(item) info = ("%s:%s: running the test CRASHED with signal %d" % (path, lineno, result.signal)) from _pytest import runner # pytest >= 4.1 has_from_call = getattr(runner.CallInfo, "from_call", None) is not None if has_from_call: call = runner.CallInfo.from_call(lambda: 0 / 0, "???") else: call = runner.CallInfo(lambda: 0 / 0, "???") call.excinfo = info rep = runner.pytest_runtest_makereport(item, call) if result.out: rep.sections.append(("captured stdout", result.out)) if result.err: rep.sections.append(("captured stderr", result.err)) return rep