From ff23a4938d09223cec53bbd747becea28b25918c Mon Sep 17 00:00:00 2001 From: Reagan Date: Thu, 17 Oct 2024 22:53:15 -0700 Subject: [PATCH 1/4] fix re-emitting to wrong module --- src/_pytest/recwarn.py | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/_pytest/recwarn.py b/src/_pytest/recwarn.py index 0dc002edd94..f7c0e97ae9c 100644 --- a/src/_pytest/recwarn.py +++ b/src/_pytest/recwarn.py @@ -5,6 +5,7 @@ from pprint import pformat import re +import sys from types import TracebackType from typing import Any from typing import Callable @@ -327,12 +328,17 @@ def found_str() -> str: # Whether or not any warnings matched, we want to re-emit all unmatched warnings. for w in self: if not self.matches(w): + module = next( + k + for k, v in sys.modules.items() + if getattr(v, "__file__", None) == w.filename + ) warnings.warn_explicit( message=w.message, category=w.category, filename=w.filename, lineno=w.lineno, - module=w.__module__, + module=module, source=w.source, ) From 90e5b18bd7f353fefe80b345557a846f9a88d831 Mon Sep 17 00:00:00 2001 From: Reagan Date: Thu, 17 Oct 2024 22:55:49 -0700 Subject: [PATCH 2/4] changelog --- changelog/11933.bugfix.rst | 1 + 1 file changed, 1 insertion(+) create mode 100644 changelog/11933.bugfix.rst diff --git a/changelog/11933.bugfix.rst b/changelog/11933.bugfix.rst new file mode 100644 index 00000000000..3f33f2667c4 --- /dev/null +++ b/changelog/11933.bugfix.rst @@ -0,0 +1 @@ +Fix regression with :func:`pytest.warns` using wrong module when re-emitting unmatched warnings. \ No newline at end of file From d0999ebe6bde9312bf930155d41ce5347a180403 Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Fri, 18 Oct 2024 05:59:57 +0000 Subject: [PATCH 3/4] [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci --- changelog/11933.bugfix.rst | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/changelog/11933.bugfix.rst b/changelog/11933.bugfix.rst index 3f33f2667c4..e9cbcce6a1b 100644 --- a/changelog/11933.bugfix.rst +++ b/changelog/11933.bugfix.rst @@ -1 +1 @@ -Fix regression with :func:`pytest.warns` using wrong module when re-emitting unmatched warnings. \ No newline at end of file +Fix regression with :func:`pytest.warns` using wrong module when re-emitting unmatched warnings. From ccd67e31e6c19baa03b49d2ec922d41fa39d2196 Mon Sep 17 00:00:00 2001 From: Reagan Date: Wed, 23 Oct 2024 16:25:41 -0700 Subject: [PATCH 4/4] changes + test --- src/_pytest/recwarn.py | 9 ++++++--- testing/test_recwarn.py | 32 ++++++++++++++++++++++++++++++++ 2 files changed, 38 insertions(+), 3 deletions(-) diff --git a/src/_pytest/recwarn.py b/src/_pytest/recwarn.py index f7c0e97ae9c..54db462e927 100644 --- a/src/_pytest/recwarn.py +++ b/src/_pytest/recwarn.py @@ -329,9 +329,12 @@ def found_str() -> str: for w in self: if not self.matches(w): module = next( - k - for k, v in sys.modules.items() - if getattr(v, "__file__", None) == w.filename + ( + k + for k, v in sys.modules.items() + if getattr(v, "__file__", None) == w.filename + ), + None, ) warnings.warn_explicit( message=w.message, diff --git a/testing/test_recwarn.py b/testing/test_recwarn.py index 384f2b66a15..7f0fed32e80 100644 --- a/testing/test_recwarn.py +++ b/testing/test_recwarn.py @@ -545,6 +545,38 @@ def test_it(): result.assert_outcomes() +def test_re_emit_uses_correct_module(pytester: Pytester) -> None: + warning_module_code = """ +import warnings + +def trigger_warning(msg): + warnings.warn(msg, UserWarning) +""" + pytester.makepyfile(module_a=warning_module_code) + pytester.makepyfile(module_b=warning_module_code) + + test_code = """ + import pytest + import warnings + from module_a import trigger_warning as trigger_warning_a + from module_b import trigger_warning as trigger_warning_b + + def test_ignore_warning_from_module_a(): + with pytest.raises(pytest.fail.Exception, match="DID NOT WARN"): + with pytest.warns(UserWarning, match="module A.") as outer: + warnings.filterwarnings("ignore", category=UserWarning, module="module_a") + with pytest.warns(UserWarning, match="module B.") as inner: # re-emit the module A warning + trigger_warning_a("module A.") + trigger_warning_b("module B.") + """ + # Write the test to a new file called 'test_re_emit.py' + pytester.makepyfile(test_re_emit=test_code) + + # Run the test and assert that it passed + result = pytester.runpytest() + result.assert_outcomes(passed=1) + + def test_raise_type_error_on_invalid_warning() -> None: """Check pytest.warns validates warning messages are strings (#10865) or Warning instances (#11959)."""