blob: 48f1643be89122bf7c21390af6b7ed72f45373fa [file] [log] [blame]
Jeremy Hylton4336eda2004-08-07 19:25:33 +00001import compiler
Neil Schemenauerf3694702005-06-02 05:55:20 +00002from compiler.ast import flatten
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00003import os, sys, time, unittest
Jeremy Hylton4336eda2004-08-07 19:25:33 +00004import test.test_support
Raymond Hettingered20ad82004-09-04 20:09:13 +00005from random import random
Jeremy Hylton4336eda2004-08-07 19:25:33 +00006
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00007# How much time in seconds can pass before we print a 'Still working' message.
8_PRINT_WORKING_MSG_INTERVAL = 5 * 60
9
Jeremy Hylton4336eda2004-08-07 19:25:33 +000010class CompilerTest(unittest.TestCase):
11
12 def testCompileLibrary(self):
13 # A simple but large test. Compile all the code in the
14 # standard library and its test suite. This doesn't verify
15 # that any of the code is correct, merely the compiler is able
16 # to generate some kind of code for it.
Tim Peters2841af42006-01-07 23:20:46 +000017
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000018 next_time = time.time() + _PRINT_WORKING_MSG_INTERVAL
Jeremy Hylton4336eda2004-08-07 19:25:33 +000019 libdir = os.path.dirname(unittest.__file__)
20 testdir = os.path.dirname(test.test_support.__file__)
21
22 for dir in [libdir, testdir]:
Tim Peters2a5f6562004-08-08 16:37:37 +000023 for basename in os.listdir(dir):
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000024 # Print still working message since this test can be really slow
25 if next_time <= time.time():
26 next_time = time.time() + _PRINT_WORKING_MSG_INTERVAL
27 print >>sys.__stdout__, \
28 ' testCompileLibrary still working, be patient...'
Thomas Wouters477c8d52006-05-27 19:21:47 +000029 sys.__stdout__.flush()
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000030
Tim Peters2a5f6562004-08-08 16:37:37 +000031 if not basename.endswith(".py"):
Jeremy Hylton4336eda2004-08-07 19:25:33 +000032 continue
Guido van Rossum5bde08d2006-03-02 04:24:01 +000033 if not TEST_ALL and random() < 0.98:
Raymond Hettingered20ad82004-09-04 20:09:13 +000034 continue
Tim Peters2a5f6562004-08-08 16:37:37 +000035 path = os.path.join(dir, basename)
Tim Petersb6ecc162004-08-08 16:32:54 +000036 if test.test_support.verbose:
Tim Peters2a5f6562004-08-08 16:37:37 +000037 print "compiling", path
Michael W. Hudson29589a02004-10-11 15:34:31 +000038 f = open(path, "U")
Jeremy Hylton4336eda2004-08-07 19:25:33 +000039 buf = f.read()
40 f.close()
Neal Norwitzf8950652005-10-24 00:01:37 +000041 if "badsyntax" in basename or "bad_coding" in basename:
Tim Peters0955f292004-08-08 16:43:59 +000042 self.assertRaises(SyntaxError, compiler.compile,
43 buf, basename, "exec")
44 else:
Martin v. Löwis15bfc3b2006-03-01 21:11:49 +000045 try:
46 compiler.compile(buf, basename, "exec")
47 except Exception, e:
Martin v. Löwisd9bfeac2006-03-01 23:24:34 +000048 args = list(e.args)
49 args[0] += "[in file %s]" % basename
50 e.args = tuple(args)
Martin v. Löwis15bfc3b2006-03-01 21:11:49 +000051 raise
Jeremy Hylton4336eda2004-08-07 19:25:33 +000052
Brett Cannonf4189912005-04-09 02:30:16 +000053 def testNewClassSyntax(self):
54 compiler.compile("class foo():pass\n\n","<string>","exec")
Tim Peterse8906822005-04-20 17:45:13 +000055
Guido van Rossum5bde08d2006-03-02 04:24:01 +000056 def testYieldExpr(self):
57 compiler.compile("def g(): yield\n\n", "<string>", "exec")
58
Thomas Wouters477c8d52006-05-27 19:21:47 +000059 def testDefaultArgs(self):
60 self.assertRaises(SyntaxError, compiler.parse, "def foo(a=1, b): pass")
61
Jeremy Hylton566d9342004-09-07 15:28:01 +000062 def testLineNo(self):
63 # Test that all nodes except Module have a correct lineno attribute.
64 filename = __file__
65 if filename.endswith(".pyc") or filename.endswith(".pyo"):
66 filename = filename[:-1]
67 tree = compiler.parseFile(filename)
68 self.check_lineno(tree)
69
70 def check_lineno(self, node):
71 try:
72 self._check_lineno(node)
73 except AssertionError:
74 print node.__class__, node.lineno
75 raise
76
77 def _check_lineno(self, node):
78 if not node.__class__ in NOLINENO:
Tim Peters0e9980f2004-09-12 03:49:31 +000079 self.assert_(isinstance(node.lineno, int),
Jeremy Hylton566d9342004-09-07 15:28:01 +000080 "lineno=%s on %s" % (node.lineno, node.__class__))
Tim Peters0e9980f2004-09-12 03:49:31 +000081 self.assert_(node.lineno > 0,
Jeremy Hylton566d9342004-09-07 15:28:01 +000082 "lineno=%s on %s" % (node.lineno, node.__class__))
83 for child in node.getChildNodes():
84 self.check_lineno(child)
85
Neil Schemenauerf3694702005-06-02 05:55:20 +000086 def testFlatten(self):
87 self.assertEquals(flatten([1, [2]]), [1, 2])
88 self.assertEquals(flatten((1, (2,))), [1, 2])
89
Jeremy Hylton566d9342004-09-07 15:28:01 +000090NOLINENO = (compiler.ast.Module, compiler.ast.Stmt, compiler.ast.Discard)
91
92###############################################################################
93# code below is just used to trigger some possible errors, for the benefit of
94# testLineNo
95###############################################################################
96
97class Toto:
98 """docstring"""
99 pass
100
101a, b = 2, 3
102[c, d] = 5, 6
103l = [(x, y) for x, y in zip(range(5), range(5,10))]
104l[0]
105l[3:4]
106if l:
107 pass
108else:
109 a, b = b, a
110
111try:
112 print yo
113except:
114 yo = 3
115else:
116 yo += 3
Tim Peters0e9980f2004-09-12 03:49:31 +0000117
Jeremy Hylton566d9342004-09-07 15:28:01 +0000118try:
119 a += b
120finally:
121 b = 0
Tim Peters0e9980f2004-09-12 03:49:31 +0000122
Michael W. Hudsone0b855f2004-11-08 16:46:02 +0000123from math import *
124
Jeremy Hylton566d9342004-09-07 15:28:01 +0000125###############################################################################
126
Jeremy Hylton4336eda2004-08-07 19:25:33 +0000127def test_main():
Raymond Hettingered20ad82004-09-04 20:09:13 +0000128 global TEST_ALL
129 TEST_ALL = test.test_support.is_resource_enabled("compiler")
Jeremy Hylton4336eda2004-08-07 19:25:33 +0000130 test.test_support.run_unittest(CompilerTest)
131
132if __name__ == "__main__":
133 test_main()