From 458120dd40db6b4df55a4e96b650e16798ef06a0 Mon Sep 17 00:00:00 2001 From: cinap_lenrek Date: Tue, 3 May 2011 11:25:13 +0000 Subject: add hg and python --- sys/lib/python/test/test_symtable.py | 44 ++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 sys/lib/python/test/test_symtable.py (limited to 'sys/lib/python/test/test_symtable.py') diff --git a/sys/lib/python/test/test_symtable.py b/sys/lib/python/test/test_symtable.py new file mode 100644 index 000000000..74a7c8559 --- /dev/null +++ b/sys/lib/python/test/test_symtable.py @@ -0,0 +1,44 @@ +from test import test_support + +import symtable +import unittest + + +## XXX +## Test disabled because symtable module needs to be rewritten for new compiler + +##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 + +class SymtableTest(unittest.TestCase): + def test_invalid_args(self): + self.assertRaises(TypeError, symtable.symtable, "42") + self.assertRaises(ValueError, symtable.symtable, "42", "?", "") + + def test_eval(self): + symbols = symtable.symtable("42", "?", "eval") + + def test_single(self): + symbols = symtable.symtable("42", "?", "single") + + def test_exec(self): + symbols = symtable.symtable("def f(x): return x", "?", "exec") + + +def test_main(): + test_support.run_unittest(SymtableTest) + +if __name__ == '__main__': + test_main() -- cgit v1.2.3