]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
bpo-41520: codeop no longer ignores SyntaxWarning (GH-21838)
authorVictor Stinner <vstinner@python.org>
Wed, 12 Aug 2020 12:53:28 +0000 (14:53 +0200)
committerGitHub <noreply@github.com>
Wed, 12 Aug 2020 12:53:28 +0000 (14:53 +0200)
Lib/codeop.py
Lib/test/test_codeop.py
Misc/NEWS.d/next/Library/2020-08-12-13-25-16.bpo-41520.BEUWa4.rst [new file with mode: 0644]

index 7e192ea6a10a03af56f62ef4b2157505a58f4028..547629262d06892cd36d7423403d849691b676bf 100644 (file)
@@ -84,9 +84,11 @@ def _maybe_compile(compiler, source, filename, symbol):
     except SyntaxError:
         pass
 
-    # Suppress warnings after the first compile to avoid duplication.
+    # Catch syntax warnings after the first compile
+    # to emit SyntaxWarning at most once.
     with warnings.catch_warnings():
-        warnings.simplefilter("ignore")
+        warnings.simplefilter("error", SyntaxWarning)
+
         try:
             code1 = compiler(source + "\n", filename, symbol)
         except SyntaxError as e:
index 6e821df6b0e7071487c89024f308259552232973..7984e5f1e5a69a77770b089c2903e95570e65d27 100644 (file)
@@ -4,6 +4,7 @@
 """
 import sys
 import unittest
+import warnings
 from test import support
 from test.support import warnings_helper
 
@@ -310,5 +311,11 @@ class CodeopTests(unittest.TestCase):
             compile_command("0 is 0")
             self.assertEqual(len(w.warnings), 1)
 
+        # bpo-41520: check SyntaxWarning treated as an SyntaxError
+        with self.assertRaises(SyntaxError):
+            warnings.simplefilter('error', SyntaxWarning)
+            compile_command('1 is 1\n', symbol='exec')
+
+
 if __name__ == "__main__":
     unittest.main()
diff --git a/Misc/NEWS.d/next/Library/2020-08-12-13-25-16.bpo-41520.BEUWa4.rst b/Misc/NEWS.d/next/Library/2020-08-12-13-25-16.bpo-41520.BEUWa4.rst
new file mode 100644 (file)
index 0000000..ca5501c
--- /dev/null
@@ -0,0 +1 @@
+Fix :mod:`codeop` regression: it no longer ignores :exc:`SyntaxWarning`.