diff options
author | Jeremy Hylton <jeremy@alum.mit.edu> | 2003-07-15 20:24:27 (GMT) |
---|---|---|
committer | Jeremy Hylton <jeremy@alum.mit.edu> | 2003-07-15 20:24:27 (GMT) |
commit | 42d90161e27cf7bf4cfdab44b5b13b6da1ef901c (patch) | |
tree | 877053b4dac1345ae75bb184f0a5401c284b1c74 /Lib/test/test_symtable.py | |
parent | 1955fcf67aebb99c06715864de468a6be6ab9a6c (diff) | |
download | cpython-42d90161e27cf7bf4cfdab44b5b13b6da1ef901c.zip cpython-42d90161e27cf7bf4cfdab44b5b13b6da1ef901c.tar.gz cpython-42d90161e27cf7bf4cfdab44b5b13b6da1ef901c.tar.bz2 |
SF patch 763201: handling of SyntaxErrors in symbol table build
Bug fix candidate.
Diffstat (limited to 'Lib/test/test_symtable.py')
-rw-r--r-- | Lib/test/test_symtable.py | 18 |
1 files changed, 15 insertions, 3 deletions
diff --git a/Lib/test/test_symtable.py b/Lib/test/test_symtable.py index 44f156e..5961102 100644 --- a/Lib/test/test_symtable.py +++ b/Lib/test/test_symtable.py @@ -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 |