]> granicus.if.org Git - python/commitdiff
SF patch 763201: handling of SyntaxErrors in symbol table build
authorJeremy Hylton <jeremy@alum.mit.edu>
Tue, 15 Jul 2003 20:24:27 +0000 (20:24 +0000)
committerJeremy Hylton <jeremy@alum.mit.edu>
Tue, 15 Jul 2003 20:24:27 +0000 (20:24 +0000)
Bug fix candidate.

Lib/test/test_symtable.py
Lib/test/test_syntax.py

index 44f156e8bf8c691f428f6824e4795c994420efe2..5961102d2909ef11c224e106b51016a225273138 100644 (file)
@@ -1,8 +1,20 @@
-from test.test_support import verify
+from test.test_support import vereq, TestFailed
 
 import _symtable
 
 symbols = _symtable.symtable("def f(x): return x", "?", "exec")
 
-verify(symbols[0].name == "global")
-verify(len([ste for ste in symbols.values() if ste.name == "f"]) == 1)
+vereq(symbols[0].name, "global")
+vereq(len([ste for ste in symbols.values() if ste.name == "f"]), 1)
+
+# Bug tickler: SyntaxError file name correct whether error raised
+# while parsing or building symbol table.
+def checkfilename(brokencode):
+    try:
+        _symtable.symtable(brokencode, "spam", "exec")
+    except SyntaxError, e:
+        vereq(e.filename, "spam")
+    else:
+        raise TestFailed("no SyntaxError for %r" % (brokencode,))
+checkfilename("def f(x): foo)(")  # parse-time
+checkfilename("def f(x): global x")  # symtable-build-time
index c5c4f6376f454cedf94c65a469bf836dbe19230b..a40190ee86bc62e42bab12af3bc9a7f31b42a5f2 100644 (file)
@@ -1,5 +1,6 @@
 import re
 import unittest
+import warnings
 
 from test import test_support
 
@@ -27,6 +28,20 @@ class SyntaxTestCase(unittest.TestCase):
     def test_assign_del(self):
         self._check_error("del f()", "delete")
 
+    def test_global_err_then_warn(self):
+        # Bug tickler:  The SyntaxError raised for one global statement
+        # shouldn't be clobbered by a SyntaxWarning issued for a later one.
+        source = re.sub('(?m)^ *:', '', """\
+            :def error(a):
+            :    global a  # SyntaxError
+            :def warning():
+            :    b = 1
+            :    global b  # SyntaxWarning
+            :""")
+        warnings.filterwarnings(action='ignore', category=SyntaxWarning)
+        self._check_error(source, "global")
+        warnings.filters.pop(0)
+
 def test_main():
     test_support.run_unittest(SyntaxTestCase)