Use a dummy RemoteTraceback for test in Python 3.5 Windows
Somehow in Python 3.5 on Windows this test fails with: File "c:\hostedtoolcache\windows\python\3.5.4\x64\Lib\multiprocessing\connection.py", line 302, in _recv_bytes overlapped=True) OSError: [WinError 6] The handle is invalid This only happens in this platform and Python version, decided to use a dummy traceback as originally done in #6412.
This commit is contained in:
parent
21d189eb52
commit
b9c136b809
|
@ -1,3 +1,5 @@
|
||||||
|
import sys
|
||||||
|
|
||||||
import pytest
|
import pytest
|
||||||
from _pytest._code.code import ExceptionChainRepr
|
from _pytest._code.code import ExceptionChainRepr
|
||||||
from _pytest.pathlib import Path
|
from _pytest.pathlib import Path
|
||||||
|
@ -314,15 +316,39 @@ class TestReportSerialization:
|
||||||
# elsewhere and we do check the contents of the longrepr object after loading it.
|
# elsewhere and we do check the contents of the longrepr object after loading it.
|
||||||
loaded_report.longrepr.toterminal(tw_mock)
|
loaded_report.longrepr.toterminal(tw_mock)
|
||||||
|
|
||||||
def test_chained_exceptions_no_reprcrash(
|
def test_chained_exceptions_no_reprcrash(self, testdir, tw_mock):
|
||||||
self, testdir, tw_mock,
|
|
||||||
):
|
|
||||||
"""Regression test for tracebacks without a reprcrash (#5971)
|
"""Regression test for tracebacks without a reprcrash (#5971)
|
||||||
|
|
||||||
This happens notably on exceptions raised by multiprocess.pool: the exception transfer
|
This happens notably on exceptions raised by multiprocess.pool: the exception transfer
|
||||||
from subprocess to main process creates an artificial exception, which ExceptionInfo
|
from subprocess to main process creates an artificial exception, which ExceptionInfo
|
||||||
can't obtain the ReprFileLocation from.
|
can't obtain the ReprFileLocation from.
|
||||||
"""
|
"""
|
||||||
|
# somehow in Python 3.5 on Windows this test fails with:
|
||||||
|
# File "c:\...\3.5.4\x64\Lib\multiprocessing\connection.py", line 302, in _recv_bytes
|
||||||
|
# overlapped=True)
|
||||||
|
# OSError: [WinError 6] The handle is invalid
|
||||||
|
#
|
||||||
|
# so in this platform we opted to use a mock traceback which is identical to the
|
||||||
|
# one produced by the multiprocessing module
|
||||||
|
if sys.version_info[:2] <= (3, 5) and sys.platform.startswith("win"):
|
||||||
|
testdir.makepyfile(
|
||||||
|
"""
|
||||||
|
# equivalent of multiprocessing.pool.RemoteTraceback
|
||||||
|
class RemoteTraceback(Exception):
|
||||||
|
def __init__(self, tb):
|
||||||
|
self.tb = tb
|
||||||
|
def __str__(self):
|
||||||
|
return self.tb
|
||||||
|
def test_a():
|
||||||
|
try:
|
||||||
|
raise ValueError('value error')
|
||||||
|
except ValueError as e:
|
||||||
|
# equivalent to how multiprocessing.pool.rebuild_exc does it
|
||||||
|
e.__cause__ = RemoteTraceback('runtime error')
|
||||||
|
raise e
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
else:
|
||||||
testdir.makepyfile(
|
testdir.makepyfile(
|
||||||
"""
|
"""
|
||||||
from concurrent.futures import ProcessPoolExecutor
|
from concurrent.futures import ProcessPoolExecutor
|
||||||
|
@ -335,6 +361,7 @@ class TestReportSerialization:
|
||||||
p.submit(func).result()
|
p.submit(func).result()
|
||||||
"""
|
"""
|
||||||
)
|
)
|
||||||
|
|
||||||
reprec = testdir.inline_run()
|
reprec = testdir.inline_run()
|
||||||
|
|
||||||
reports = reprec.getreports("pytest_runtest_logreport")
|
reports = reprec.getreports("pytest_runtest_logreport")
|
||||||
|
|
Loading…
Reference in New Issue