blob: b5a5c5d8f912d1bc3184714fc891edb69aa607aa [file] [log] [blame]
Jeremy Hyltonc960f262006-01-27 15:18:39 +00001"""This module tests SyntaxErrors.
2
3Here's an example of the sort of thing that is tested.
4
5>>> def f(x):
6... global x
7Traceback (most recent call last):
Nick Coghlan650f0d02007-04-15 12:05:43 +00008SyntaxError: name 'x' is parameter and global
Jeremy Hyltonc960f262006-01-27 15:18:39 +00009
10The tests are all raise SyntaxErrors. They were created by checking
11each C call that raises SyntaxError. There are several modules that
12raise these exceptions-- ast.c, compile.c, future.c, pythonrun.c, and
13symtable.c.
14
15The parser itself outlaws a lot of invalid syntax. None of these
16errors are tested here at the moment. We should add some tests; since
17there are infinitely many programs with invalid syntax, we would need
18to be judicious in selecting some.
19
20The compiler generates a synthetic module name for code executed by
21doctest. Since all the code comes from the same module, a suffix like
22[1] is appended to the module name, As a consequence, changing the
23order of tests in this module means renumbering all the errors after
24it. (Maybe we should enable the ellipsis option for these tests.)
25
26In ast.c, syntax errors are raised by calling ast_error().
27
28Errors from set_context():
29
30TODO(jhylton): "assignment to None" is inconsistent with other messages
31
32>>> obj.None = 1
33Traceback (most recent call last):
34SyntaxError: assignment to None (<doctest test.test_syntax[1]>, line 1)
35
36>>> None = 1
37Traceback (most recent call last):
38SyntaxError: assignment to None (<doctest test.test_syntax[2]>, line 1)
39
40It's a syntax error to assign to the empty tuple. Why isn't it an
41error to assign to the empty list? It will always raise some error at
42runtime.
43
44>>> () = 1
45Traceback (most recent call last):
46SyntaxError: can't assign to () (<doctest test.test_syntax[3]>, line 1)
47
48>>> f() = 1
49Traceback (most recent call last):
50SyntaxError: can't assign to function call (<doctest test.test_syntax[4]>, line 1)
51
52>>> del f()
53Traceback (most recent call last):
54SyntaxError: can't delete function call (<doctest test.test_syntax[5]>, line 1)
55
56>>> a + 1 = 2
57Traceback (most recent call last):
58SyntaxError: can't assign to operator (<doctest test.test_syntax[6]>, line 1)
59
60>>> (x for x in x) = 1
61Traceback (most recent call last):
62SyntaxError: can't assign to generator expression (<doctest test.test_syntax[7]>, line 1)
63
64>>> 1 = 1
65Traceback (most recent call last):
66SyntaxError: can't assign to literal (<doctest test.test_syntax[8]>, line 1)
67
68>>> "abc" = 1
69Traceback (most recent call last):
70SyntaxError: can't assign to literal (<doctest test.test_syntax[9]>, line 1)
71
72>>> `1` = 1
73Traceback (most recent call last):
Brett Cannon8933cb42006-08-25 04:12:10 +000074SyntaxError: invalid syntax
Jeremy Hyltonc960f262006-01-27 15:18:39 +000075
76If the left-hand side of an assignment is a list or tuple, an illegal
77expression inside that contain should still cause a syntax error.
78This test just checks a couple of cases rather than enumerating all of
79them.
80
81>>> (a, "b", c) = (1, 2, 3)
82Traceback (most recent call last):
83SyntaxError: can't assign to literal (<doctest test.test_syntax[11]>, line 1)
84
85>>> [a, b, c + 1] = [1, 2, 3]
86Traceback (most recent call last):
87SyntaxError: can't assign to operator (<doctest test.test_syntax[12]>, line 1)
88
Thomas Wouters477c8d52006-05-27 19:21:47 +000089>>> a if 1 else b = 1
90Traceback (most recent call last):
91SyntaxError: can't assign to conditional expression (<doctest test.test_syntax[13]>, line 1)
Jeremy Hyltonc960f262006-01-27 15:18:39 +000092
93From compiler_complex_args():
94
95>>> def f(None=1):
96... pass
97Traceback (most recent call last):
Thomas Wouters477c8d52006-05-27 19:21:47 +000098SyntaxError: assignment to None (<doctest test.test_syntax[14]>, line 1)
Jeremy Hyltonc960f262006-01-27 15:18:39 +000099
100
101From ast_for_arguments():
102
103>>> def f(x, y=1, z):
104... pass
105Traceback (most recent call last):
Thomas Wouters477c8d52006-05-27 19:21:47 +0000106SyntaxError: non-default argument follows default argument (<doctest test.test_syntax[15]>, line 1)
Jeremy Hyltonc960f262006-01-27 15:18:39 +0000107
108>>> def f(x, None):
109... pass
110Traceback (most recent call last):
Thomas Wouters477c8d52006-05-27 19:21:47 +0000111SyntaxError: assignment to None (<doctest test.test_syntax[16]>, line 1)
Jeremy Hyltonc960f262006-01-27 15:18:39 +0000112
113>>> def f(*None):
114... pass
115Traceback (most recent call last):
Thomas Wouters477c8d52006-05-27 19:21:47 +0000116SyntaxError: assignment to None (<doctest test.test_syntax[17]>, line 1)
Jeremy Hyltonc960f262006-01-27 15:18:39 +0000117
118>>> def f(**None):
119... pass
120Traceback (most recent call last):
Thomas Wouters477c8d52006-05-27 19:21:47 +0000121SyntaxError: assignment to None (<doctest test.test_syntax[18]>, line 1)
Jeremy Hyltonc960f262006-01-27 15:18:39 +0000122
123
124From ast_for_funcdef():
125
126>>> def None(x):
127... pass
128Traceback (most recent call last):
Thomas Wouters477c8d52006-05-27 19:21:47 +0000129SyntaxError: assignment to None (<doctest test.test_syntax[19]>, line 1)
Jeremy Hyltonc960f262006-01-27 15:18:39 +0000130
131
132From ast_for_call():
133
134>>> def f(it, *varargs):
135... return list(it)
136>>> L = range(10)
137>>> f(x for x in L)
138[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
139>>> f(x for x in L, 1)
140Traceback (most recent call last):
Thomas Wouters477c8d52006-05-27 19:21:47 +0000141SyntaxError: Generator expression must be parenthesized if not sole argument (<doctest test.test_syntax[23]>, line 1)
Jeremy Hyltonc960f262006-01-27 15:18:39 +0000142>>> f((x for x in L), 1)
143[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
144
145>>> f(i0, i1, i2, i3, i4, i5, i6, i7, i8, i9, i10, i11,
146... i12, i13, i14, i15, i16, i17, i18, i19, i20, i21, i22,
147... i23, i24, i25, i26, i27, i28, i29, i30, i31, i32, i33,
148... i34, i35, i36, i37, i38, i39, i40, i41, i42, i43, i44,
149... i45, i46, i47, i48, i49, i50, i51, i52, i53, i54, i55,
150... i56, i57, i58, i59, i60, i61, i62, i63, i64, i65, i66,
151... i67, i68, i69, i70, i71, i72, i73, i74, i75, i76, i77,
152... i78, i79, i80, i81, i82, i83, i84, i85, i86, i87, i88,
153... i89, i90, i91, i92, i93, i94, i95, i96, i97, i98, i99,
154... i100, i101, i102, i103, i104, i105, i106, i107, i108,
155... i109, i110, i111, i112, i113, i114, i115, i116, i117,
156... i118, i119, i120, i121, i122, i123, i124, i125, i126,
157... i127, i128, i129, i130, i131, i132, i133, i134, i135,
158... i136, i137, i138, i139, i140, i141, i142, i143, i144,
159... i145, i146, i147, i148, i149, i150, i151, i152, i153,
160... i154, i155, i156, i157, i158, i159, i160, i161, i162,
161... i163, i164, i165, i166, i167, i168, i169, i170, i171,
162... i172, i173, i174, i175, i176, i177, i178, i179, i180,
163... i181, i182, i183, i184, i185, i186, i187, i188, i189,
164... i190, i191, i192, i193, i194, i195, i196, i197, i198,
165... i199, i200, i201, i202, i203, i204, i205, i206, i207,
166... i208, i209, i210, i211, i212, i213, i214, i215, i216,
167... i217, i218, i219, i220, i221, i222, i223, i224, i225,
168... i226, i227, i228, i229, i230, i231, i232, i233, i234,
169... i235, i236, i237, i238, i239, i240, i241, i242, i243,
170... i244, i245, i246, i247, i248, i249, i250, i251, i252,
171... i253, i254, i255)
172Traceback (most recent call last):
Thomas Wouters477c8d52006-05-27 19:21:47 +0000173SyntaxError: more than 255 arguments (<doctest test.test_syntax[25]>, line 1)
Jeremy Hyltonc960f262006-01-27 15:18:39 +0000174
175The actual error cases counts positional arguments, keyword arguments,
176and generator expression arguments separately. This test combines the
177three.
178
179>>> f(i0, i1, i2, i3, i4, i5, i6, i7, i8, i9, i10, i11,
180... i12, i13, i14, i15, i16, i17, i18, i19, i20, i21, i22,
181... i23, i24, i25, i26, i27, i28, i29, i30, i31, i32, i33,
182... i34, i35, i36, i37, i38, i39, i40, i41, i42, i43, i44,
183... i45, i46, i47, i48, i49, i50, i51, i52, i53, i54, i55,
184... i56, i57, i58, i59, i60, i61, i62, i63, i64, i65, i66,
185... i67, i68, i69, i70, i71, i72, i73, i74, i75, i76, i77,
186... i78, i79, i80, i81, i82, i83, i84, i85, i86, i87, i88,
187... i89, i90, i91, i92, i93, i94, i95, i96, i97, i98, i99,
188... i100, i101, i102, i103, i104, i105, i106, i107, i108,
189... i109, i110, i111, i112, i113, i114, i115, i116, i117,
190... i118, i119, i120, i121, i122, i123, i124, i125, i126,
191... i127, i128, i129, i130, i131, i132, i133, i134, i135,
192... i136, i137, i138, i139, i140, i141, i142, i143, i144,
193... i145, i146, i147, i148, i149, i150, i151, i152, i153,
194... i154, i155, i156, i157, i158, i159, i160, i161, i162,
195... i163, i164, i165, i166, i167, i168, i169, i170, i171,
196... i172, i173, i174, i175, i176, i177, i178, i179, i180,
197... i181, i182, i183, i184, i185, i186, i187, i188, i189,
198... i190, i191, i192, i193, i194, i195, i196, i197, i198,
199... i199, i200, i201, i202, i203, i204, i205, i206, i207,
200... i208, i209, i210, i211, i212, i213, i214, i215, i216,
201... i217, i218, i219, i220, i221, i222, i223, i224, i225,
202... i226, i227, i228, i229, i230, i231, i232, i233, i234,
203... i235, i236, i237, i238, i239, i240, i241, i242, i243,
204... (x for x in i244), i245, i246, i247, i248, i249, i250, i251,
205... i252=1, i253=1, i254=1, i255=1)
206Traceback (most recent call last):
Thomas Wouters477c8d52006-05-27 19:21:47 +0000207SyntaxError: more than 255 arguments (<doctest test.test_syntax[26]>, line 1)
Jeremy Hyltonc960f262006-01-27 15:18:39 +0000208
209>>> f(lambda x: x[0] = 3)
210Traceback (most recent call last):
Thomas Wouters477c8d52006-05-27 19:21:47 +0000211SyntaxError: lambda cannot contain assignment (<doctest test.test_syntax[27]>, line 1)
Jeremy Hyltonc960f262006-01-27 15:18:39 +0000212
213The grammar accepts any test (basically, any expression) in the
214keyword slot of a call site. Test a few different options.
215
216>>> f(x()=2)
217Traceback (most recent call last):
Thomas Wouters477c8d52006-05-27 19:21:47 +0000218SyntaxError: keyword can't be an expression (<doctest test.test_syntax[28]>, line 1)
Jeremy Hyltonc960f262006-01-27 15:18:39 +0000219>>> f(a or b=1)
220Traceback (most recent call last):
Thomas Wouters477c8d52006-05-27 19:21:47 +0000221SyntaxError: keyword can't be an expression (<doctest test.test_syntax[29]>, line 1)
Jeremy Hyltonc960f262006-01-27 15:18:39 +0000222>>> f(x.y=1)
223Traceback (most recent call last):
Thomas Wouters477c8d52006-05-27 19:21:47 +0000224SyntaxError: keyword can't be an expression (<doctest test.test_syntax[30]>, line 1)
Jeremy Hyltonc960f262006-01-27 15:18:39 +0000225
226
227From ast_for_expr_stmt():
228
229>>> (x for x in x) += 1
230Traceback (most recent call last):
Thomas Wouters477c8d52006-05-27 19:21:47 +0000231SyntaxError: augmented assignment to generator expression not possible (<doctest test.test_syntax[31]>, line 1)
Jeremy Hyltonc960f262006-01-27 15:18:39 +0000232>>> None += 1
233Traceback (most recent call last):
Thomas Wouters477c8d52006-05-27 19:21:47 +0000234SyntaxError: assignment to None (<doctest test.test_syntax[32]>, line 1)
Jeremy Hyltonc960f262006-01-27 15:18:39 +0000235>>> f() += 1
236Traceback (most recent call last):
Thomas Wouters477c8d52006-05-27 19:21:47 +0000237SyntaxError: illegal expression for augmented assignment (<doctest test.test_syntax[33]>, line 1)
Thomas Wouters89f507f2006-12-13 04:49:30 +0000238
239
240Test continue in finally in weird combinations.
241
242continue in for loop under finally shouuld be ok.
243
244 >>> def test():
245 ... try:
246 ... pass
247 ... finally:
248 ... for abc in range(10):
249 ... continue
Guido van Rossum7131f842007-02-09 20:13:25 +0000250 ... print(abc)
Thomas Wouters89f507f2006-12-13 04:49:30 +0000251 >>> test()
252 9
253
254Start simple, a continue in a finally should not be allowed.
255
256 >>> def test():
257 ... for abc in range(10):
258 ... try:
259 ... pass
260 ... finally:
261 ... continue
262 Traceback (most recent call last):
263 ...
264 SyntaxError: 'continue' not supported inside 'finally' clause (<doctest test.test_syntax[36]>, line 6)
265
266This is essentially a continue in a finally which should not be allowed.
267
268 >>> def test():
269 ... for abc in range(10):
270 ... try:
271 ... pass
272 ... finally:
273 ... try:
274 ... continue
275 ... except:
276 ... pass
277 Traceback (most recent call last):
278 ...
279 SyntaxError: 'continue' not supported inside 'finally' clause (<doctest test.test_syntax[37]>, line 7)
280
281 >>> def foo():
282 ... try:
283 ... pass
284 ... finally:
285 ... continue
286 Traceback (most recent call last):
287 ...
288 SyntaxError: 'continue' not supported inside 'finally' clause (<doctest test.test_syntax[38]>, line 5)
289
290 >>> def foo():
291 ... for a in ():
292 ... try:
293 ... pass
294 ... finally:
295 ... continue
296 Traceback (most recent call last):
297 ...
298 SyntaxError: 'continue' not supported inside 'finally' clause (<doctest test.test_syntax[39]>, line 6)
299
300 >>> def foo():
301 ... for a in ():
302 ... try:
303 ... pass
304 ... finally:
305 ... try:
306 ... continue
307 ... finally:
308 ... pass
309 Traceback (most recent call last):
310 ...
311 SyntaxError: 'continue' not supported inside 'finally' clause (<doctest test.test_syntax[40]>, line 7)
312
313 >>> def foo():
314 ... for a in ():
315 ... try: pass
316 ... finally:
317 ... try:
318 ... pass
319 ... except:
320 ... continue
321 Traceback (most recent call last):
322 ...
323 SyntaxError: 'continue' not supported inside 'finally' clause (<doctest test.test_syntax[41]>, line 8)
324
325There is one test for a break that is not in a loop. The compiler
326uses a single data structure to keep track of try-finally and loops,
327so we need to be sure that a break is actually inside a loop. If it
328isn't, there should be a syntax error.
329
330 >>> try:
Guido van Rossum7131f842007-02-09 20:13:25 +0000331 ... print(1)
Thomas Wouters89f507f2006-12-13 04:49:30 +0000332 ... break
Guido van Rossum7131f842007-02-09 20:13:25 +0000333 ... print(2)
Thomas Wouters89f507f2006-12-13 04:49:30 +0000334 ... finally:
Guido van Rossum7131f842007-02-09 20:13:25 +0000335 ... print(3)
Thomas Wouters89f507f2006-12-13 04:49:30 +0000336 Traceback (most recent call last):
337 ...
338 SyntaxError: 'break' outside loop (<doctest test.test_syntax[42]>, line 3)
339
340This should probably raise a better error than a SystemError (or none at all).
341In 2.5 there was a missing exception and an assert was triggered in a debug
342build. The number of blocks must be greater than CO_MAXBLOCKS. SF #1565514
343
344 >>> while 1:
345 ... while 2:
346 ... while 3:
347 ... while 4:
348 ... while 5:
349 ... while 6:
350 ... while 8:
351 ... while 9:
352 ... while 10:
353 ... while 11:
354 ... while 12:
355 ... while 13:
356 ... while 14:
357 ... while 15:
358 ... while 16:
359 ... while 17:
360 ... while 18:
361 ... while 19:
362 ... while 20:
363 ... while 21:
364 ... while 22:
365 ... break
366 Traceback (most recent call last):
367 ...
368 SystemError: too many statically nested blocks
369
Jeremy Hylton81e95022007-02-27 06:50:52 +0000370Misuse of the nonlocal statement can lead to a few unique syntax errors.
371
372 >>> def f(x):
373 ... nonlocal x
374 Traceback (most recent call last):
375 ...
Nick Coghlan650f0d02007-04-15 12:05:43 +0000376 SyntaxError: name 'x' is parameter and nonlocal
Jeremy Hylton81e95022007-02-27 06:50:52 +0000377
378 >>> def f():
379 ... global x
380 ... nonlocal x
381 Traceback (most recent call last):
382 ...
383 SyntaxError: name 'x' is nonlocal and global
384
385 >>> def f():
386 ... nonlocal x
387 Traceback (most recent call last):
388 ...
389 SyntaxError: no binding for nonlocal 'x' found
390
Nick Coghlan4138bfe2007-04-23 10:14:27 +0000391From SF bug #1705365
392 >>> nonlocal x
393 Traceback (most recent call last):
394 ...
395 SyntaxError: nonlocal declaration not allowed at module level
396
Jeremy Hylton81e95022007-02-27 06:50:52 +0000397TODO(jhylton): Figure out how to test SyntaxWarning with doctest.
398
399## >>> def f(x):
400## ... def f():
401## ... print(x)
402## ... nonlocal x
403## Traceback (most recent call last):
404## ...
405## SyntaxWarning: name 'x' is assigned to before nonlocal declaration
406
407## >>> def f():
408## ... x = 1
409## ... nonlocal x
410## Traceback (most recent call last):
411## ...
412## SyntaxWarning: name 'x' is assigned to before nonlocal declaration
413
414
415
Jeremy Hyltonc960f262006-01-27 15:18:39 +0000416"""
417
Jeremy Hylton05ab2e62002-05-31 14:08:29 +0000418import re
419import unittest
Jeremy Hylton42d90162003-07-15 20:24:27 +0000420import warnings
Jeremy Hylton05ab2e62002-05-31 14:08:29 +0000421
Barry Warsaw04f357c2002-07-23 19:04:11 +0000422from test import test_support
Jeremy Hylton05ab2e62002-05-31 14:08:29 +0000423
424class SyntaxTestCase(unittest.TestCase):
425
426 def _check_error(self, code, errtext,
Thomas Wouters477c8d52006-05-27 19:21:47 +0000427 filename="<testcase>", mode="exec", subclass=None):
Jeremy Hylton05ab2e62002-05-31 14:08:29 +0000428 """Check that compiling code raises SyntaxError with errtext.
429
430 errtest is a regular expression that must be present in the
Thomas Wouters477c8d52006-05-27 19:21:47 +0000431 test of the exception raised. If subclass is specified it
432 is the expected subclass of SyntaxError (e.g. IndentationError).
Jeremy Hylton05ab2e62002-05-31 14:08:29 +0000433 """
434 try:
435 compile(code, filename, mode)
Guido van Rossumb940e112007-01-10 16:19:56 +0000436 except SyntaxError as err:
Thomas Wouters477c8d52006-05-27 19:21:47 +0000437 if subclass and not isinstance(err, subclass):
438 self.fail("SyntaxError is not a %s" % subclass.__name__)
Jeremy Hylton05ab2e62002-05-31 14:08:29 +0000439 mo = re.search(errtext, str(err))
440 if mo is None:
Walter Dörwald70a6b492004-02-12 17:35:32 +0000441 self.fail("SyntaxError did not contain '%r'" % (errtext,))
Jeremy Hylton05ab2e62002-05-31 14:08:29 +0000442 else:
443 self.fail("compile() did not raise SyntaxError")
444
445 def test_assign_call(self):
446 self._check_error("f() = 1", "assign")
447
448 def test_assign_del(self):
449 self._check_error("del f()", "delete")
450
Jeremy Hylton42d90162003-07-15 20:24:27 +0000451 def test_global_err_then_warn(self):
452 # Bug tickler: The SyntaxError raised for one global statement
453 # shouldn't be clobbered by a SyntaxWarning issued for a later one.
454 source = re.sub('(?m)^ *:', '', """\
455 :def error(a):
456 : global a # SyntaxError
457 :def warning():
458 : b = 1
459 : global b # SyntaxWarning
460 :""")
461 warnings.filterwarnings(action='ignore', category=SyntaxWarning)
462 self._check_error(source, "global")
463 warnings.filters.pop(0)
464
Neal Norwitzfcf44352005-11-27 20:37:43 +0000465 def test_break_outside_loop(self):
466 self._check_error("break", "outside loop")
467
468 def test_delete_deref(self):
469 source = re.sub('(?m)^ *:', '', """\
470 :def foo(x):
471 : def bar():
Georg Brandl88fc6642007-02-09 21:28:07 +0000472 : print(x)
Neal Norwitzfcf44352005-11-27 20:37:43 +0000473 : del x
474 :""")
475 self._check_error(source, "nested scope")
476
Thomas Wouters477c8d52006-05-27 19:21:47 +0000477 def test_unexpected_indent(self):
478 self._check_error("foo()\n bar()\n", "unexpected indent",
479 subclass=IndentationError)
480
481 def test_no_indent(self):
482 self._check_error("if 1:\nfoo()", "expected an indented block",
483 subclass=IndentationError)
484
485 def test_bad_outdent(self):
486 self._check_error("if 1:\n foo()\n bar()",
487 "unindent does not match .* level",
488 subclass=IndentationError)
489
490 def test_kwargs_last(self):
491 self._check_error("int(base=10, '2')", "non-keyword arg")
492
Jeremy Hylton05ab2e62002-05-31 14:08:29 +0000493def test_main():
494 test_support.run_unittest(SyntaxTestCase)
Jeremy Hyltonc960f262006-01-27 15:18:39 +0000495 from test import test_syntax
496 test_support.run_doctest(test_syntax, verbosity=True)
Jeremy Hylton05ab2e62002-05-31 14:08:29 +0000497
498if __name__ == "__main__":
499 test_main()