blob: 483bc1828980793a2e17cf87d36ede427ace90bc [file] [log] [blame]
Jeremy Hylton4336eda2004-08-07 19:25:33 +00001import compiler
Neil Schemenauerf3694702005-06-02 05:55:20 +00002from compiler.ast import flatten
Neal Norwitz07c60712006-04-13 06:34:59 +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
Neal Norwitz07c60712006-04-13 06:34:59 +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
Neal Norwitz07c60712006-04-13 06:34:59 +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):
Neal Norwitz07c60712006-04-13 06:34:59 +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...'
Neal Norwitzdd28d1c2006-04-28 04:34:43 +000029 sys.__stdout__.flush()
Neal Norwitz07c60712006-04-13 06:34:59 +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
Jeremy Hylton566d9342004-09-07 15:28:01 +000059 def testLineNo(self):
60 # Test that all nodes except Module have a correct lineno attribute.
61 filename = __file__
62 if filename.endswith(".pyc") or filename.endswith(".pyo"):
63 filename = filename[:-1]
64 tree = compiler.parseFile(filename)
65 self.check_lineno(tree)
66
67 def check_lineno(self, node):
68 try:
69 self._check_lineno(node)
70 except AssertionError:
71 print node.__class__, node.lineno
72 raise
73
74 def _check_lineno(self, node):
75 if not node.__class__ in NOLINENO:
Tim Peters0e9980f2004-09-12 03:49:31 +000076 self.assert_(isinstance(node.lineno, int),
Jeremy Hylton566d9342004-09-07 15:28:01 +000077 "lineno=%s on %s" % (node.lineno, node.__class__))
Tim Peters0e9980f2004-09-12 03:49:31 +000078 self.assert_(node.lineno > 0,
Jeremy Hylton566d9342004-09-07 15:28:01 +000079 "lineno=%s on %s" % (node.lineno, node.__class__))
80 for child in node.getChildNodes():
81 self.check_lineno(child)
82
Neil Schemenauerf3694702005-06-02 05:55:20 +000083 def testFlatten(self):
84 self.assertEquals(flatten([1, [2]]), [1, 2])
85 self.assertEquals(flatten((1, (2,))), [1, 2])
86
Jeremy Hylton566d9342004-09-07 15:28:01 +000087NOLINENO = (compiler.ast.Module, compiler.ast.Stmt, compiler.ast.Discard)
88
89###############################################################################
90# code below is just used to trigger some possible errors, for the benefit of
91# testLineNo
92###############################################################################
93
94class Toto:
95 """docstring"""
96 pass
97
98a, b = 2, 3
99[c, d] = 5, 6
100l = [(x, y) for x, y in zip(range(5), range(5,10))]
101l[0]
102l[3:4]
103if l:
104 pass
105else:
106 a, b = b, a
107
108try:
109 print yo
110except:
111 yo = 3
112else:
113 yo += 3
Tim Peters0e9980f2004-09-12 03:49:31 +0000114
Jeremy Hylton566d9342004-09-07 15:28:01 +0000115try:
116 a += b
117finally:
118 b = 0
Tim Peters0e9980f2004-09-12 03:49:31 +0000119
Michael W. Hudsone0b855f2004-11-08 16:46:02 +0000120from math import *
121
Jeremy Hylton566d9342004-09-07 15:28:01 +0000122###############################################################################
123
Jeremy Hylton4336eda2004-08-07 19:25:33 +0000124def test_main():
Raymond Hettingered20ad82004-09-04 20:09:13 +0000125 global TEST_ALL
126 TEST_ALL = test.test_support.is_resource_enabled("compiler")
Jeremy Hylton4336eda2004-08-07 19:25:33 +0000127 test.test_support.run_unittest(CompilerTest)
128
129if __name__ == "__main__":
130 test_main()