-
- Notifications
You must be signed in to change notification settings - Fork 2.9k
Closed
Description
$ python3.14 --version Python 3.14.0a6 $ tox -e py314 -- -k 'test_issue_11872 or test_pastebin_http_error or test_raises_bdbquit_with_eoferror or test_unraisable' -v ... .pkg: _optional_hooks> python /usr/lib/python3.13/site-packages/pyproject_api/_backend.py True setuptools.build_meta .pkg: get_requires_for_build_sdist> python /usr/lib/python3.13/site-packages/pyproject_api/_backend.py True setuptools.build_meta .pkg: get_requires_for_build_editable> python /usr/lib/python3.13/site-packages/pyproject_api/_backend.py True setuptools.build_meta .pkg: build_sdist> python /usr/lib/python3.13/site-packages/pyproject_api/_backend.py True setuptools.build_meta py314: install_package> /usr/bin/uv pip install --reinstall --no-deps pytest@.../pytest/.tox/.tmp/package/2/pytest-6.3.0.dev3354+g2b4098102.tar.gz py314: commands[0]> pytest -k 'test_issue_11872 or test_pastebin_http_error or test_raises_bdbquit_with_eoferror or test_unraisable' -v ============================= test session starts ============================== platform linux -- Python 3.14.0a6, pytest-6.3.0.dev3354+g2b4098102, pluggy-1.5.0 -- .../pytest/.tox/py314/bin/python3 cachedir: .tox/py314/.pytest_cache hypothesis profile 'default' -> database=DirectoryBasedExampleDatabase(PosixPath('.../pytest/.hypothesis/examples')) rootdir: .../pytest configfile: pyproject.toml testpaths: testing plugins: hypothesis-6.129.4 collecting ... collected 3905 items / 3890 deselected / 15 selected testing/python/raises.py::TestRaises::test_issue_11872 FAILED [ 6%] testing/test_pastebin.py::TestPaste::test_pastebin_http_error FAILED [ 13%] testing/test_debugging.py::test_raises_bdbquit_with_eoferror FAILED [ 20%] testing/test_threadexception.py::test_unraisable_collection_failure PASSED [ 26%] testing/test_unraisableexception.py::test_unraisable FAILED [ 33%] testing/test_unraisableexception.py::test_unraisable_in_setup FAILED [ 40%] testing/test_unraisableexception.py::test_unraisable_in_teardown FAILED [ 46%] testing/test_unraisableexception.py::test_unraisable_warning_error PASSED [ 53%] testing/test_unraisableexception.py::test_unraisable_warning_multiple_errors PASSED [ 60%] testing/test_unraisableexception.py::test_unraisable_collection_failure PASSED [ 66%] testing/test_unraisableexception.py::test_refcycle_unraisable PASSED [ 73%] testing/test_unraisableexception.py::test_refcycle_unraisable_warning_filter PASSED [ 80%] testing/test_unraisableexception.py::test_create_task_raises_unraisable_warning_filter PASSED [ 86%] testing/test_unraisableexception.py::test_possibly_none_excinfo PASSED [ 93%] testing/test_unraisableexception.py::test_refcycle_unraisable_warning_filter_default PASSED [100%] =================================== FAILURES =================================== _________________________ TestRaises.test_issue_11872 __________________________ self = <tempfile._TemporaryFileCloser object at 0x7f9b85b55b50> def __del__(self): close_called = self.close_called self.cleanup() if not close_called: > _warnings.warn(self.warn_message, ResourceWarning) E ResourceWarning: Implicitly cleaning up <HTTPError 404: 'Not Found'> /usr/lib64/python3.14/tempfile.py:483: ResourceWarning The above exception was the direct cause of the following exception: cls = <class '_pytest.runner.CallInfo'> func = <function call_and_report.<locals>.<lambda> at 0x7f9b87605590> when = 'call' reraise = (<class '_pytest.outcomes.Exit'>, <class 'KeyboardInterrupt'>) @classmethod def from_call( cls, func: Callable[[], TResult], when: Literal["collect", "setup", "call", "teardown"], reraise: type[BaseException] | tuple[type[BaseException], ...] | None = None, ) -> CallInfo[TResult]: """Call func, wrapping the result in a CallInfo. :param func: The function to call. Called without arguments. :type func: Callable[[], _pytest.runner.TResult] :param when: The phase in which the function is called. :param reraise: Exception or exceptions that shall propagate if raised by the function, instead of being wrapped in the CallInfo. """ excinfo = None start = timing.time() precise_start = timing.perf_counter() try: > result: TResult | None = func() ^^^^^^ .tox/py314/lib64/python3.14/site-packages/_pytest/runner.py:345: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ .tox/py314/lib64/python3.14/site-packages/_pytest/runner.py:246: in <lambda> lambda: runtest_hook(item=item, **kwds), when=when, reraise=reraise ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ .tox/py314/lib64/python3.14/site-packages/pluggy/_hooks.py:513: in __call__ return self._hookexec(self.name, self._hookimpls.copy(), kwargs, firstresult) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ .tox/py314/lib64/python3.14/site-packages/pluggy/_manager.py:120: in _hookexec return self._inner_hookexec(hook_name, methods, kwargs, firstresult) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ .tox/py314/lib64/python3.14/site-packages/_pytest/logging.py:847: in pytest_runtest_call yield from self._runtest_for(item, "call") .tox/py314/lib64/python3.14/site-packages/_pytest/logging.py:830: in _runtest_for yield .tox/py314/lib64/python3.14/site-packages/_pytest/capture.py:900: in pytest_runtest_call return (yield) ^^^^^ .tox/py314/lib64/python3.14/site-packages/_pytest/skipping.py:263: in pytest_runtest_call return (yield) ^^^^^ .tox/py314/lib64/python3.14/site-packages/_pytest/unraisableexception.py:153: in pytest_runtest_call collect_unraisable(item.config) .tox/py314/lib64/python3.14/site-packages/_pytest/unraisableexception.py:77: in collect_unraisable raise errors[0] _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ config = <_pytest.config.Config object at 0x7f9b889b2a50> def collect_unraisable(config: Config) -> None: pop_unraisable = config.stash[unraisable_exceptions].pop errors: list[pytest.PytestUnraisableExceptionWarning | RuntimeError] = [] meta = None hook_error = None try: while True: try: meta = pop_unraisable() except IndexError: break if isinstance(meta, BaseException): hook_error = RuntimeError("Failed to process unraisable exception") hook_error.__cause__ = meta errors.append(hook_error) continue msg = meta.msg try: > warnings.warn(pytest.PytestUnraisableExceptionWarning(msg)) E pytest.PytestUnraisableExceptionWarning: Exception ignored while calling deallocator <function _TemporaryFileCloser.__del__ at 0x7f9b88bac460>: None .tox/py314/lib64/python3.14/site-packages/_pytest/unraisableexception.py:65: PytestUnraisableExceptionWarning ______________________ TestPaste.test_pastebin_http_error ______________________ self = <tempfile._TemporaryFileCloser object at 0x7f9b859a3550> def __del__(self): close_called = self.close_called self.cleanup() if not close_called: > _warnings.warn(self.warn_message, ResourceWarning) E ResourceWarning: Implicitly cleaning up <HTTPError 400: 'Bad request'> /usr/lib64/python3.14/tempfile.py:483: ResourceWarning The above exception was the direct cause of the following exception: cls = <class '_pytest.runner.CallInfo'> func = <function call_and_report.<locals>.<lambda> at 0x7f9b8589d430> when = 'call' reraise = (<class '_pytest.outcomes.Exit'>, <class 'KeyboardInterrupt'>) @classmethod def from_call( cls, func: Callable[[], TResult], when: Literal["collect", "setup", "call", "teardown"], reraise: type[BaseException] | tuple[type[BaseException], ...] | None = None, ) -> CallInfo[TResult]: """Call func, wrapping the result in a CallInfo. :param func: The function to call. Called without arguments. :type func: Callable[[], _pytest.runner.TResult] :param when: The phase in which the function is called. :param reraise: Exception or exceptions that shall propagate if raised by the function, instead of being wrapped in the CallInfo. """ excinfo = None start = timing.time() precise_start = timing.perf_counter() try: > result: TResult | None = func() ^^^^^^ .tox/py314/lib64/python3.14/site-packages/_pytest/runner.py:345: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ .tox/py314/lib64/python3.14/site-packages/_pytest/runner.py:246: in <lambda> lambda: runtest_hook(item=item, **kwds), when=when, reraise=reraise ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ .tox/py314/lib64/python3.14/site-packages/pluggy/_hooks.py:513: in __call__ return self._hookexec(self.name, self._hookimpls.copy(), kwargs, firstresult) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ .tox/py314/lib64/python3.14/site-packages/pluggy/_manager.py:120: in _hookexec return self._inner_hookexec(hook_name, methods, kwargs, firstresult) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ .tox/py314/lib64/python3.14/site-packages/_pytest/logging.py:847: in pytest_runtest_call yield from self._runtest_for(item, "call") .tox/py314/lib64/python3.14/site-packages/_pytest/logging.py:830: in _runtest_for yield .tox/py314/lib64/python3.14/site-packages/_pytest/capture.py:900: in pytest_runtest_call return (yield) ^^^^^ .tox/py314/lib64/python3.14/site-packages/_pytest/skipping.py:263: in pytest_runtest_call return (yield) ^^^^^ .tox/py314/lib64/python3.14/site-packages/_pytest/unraisableexception.py:153: in pytest_runtest_call collect_unraisable(item.config) .tox/py314/lib64/python3.14/site-packages/_pytest/unraisableexception.py:77: in collect_unraisable raise errors[0] _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ config = <_pytest.config.Config object at 0x7f9b889b2a50> def collect_unraisable(config: Config) -> None: pop_unraisable = config.stash[unraisable_exceptions].pop errors: list[pytest.PytestUnraisableExceptionWarning | RuntimeError] = [] meta = None hook_error = None try: while True: try: meta = pop_unraisable() except IndexError: break if isinstance(meta, BaseException): hook_error = RuntimeError("Failed to process unraisable exception") hook_error.__cause__ = meta errors.append(hook_error) continue msg = meta.msg try: > warnings.warn(pytest.PytestUnraisableExceptionWarning(msg)) E pytest.PytestUnraisableExceptionWarning: Exception ignored while calling deallocator <function _TemporaryFileCloser.__del__ at 0x7f9b88bac460>: None .tox/py314/lib64/python3.14/site-packages/_pytest/unraisableexception.py:65: PytestUnraisableExceptionWarning ______________________ test_raises_bdbquit_with_eoferror _______________________ pytester = <Pytester PosixPath('/tmp/pytest-of-.../pytest-26/test_raises_bdbquit_with_eoferror0')> def test_raises_bdbquit_with_eoferror(pytester: Pytester) -> None: """It is not guaranteed that DontReadFromInput's read is called.""" p1 = pytester.makepyfile( """ def input_without_read(*args, **kwargs): raise EOFError() def test(monkeypatch): import builtins monkeypatch.setattr(builtins, "input", input_without_read) __import__('pdb').set_trace() """ ) result = pytester.runpytest(str(p1)) > result.stdout.fnmatch_lines(["E *BdbQuit", "*= 1 failed in*"]) E Failed: nomatch: 'E *BdbQuit' E and: '============================= test session starts ==============================' E and: 'platform linux -- Python 3.14.0a6, pytest-6.3.0.dev3354+g2b4098102, pluggy-1.5.0' E and: 'rootdir: /tmp/pytest-of-.../pytest-26/test_raises_bdbquit_with_eoferror0' E and: 'collected 1 item' E and: '' E and: 'test_raises_bdbquit_with_eoferror.py ' E and: '>>>>>>>>>>>>>>>>>>> PDB set_trace (IO-capturing turned off) >>>>>>>>>>>>>>>>>>>>' E and: '> /tmp/pytest-of-.../pytest-26/test_raises_bdbquit_with_eoferror0/test_raises_bdbquit_with_eoferror.py(7)test()' E and: "-> __import__('pdb').set_trace()" E and: '' E and: '' E and: '' E and: '!!!!!!!!!!!!!!!!!!! _pytest.outcomes.Exit: Quitting debugger !!!!!!!!!!!!!!!!!!!' E and: '============================ no tests ran in 0.50s =============================' E remains unmatched: 'E *BdbQuit' .../pytest/testing/test_debugging.py:1390: Failed ----------------------------- Captured stdout call ----------------------------- ============================= test session starts ============================== platform linux -- Python 3.14.0a6, pytest-6.3.0.dev3354+g2b4098102, pluggy-1.5.0 rootdir: /tmp/pytest-of-.../pytest-26/test_raises_bdbquit_with_eoferror0 collected 1 item test_raises_bdbquit_with_eoferror.py >>>>>>>>>>>>>>>>>>> PDB set_trace (IO-capturing turned off) >>>>>>>>>>>>>>>>>>>> > /tmp/pytest-of-.../pytest-26/test_raises_bdbquit_with_eoferror0/test_raises_bdbquit_with_eoferror.py(7)test() -> __import__('pdb').set_trace() !!!!!!!!!!!!!!!!!!! _pytest.outcomes.Exit: Quitting debugger !!!!!!!!!!!!!!!!!!! ============================ no tests ran in 0.50s ============================= _______________________________ test_unraisable ________________________________ pytester = <Pytester PosixPath('/tmp/pytest-of-.../pytest-26/test_unraisable0')> @pytest.mark.skipif(PYPY, reason="garbage-collection differences make this flaky") @pytest.mark.filterwarnings("default::pytest.PytestUnraisableExceptionWarning") def test_unraisable(pytester: Pytester) -> None: pytester.makepyfile( test_it=""" class BrokenDel: def __del__(self): raise ValueError("del is broken") def test_it(): obj = BrokenDel() del obj def test_2(): pass """ ) result = pytester.runpytest() assert result.ret == 0 result.assert_outcomes(passed=2, warnings=1) > result.stdout.fnmatch_lines( [ "*= warnings summary =*", "test_it.py::test_it", " * PytestUnraisableExceptionWarning: Exception ignored in: <function BrokenDel.__del__ at *>", " ", " Traceback (most recent call last):", " ValueError: del is broken", " ", " Enable tracemalloc to get traceback where the object was allocated.", " See https* for more info.", " warnings.warn(pytest.PytestUnraisableExceptionWarning(msg))", ] ) E Failed: nomatch: '*= warnings summary =*' E and: '============================= test session starts ==============================' E and: 'platform linux -- Python 3.14.0a6, pytest-6.3.0.dev3354+g2b4098102, pluggy-1.5.0' E and: 'rootdir: /tmp/pytest-of-.../pytest-26/test_unraisable0' E and: 'collected 2 items' E and: '' E and: 'test_it.py .. [100%]' E and: '' E fnmatch: '*= warnings summary =*' E with: '=============================== warnings summary ===============================' E exact match: 'test_it.py::test_it' E nomatch: ' * PytestUnraisableExceptionWarning: Exception ignored in: <function BrokenDel.__del__ at *>' E and: ' .../pytest/.tox/py314/lib64/python3.14/site-packages/_pytest/unraisableexception.py:65: PytestUnraisableExceptionWarning: Exception ignored while calling deallocator <function BrokenDel.__del__ at 0x7f9b853c0a90>: None' E and: ' ' E and: ' Traceback (most recent call last):' E and: ' File "/tmp/pytest-of-.../pytest-26/test_unraisable0/test_it.py", line 3, in __del__' E and: ' raise ValueError("del is broken")' E and: ' ValueError: del is broken' E and: ' ' E and: ' ' E and: ' warnings.warn(pytest.PytestUnraisableExceptionWarning(msg))' E and: '' E and: '-- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html' E and: '========================= 2 passed, 1 warning in 0.01s =========================' E remains unmatched: ' * PytestUnraisableExceptionWarning: Exception ignored in: <function BrokenDel.__del__ at *>' .../pytest/testing/test_unraisableexception.py:35: Failed ----------------------------- Captured stdout call ----------------------------- ============================= test session starts ============================== platform linux -- Python 3.14.0a6, pytest-6.3.0.dev3354+g2b4098102, pluggy-1.5.0 rootdir: /tmp/pytest-of-.../pytest-26/test_unraisable0 collected 2 items test_it.py .. [100%] =============================== warnings summary =============================== test_it.py::test_it .../pytest/.tox/py314/lib64/python3.14/site-packages/_pytest/unraisableexception.py:65: PytestUnraisableExceptionWarning: Exception ignored while calling deallocator <function BrokenDel.__del__ at 0x7f9b853c0a90>: None Traceback (most recent call last): File "/tmp/pytest-of-.../pytest-26/test_unraisable0/test_it.py", line 3, in __del__ raise ValueError("del is broken") ValueError: del is broken warnings.warn(pytest.PytestUnraisableExceptionWarning(msg)) -- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html ========================= 2 passed, 1 warning in 0.01s ========================= ___________________________ test_unraisable_in_setup ___________________________ pytester = <Pytester PosixPath('/tmp/pytest-of-.../pytest-26/test_unraisable_in_setup0')> @pytest.mark.skipif(PYPY, reason="garbage-collection differences make this flaky") @pytest.mark.filterwarnings("default::pytest.PytestUnraisableExceptionWarning") def test_unraisable_in_setup(pytester: Pytester) -> None: pytester.makepyfile( test_it=""" import pytest class BrokenDel: def __del__(self): raise ValueError("del is broken") @pytest.fixture def broken_del(): obj = BrokenDel() del obj def test_it(broken_del): pass def test_2(): pass """ ) result = pytester.runpytest() assert result.ret == 0 result.assert_outcomes(passed=2, warnings=1) > result.stdout.fnmatch_lines( [ "*= warnings summary =*", "test_it.py::test_it", " * PytestUnraisableExceptionWarning: Exception ignored in: <function BrokenDel.__del__ at *>", " ", " Traceback (most recent call last):", " ValueError: del is broken", " ", " Enable tracemalloc to get traceback where the object was allocated.", " See https* for more info.", " warnings.warn(pytest.PytestUnraisableExceptionWarning(msg))", ] ) E Failed: nomatch: '*= warnings summary =*' E and: '============================= test session starts ==============================' E and: 'platform linux -- Python 3.14.0a6, pytest-6.3.0.dev3354+g2b4098102, pluggy-1.5.0' E and: 'rootdir: /tmp/pytest-of-.../pytest-26/test_unraisable_in_setup0' E and: 'collected 2 items' E and: '' E and: 'test_it.py .. [100%]' E and: '' E fnmatch: '*= warnings summary =*' E with: '=============================== warnings summary ===============================' E exact match: 'test_it.py::test_it' E nomatch: ' * PytestUnraisableExceptionWarning: Exception ignored in: <function BrokenDel.__del__ at *>' E and: ' .../pytest/.tox/py314/lib64/python3.14/site-packages/_pytest/unraisableexception.py:65: PytestUnraisableExceptionWarning: Exception ignored while calling deallocator <function BrokenDel.__del__ at 0x7f9b85430300>: None' E and: ' ' E and: ' Traceback (most recent call last):' E and: ' File "/tmp/pytest-of-.../pytest-26/test_unraisable_in_setup0/test_it.py", line 5, in __del__' E and: ' raise ValueError("del is broken")' E and: ' ValueError: del is broken' E and: ' ' E and: ' ' E and: ' warnings.warn(pytest.PytestUnraisableExceptionWarning(msg))' E and: '' E and: '-- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html' E and: '========================= 2 passed, 1 warning in 0.01s =========================' E remains unmatched: ' * PytestUnraisableExceptionWarning: Exception ignored in: <function BrokenDel.__del__ at *>' .../pytest/testing/test_unraisableexception.py:74: Failed ----------------------------- Captured stdout call ----------------------------- ============================= test session starts ============================== platform linux -- Python 3.14.0a6, pytest-6.3.0.dev3354+g2b4098102, pluggy-1.5.0 rootdir: /tmp/pytest-of-.../pytest-26/test_unraisable_in_setup0 collected 2 items test_it.py .. [100%] =============================== warnings summary =============================== test_it.py::test_it .../pytest/.tox/py314/lib64/python3.14/site-packages/_pytest/unraisableexception.py:65: PytestUnraisableExceptionWarning: Exception ignored while calling deallocator <function BrokenDel.__del__ at 0x7f9b85430300>: None Traceback (most recent call last): File "/tmp/pytest-of-.../pytest-26/test_unraisable_in_setup0/test_it.py", line 5, in __del__ raise ValueError("del is broken") ValueError: del is broken warnings.warn(pytest.PytestUnraisableExceptionWarning(msg)) -- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html ========================= 2 passed, 1 warning in 0.01s ========================= _________________________ test_unraisable_in_teardown __________________________ pytester = <Pytester PosixPath('/tmp/pytest-of-.../pytest-26/test_unraisable_in_teardown0')> @pytest.mark.skipif(PYPY, reason="garbage-collection differences make this flaky") @pytest.mark.filterwarnings("default::pytest.PytestUnraisableExceptionWarning") def test_unraisable_in_teardown(pytester: Pytester) -> None: pytester.makepyfile( test_it=""" import pytest class BrokenDel: def __del__(self): raise ValueError("del is broken") @pytest.fixture def broken_del(): yield obj = BrokenDel() del obj def test_it(broken_del): pass def test_2(): pass """ ) result = pytester.runpytest() assert result.ret == 0 result.assert_outcomes(passed=2, warnings=1) > result.stdout.fnmatch_lines( [ "*= warnings summary =*", "test_it.py::test_it", " * PytestUnraisableExceptionWarning: Exception ignored in: <function BrokenDel.__del__ at *>", " ", " Traceback (most recent call last):", " ValueError: del is broken", " ", " Enable tracemalloc to get traceback where the object was allocated.", " See https* for more info.", " warnings.warn(pytest.PytestUnraisableExceptionWarning(msg))", ] ) E Failed: nomatch: '*= warnings summary =*' E and: '============================= test session starts ==============================' E and: 'platform linux -- Python 3.14.0a6, pytest-6.3.0.dev3354+g2b4098102, pluggy-1.5.0' E and: 'rootdir: /tmp/pytest-of-.../pytest-26/test_unraisable_in_teardown0' E and: 'collected 2 items' E and: '' E and: 'test_it.py .. [100%]' E and: '' E fnmatch: '*= warnings summary =*' E with: '=============================== warnings summary ===============================' E exact match: 'test_it.py::test_it' E nomatch: ' * PytestUnraisableExceptionWarning: Exception ignored in: <function BrokenDel.__del__ at *>' E and: ' .../pytest/.tox/py314/lib64/python3.14/site-packages/_pytest/unraisableexception.py:65: PytestUnraisableExceptionWarning: Exception ignored while calling deallocator <function BrokenDel.__del__ at 0x7f9b85434880>: None' E and: ' ' E and: ' Traceback (most recent call last):' E and: ' File "/tmp/pytest-of-.../pytest-26/test_unraisable_in_teardown0/test_it.py", line 5, in __del__' E and: ' raise ValueError("del is broken")' E and: ' ValueError: del is broken' E and: ' ' E and: ' ' E and: ' warnings.warn(pytest.PytestUnraisableExceptionWarning(msg))' E and: '' E and: '-- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html' E and: '========================= 2 passed, 1 warning in 0.01s =========================' E remains unmatched: ' * PytestUnraisableExceptionWarning: Exception ignored in: <function BrokenDel.__del__ at *>' .../pytest/testing/test_unraisableexception.py:114: Failed ----------------------------- Captured stdout call ----------------------------- ============================= test session starts ============================== platform linux -- Python 3.14.0a6, pytest-6.3.0.dev3354+g2b4098102, pluggy-1.5.0 rootdir: /tmp/pytest-of-.../pytest-26/test_unraisable_in_teardown0 collected 2 items test_it.py .. [100%] =============================== warnings summary =============================== test_it.py::test_it .../pytest/.tox/py314/lib64/python3.14/site-packages/_pytest/unraisableexception.py:65: PytestUnraisableExceptionWarning: Exception ignored while calling deallocator <function BrokenDel.__del__ at 0x7f9b85434880>: None Traceback (most recent call last): File "/tmp/pytest-of-.../pytest-26/test_unraisable_in_teardown0/test_it.py", line 5, in __del__ raise ValueError("del is broken") ValueError: del is broken warnings.warn(pytest.PytestUnraisableExceptionWarning(msg)) -- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html ========================= 2 passed, 1 warning in 0.01s ========================= =========================== short test summary info ============================ FAILED testing/python/raises.py::TestRaises::test_issue_11872 - pytest.Pytest... FAILED testing/test_pastebin.py::TestPaste::test_pastebin_http_error - pytest... FAILED testing/test_debugging.py::test_raises_bdbquit_with_eoferror - Failed:... FAILED testing/test_unraisableexception.py::test_unraisable - Failed: nomatch... FAILED testing/test_unraisableexception.py::test_unraisable_in_setup - Failed... FAILED testing/test_unraisableexception.py::test_unraisable_in_teardown - Fai... ================= 6 failed, 9 passed, 3890 deselected in 9.55s ================= py314: exit 1 (11.30 seconds) .../pytest> pytest -k 'test_issue_11872 or test_pastebin_http_error or test_raises_bdbquit_with_eoferror or test_unraisable' -v pid=3081635 py314: FAIL code 1 (18.23=setup[6.93]+cmd[11.30] seconds) evaluation failed :( (18.31 seconds) $ uv pip list Using Python 3.14.0a6 environment at: .tox/py314 Package Version ------------------ ------------------------ argcomplete 3.6.0 attrs 25.3.0 certifi 2025.1.31 charset-normalizer 3.4.1 elementpath 4.8.0 hypothesis 6.129.4 idna 3.10 iniconfig 2.0.0 mock 5.2.0 packaging 24.2 pluggy 1.5.0 pygments 2.19.1 pytest 6.3.0.dev3354+g2b4098102 requests 2.32.3 setuptools 76.1.0 sortedcontainers 2.4.0 urllib3 2.3.0 xmlschema 3.4.4 This is both the latest pytest 8.3.5 and main branch @ 2b40981.
Fedora Linux (41 and 43 both).
Metadata
Metadata
Assignees
Labels
No labels