blob: 3fac03d44525655dcf230602f716a05171517da5 [file] [log] [blame]
Victor Stinnerf2c1aa12016-01-26 00:40:57 +01001import ast
Victor Stinnere5fbe0c2020-09-15 18:03:34 +02002import builtins
Victor Stinnerf2c1aa12016-01-26 00:40:57 +01003import dis
Benjamin Peterson832bfe22011-08-09 16:15:04 -05004import os
5import sys
Victor Stinnere5fbe0c2020-09-15 18:03:34 +02006import types
Benjamin Peterson832bfe22011-08-09 16:15:04 -05007import unittest
Serhiy Storchakac3ea41e2019-08-26 10:13:19 +03008import warnings
Benjamin Peterson9ed37432012-07-08 11:13:36 -07009import weakref
Ivan Levkivskyi9932a222019-01-22 11:18:22 +000010from textwrap import dedent
Benjamin Peterson9ed37432012-07-08 11:13:36 -070011
12from test import support
Tim Peters400cbc32006-02-28 18:44:41 +000013
14def to_tuple(t):
Guido van Rossum3172c5d2007-10-16 18:12:55 +000015 if t is None or isinstance(t, (str, int, complex)):
Tim Peters400cbc32006-02-28 18:44:41 +000016 return t
17 elif isinstance(t, list):
18 return [to_tuple(e) for e in t]
19 result = [t.__class__.__name__]
Martin v. Löwis49c5da12006-03-01 22:49:05 +000020 if hasattr(t, 'lineno') and hasattr(t, 'col_offset'):
21 result.append((t.lineno, t.col_offset))
Serhiy Storchaka850a8852020-01-10 10:12:55 +020022 if hasattr(t, 'end_lineno') and hasattr(t, 'end_col_offset'):
23 result[-1] += (t.end_lineno, t.end_col_offset)
Tim Peters400cbc32006-02-28 18:44:41 +000024 if t._fields is None:
25 return tuple(result)
26 for f in t._fields:
27 result.append(to_tuple(getattr(t, f)))
28 return tuple(result)
29
Neal Norwitzee9b10a2008-03-31 05:29:39 +000030
Tim Peters400cbc32006-02-28 18:44:41 +000031# These tests are compiled through "exec"
Ezio Melotti85a86292013-08-17 16:57:41 +030032# There should be at least one test per statement
Tim Peters400cbc32006-02-28 18:44:41 +000033exec_tests = [
Benjamin Peterson6ccfe852011-06-27 17:46:06 -050034 # None
35 "None",
INADA Naokicb41b272017-02-23 00:31:59 +090036 # Module docstring
37 "'module docstring'",
Tim Peters400cbc32006-02-28 18:44:41 +000038 # FunctionDef
39 "def f(): pass",
INADA Naokicb41b272017-02-23 00:31:59 +090040 # FunctionDef with docstring
41 "def f(): 'function docstring'",
Benjamin Peterson6ccfe852011-06-27 17:46:06 -050042 # FunctionDef with arg
43 "def f(a): pass",
44 # FunctionDef with arg and default value
45 "def f(a=0): pass",
46 # FunctionDef with varargs
47 "def f(*args): pass",
48 # FunctionDef with kwargs
49 "def f(**kwargs): pass",
INADA Naokicb41b272017-02-23 00:31:59 +090050 # FunctionDef with all kind of args and docstring
51 "def f(a, b=1, c=None, d=[], e={}, *args, f=42, **kwargs): 'doc for f()'",
Tim Peters400cbc32006-02-28 18:44:41 +000052 # ClassDef
53 "class C:pass",
INADA Naokicb41b272017-02-23 00:31:59 +090054 # ClassDef with docstring
55 "class C: 'docstring for class C'",
Benjamin Peterson6ccfe852011-06-27 17:46:06 -050056 # ClassDef, new style class
57 "class C(object): pass",
Tim Peters400cbc32006-02-28 18:44:41 +000058 # Return
59 "def f():return 1",
60 # Delete
61 "del v",
62 # Assign
63 "v = 1",
Serhiy Storchakab619b092018-11-27 09:40:29 +020064 "a,b = c",
65 "(a,b) = c",
66 "[a,b] = c",
Tim Peters400cbc32006-02-28 18:44:41 +000067 # AugAssign
68 "v += 1",
Tim Peters400cbc32006-02-28 18:44:41 +000069 # For
70 "for v in v:pass",
71 # While
72 "while v:pass",
73 # If
74 "if v:pass",
Lysandros Nikolaou025a6022019-12-12 22:40:21 +010075 # If-Elif
76 "if a:\n pass\nelif b:\n pass",
Lysandros Nikolaou5936a4c2019-12-14 11:24:57 +010077 # If-Elif-Else
78 "if a:\n pass\nelif b:\n pass\nelse:\n pass",
Benjamin Petersonaeabd5f2011-05-27 15:02:03 -050079 # With
80 "with x as y: pass",
81 "with x as y, z as q: pass",
Tim Peters400cbc32006-02-28 18:44:41 +000082 # Raise
Collin Winter828f04a2007-08-31 00:04:24 +000083 "raise Exception('string')",
Tim Peters400cbc32006-02-28 18:44:41 +000084 # TryExcept
85 "try:\n pass\nexcept Exception:\n pass",
86 # TryFinally
87 "try:\n pass\nfinally:\n pass",
88 # Assert
89 "assert v",
90 # Import
91 "import sys",
92 # ImportFrom
93 "from sys import v",
Tim Peters400cbc32006-02-28 18:44:41 +000094 # Global
95 "global v",
96 # Expr
97 "1",
98 # Pass,
99 "pass",
100 # Break
Yury Selivanovb3d53132015-09-01 16:10:49 -0400101 "for v in v:break",
Tim Peters400cbc32006-02-28 18:44:41 +0000102 # Continue
Yury Selivanovb3d53132015-09-01 16:10:49 -0400103 "for v in v:continue",
Benjamin Peterson2e4b0e12009-09-11 22:36:20 +0000104 # for statements with naked tuples (see http://bugs.python.org/issue6704)
105 "for a,b in c: pass",
Serhiy Storchakab619b092018-11-27 09:40:29 +0200106 "for (a,b) in c: pass",
107 "for [a,b] in c: pass",
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500108 # Multiline generator expression (test for .lineno & .col_offset)
109 """(
110 (
111 Aa
112 ,
113 Bb
114 )
115 for
116 Aa
117 ,
118 Bb in Cc
119 )""",
120 # dictcomp
121 "{a : b for w in x for m in p if g}",
122 # dictcomp with naked tuple
123 "{a : b for v,w in x}",
124 # setcomp
125 "{r for l in x if g}",
126 # setcomp with naked tuple
127 "{r for l,m in x}",
Yury Selivanov75445082015-05-11 22:57:16 -0400128 # AsyncFunctionDef
INADA Naokicb41b272017-02-23 00:31:59 +0900129 "async def f():\n 'async function'\n await something()",
Yury Selivanov75445082015-05-11 22:57:16 -0400130 # AsyncFor
131 "async def f():\n async for e in i: 1\n else: 2",
132 # AsyncWith
133 "async def f():\n async with a as b: 1",
Yury Selivanovb3d53132015-09-01 16:10:49 -0400134 # PEP 448: Additional Unpacking Generalizations
135 "{**{1:2}, 2:3}",
136 "{*{1, 2}, 3}",
Yury Selivanov52c4e7c2016-09-09 10:36:01 -0700137 # Asynchronous comprehensions
138 "async def f():\n [i async for b in c]",
Serhiy Storchaka95b6acf2018-10-30 13:16:02 +0200139 # Decorated FunctionDef
Serhiy Storchaka26ae9f62019-10-26 16:46:05 +0300140 "@deco1\n@deco2()\n@deco3(1)\ndef f(): pass",
Serhiy Storchaka95b6acf2018-10-30 13:16:02 +0200141 # Decorated AsyncFunctionDef
Serhiy Storchaka26ae9f62019-10-26 16:46:05 +0300142 "@deco1\n@deco2()\n@deco3(1)\nasync def f(): pass",
Serhiy Storchaka95b6acf2018-10-30 13:16:02 +0200143 # Decorated ClassDef
Serhiy Storchaka26ae9f62019-10-26 16:46:05 +0300144 "@deco1\n@deco2()\n@deco3(1)\nclass C: pass",
Serhiy Storchakab619b092018-11-27 09:40:29 +0200145 # Decorator with generator argument
146 "@deco(a for a in b)\ndef f(): pass",
Lysandros Nikolaoud2e10982020-02-08 00:36:32 +0100147 # Decorator with attribute
148 "@a.b.c\ndef f(): pass",
Pablo Galindo0c9258a2019-03-18 13:51:53 +0000149 # Simple assignment expression
150 "(a := 1)",
Pablo Galindo2f58a842019-05-31 14:09:49 +0100151 # Positional-only arguments
152 "def f(a, /,): pass",
153 "def f(a, /, c, d, e): pass",
154 "def f(a, /, c, *, d, e): pass",
155 "def f(a, /, c, *, d, e, **kwargs): pass",
156 # Positional-only arguments with defaults
157 "def f(a=1, /,): pass",
158 "def f(a=1, /, b=2, c=4): pass",
159 "def f(a=1, /, b=2, *, c=4): pass",
160 "def f(a=1, /, b=2, *, c): pass",
161 "def f(a=1, /, b=2, *, c=4, **kwargs): pass",
162 "def f(a=1, /, b=2, *, c, **kwargs): pass",
Pablo Galindo0c9258a2019-03-18 13:51:53 +0000163
Tim Peters400cbc32006-02-28 18:44:41 +0000164]
165
166# These are compiled through "single"
167# because of overlap with "eval", it just tests what
168# can't be tested with "eval"
169single_tests = [
170 "1+2"
171]
172
173# These are compiled through "eval"
174# It should test all expressions
175eval_tests = [
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500176 # None
177 "None",
Tim Peters400cbc32006-02-28 18:44:41 +0000178 # BoolOp
179 "a and b",
180 # BinOp
181 "a + b",
182 # UnaryOp
183 "not v",
184 # Lambda
185 "lambda:None",
186 # Dict
187 "{ 1:2 }",
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500188 # Empty dict
189 "{}",
190 # Set
191 "{None,}",
192 # Multiline dict (test for .lineno & .col_offset)
193 """{
194 1
195 :
196 2
197 }""",
Tim Peters400cbc32006-02-28 18:44:41 +0000198 # ListComp
199 "[a for b in c if d]",
200 # GeneratorExp
201 "(a for b in c if d)",
Serhiy Storchakab619b092018-11-27 09:40:29 +0200202 # Comprehensions with multiple for targets
203 "[(a,b) for a,b in c]",
204 "[(a,b) for (a,b) in c]",
205 "[(a,b) for [a,b] in c]",
206 "{(a,b) for a,b in c}",
207 "{(a,b) for (a,b) in c}",
208 "{(a,b) for [a,b] in c}",
209 "((a,b) for a,b in c)",
210 "((a,b) for (a,b) in c)",
211 "((a,b) for [a,b] in c)",
Tim Peters400cbc32006-02-28 18:44:41 +0000212 # Yield - yield expressions can't work outside a function
213 #
214 # Compare
215 "1 < 2 < 3",
216 # Call
217 "f(1,2,c=3,*d,**e)",
Lysandros Nikolaou50d4f122019-12-18 01:20:55 +0100218 # Call with multi-character starred
219 "f(*[0, 1])",
Serhiy Storchakab619b092018-11-27 09:40:29 +0200220 # Call with a generator argument
221 "f(a for a in b)",
Tim Peters400cbc32006-02-28 18:44:41 +0000222 # Num
Guido van Rossume2a383d2007-01-15 16:59:06 +0000223 "10",
Tim Peters400cbc32006-02-28 18:44:41 +0000224 # Str
225 "'string'",
226 # Attribute
227 "a.b",
228 # Subscript
229 "a[b:c]",
230 # Name
231 "v",
232 # List
233 "[1,2,3]",
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500234 # Empty list
235 "[]",
Tim Peters400cbc32006-02-28 18:44:41 +0000236 # Tuple
Martin v. Löwis49c5da12006-03-01 22:49:05 +0000237 "1,2,3",
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500238 # Tuple
239 "(1,2,3)",
240 # Empty tuple
241 "()",
Martin v. Löwis49c5da12006-03-01 22:49:05 +0000242 # Combination
243 "a.b.c.d(a.b[1:2])",
244
Tim Peters400cbc32006-02-28 18:44:41 +0000245]
246
247# TODO: expr_context, slice, boolop, operator, unaryop, cmpop, comprehension
248# excepthandler, arguments, keywords, alias
249
Neal Norwitzee9b10a2008-03-31 05:29:39 +0000250class AST_Tests(unittest.TestCase):
Tim Peters400cbc32006-02-28 18:44:41 +0000251
Batuhan TaĹźkaya397b96f2020-03-01 23:12:17 +0300252 def _is_ast_node(self, name, node):
253 if not isinstance(node, type):
254 return False
255 if "ast" not in node.__module__:
256 return False
257 return name != 'AST' and name[0].isupper()
258
Benjamin Peterson7a66fc22015-02-02 10:51:20 -0500259 def _assertTrueorder(self, ast_node, parent_pos):
Georg Brandl0c77a822008-06-10 16:37:50 +0000260 if not isinstance(ast_node, ast.AST) or ast_node._fields is None:
Neal Norwitzee9b10a2008-03-31 05:29:39 +0000261 return
Georg Brandl0c77a822008-06-10 16:37:50 +0000262 if isinstance(ast_node, (ast.expr, ast.stmt, ast.excepthandler)):
Neal Norwitzee9b10a2008-03-31 05:29:39 +0000263 node_pos = (ast_node.lineno, ast_node.col_offset)
Serhiy Storchaka95b6acf2018-10-30 13:16:02 +0200264 self.assertGreaterEqual(node_pos, parent_pos)
Neal Norwitzee9b10a2008-03-31 05:29:39 +0000265 parent_pos = (ast_node.lineno, ast_node.col_offset)
266 for name in ast_node._fields:
267 value = getattr(ast_node, name)
268 if isinstance(value, list):
Serhiy Storchaka95b6acf2018-10-30 13:16:02 +0200269 first_pos = parent_pos
270 if value and name == 'decorator_list':
271 first_pos = (value[0].lineno, value[0].col_offset)
Neal Norwitzee9b10a2008-03-31 05:29:39 +0000272 for child in value:
Serhiy Storchaka95b6acf2018-10-30 13:16:02 +0200273 self._assertTrueorder(child, first_pos)
Neal Norwitzee9b10a2008-03-31 05:29:39 +0000274 elif value is not None:
Benjamin Peterson7a66fc22015-02-02 10:51:20 -0500275 self._assertTrueorder(value, parent_pos)
Brandt Bucher145bf262021-02-26 14:51:55 -0800276 self.assertEqual(ast_node._fields, ast_node.__match_args__)
Tim Peters5ddfe412006-03-01 23:02:57 +0000277
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500278 def test_AST_objects(self):
279 x = ast.AST()
280 self.assertEqual(x._fields, ())
Benjamin Peterson7e0dbfb2012-03-12 09:46:44 -0700281 x.foobar = 42
282 self.assertEqual(x.foobar, 42)
283 self.assertEqual(x.__dict__["foobar"], 42)
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500284
285 with self.assertRaises(AttributeError):
286 x.vararg
287
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500288 with self.assertRaises(TypeError):
Serhiy Storchakabace59d2020-03-22 20:33:34 +0200289 # "ast.AST constructor takes 0 positional arguments"
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500290 ast.AST(2)
291
Benjamin Peterson9ed37432012-07-08 11:13:36 -0700292 def test_AST_garbage_collection(self):
293 class X:
294 pass
295 a = ast.AST()
296 a.x = X()
297 a.x.a = a
298 ref = weakref.ref(a.x)
299 del a
300 support.gc_collect()
301 self.assertIsNone(ref())
302
Neal Norwitzee9b10a2008-03-31 05:29:39 +0000303 def test_snippets(self):
304 for input, output, kind in ((exec_tests, exec_results, "exec"),
305 (single_tests, single_results, "single"),
306 (eval_tests, eval_results, "eval")):
307 for i, o in zip(input, output):
Yury Selivanovb3d53132015-09-01 16:10:49 -0400308 with self.subTest(action="parsing", input=i):
309 ast_tree = compile(i, "?", kind, ast.PyCF_ONLY_AST)
310 self.assertEqual(to_tuple(ast_tree), o)
311 self._assertTrueorder(ast_tree, (0, 0))
Victor Stinner15a30952016-02-08 22:45:06 +0100312 with self.subTest(action="compiling", input=i, kind=kind):
313 compile(ast_tree, "?", kind)
Neal Norwitzee9b10a2008-03-31 05:29:39 +0000314
Pablo Galindo0c9258a2019-03-18 13:51:53 +0000315 def test_ast_validation(self):
316 # compile() is the only function that calls PyAST_Validate
317 snippets_to_validate = exec_tests + single_tests + eval_tests
318 for snippet in snippets_to_validate:
319 tree = ast.parse(snippet)
320 compile(tree, '<string>', 'exec')
321
Benjamin Peterson78565b22009-06-28 19:19:51 +0000322 def test_slice(self):
323 slc = ast.parse("x[::]").body[0].value.slice
324 self.assertIsNone(slc.upper)
325 self.assertIsNone(slc.lower)
326 self.assertIsNone(slc.step)
327
328 def test_from_import(self):
329 im = ast.parse("from . import y").body[0]
330 self.assertIsNone(im.module)
331
Benjamin Petersona4e4e352012-03-22 08:19:04 -0400332 def test_non_interned_future_from_ast(self):
333 mod = ast.parse("from __future__ import division")
334 self.assertIsInstance(mod.body[0], ast.ImportFrom)
335 mod.body[0].module = " __future__ ".strip()
336 compile(mod, "<test>", "exec")
337
Matthew Suozzo75a06f02021-04-10 16:56:28 -0400338 def test_alias(self):
339 im = ast.parse("from bar import y").body[0]
340 self.assertEqual(len(im.names), 1)
341 alias = im.names[0]
342 self.assertEqual(alias.name, 'y')
343 self.assertIsNone(alias.asname)
344 self.assertEqual(alias.lineno, 1)
345 self.assertEqual(alias.end_lineno, 1)
346 self.assertEqual(alias.col_offset, 16)
347 self.assertEqual(alias.end_col_offset, 17)
348
349 im = ast.parse("from bar import *").body[0]
350 alias = im.names[0]
351 self.assertEqual(alias.name, '*')
352 self.assertIsNone(alias.asname)
353 self.assertEqual(alias.lineno, 1)
354 self.assertEqual(alias.end_lineno, 1)
355 self.assertEqual(alias.col_offset, 16)
356 self.assertEqual(alias.end_col_offset, 17)
357
Benjamin Petersona0dfa822009-11-13 02:25:08 +0000358 def test_base_classes(self):
359 self.assertTrue(issubclass(ast.For, ast.stmt))
360 self.assertTrue(issubclass(ast.Name, ast.expr))
361 self.assertTrue(issubclass(ast.stmt, ast.AST))
362 self.assertTrue(issubclass(ast.expr, ast.AST))
363 self.assertTrue(issubclass(ast.comprehension, ast.AST))
364 self.assertTrue(issubclass(ast.Gt, ast.AST))
365
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500366 def test_field_attr_existence(self):
367 for name, item in ast.__dict__.items():
Batuhan TaĹźkaya397b96f2020-03-01 23:12:17 +0300368 if self._is_ast_node(name, item):
Serhiy Storchaka13d52c22020-03-10 18:52:34 +0200369 if name == 'Index':
370 # Index(value) just returns value now.
371 # The argument is required.
372 continue
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500373 x = item()
374 if isinstance(x, ast.AST):
375 self.assertEqual(type(x._fields), tuple)
376
377 def test_arguments(self):
378 x = ast.arguments()
Pablo Galindocd6e83b2019-07-15 01:32:18 +0200379 self.assertEqual(x._fields, ('posonlyargs', 'args', 'vararg', 'kwonlyargs',
380 'kw_defaults', 'kwarg', 'defaults'))
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500381
382 with self.assertRaises(AttributeError):
Serhiy Storchakab7e95252020-03-10 00:07:47 +0200383 x.args
384 self.assertIsNone(x.vararg)
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500385
Pablo Galindo8c77b8c2019-04-29 13:36:57 +0100386 x = ast.arguments(*range(1, 8))
Serhiy Storchakab7e95252020-03-10 00:07:47 +0200387 self.assertEqual(x.args, 2)
Pablo Galindo8c77b8c2019-04-29 13:36:57 +0100388 self.assertEqual(x.vararg, 3)
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500389
390 def test_field_attr_writable(self):
391 x = ast.Num()
392 # We can assign to _fields
393 x._fields = 666
394 self.assertEqual(x._fields, 666)
395
396 def test_classattrs(self):
397 x = ast.Num()
Guido van Rossum10f8ce62019-03-13 13:00:46 -0700398 self.assertEqual(x._fields, ('value', 'kind'))
Serhiy Storchaka3f228112018-09-27 17:42:37 +0300399
400 with self.assertRaises(AttributeError):
401 x.value
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500402
403 with self.assertRaises(AttributeError):
404 x.n
405
406 x = ast.Num(42)
Serhiy Storchaka3f228112018-09-27 17:42:37 +0300407 self.assertEqual(x.value, 42)
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500408 self.assertEqual(x.n, 42)
409
410 with self.assertRaises(AttributeError):
411 x.lineno
412
413 with self.assertRaises(AttributeError):
414 x.foobar
415
416 x = ast.Num(lineno=2)
417 self.assertEqual(x.lineno, 2)
418
419 x = ast.Num(42, lineno=0)
420 self.assertEqual(x.lineno, 0)
Guido van Rossum10f8ce62019-03-13 13:00:46 -0700421 self.assertEqual(x._fields, ('value', 'kind'))
Serhiy Storchaka3f228112018-09-27 17:42:37 +0300422 self.assertEqual(x.value, 42)
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500423 self.assertEqual(x.n, 42)
424
Guido van Rossum10f8ce62019-03-13 13:00:46 -0700425 self.assertRaises(TypeError, ast.Num, 1, None, 2)
426 self.assertRaises(TypeError, ast.Num, 1, None, 2, lineno=0)
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500427
Rémi Lapeyrec73914a2020-05-24 23:12:57 +0200428 # Arbitrary keyword arguments are supported
429 self.assertEqual(ast.Constant(1, foo='bar').foo, 'bar')
430 self.assertEqual(ast.Num(1, foo='bar').foo, 'bar')
431
432 with self.assertRaisesRegex(TypeError, "Num got multiple values for argument 'n'"):
433 ast.Num(1, n=2)
434 with self.assertRaisesRegex(TypeError, "Constant got multiple values for argument 'value'"):
435 ast.Constant(1, value=2)
436
Serhiy Storchaka3f228112018-09-27 17:42:37 +0300437 self.assertEqual(ast.Num(42).n, 42)
438 self.assertEqual(ast.Num(4.25).n, 4.25)
439 self.assertEqual(ast.Num(4.25j).n, 4.25j)
440 self.assertEqual(ast.Str('42').s, '42')
441 self.assertEqual(ast.Bytes(b'42').s, b'42')
442 self.assertIs(ast.NameConstant(True).value, True)
443 self.assertIs(ast.NameConstant(False).value, False)
444 self.assertIs(ast.NameConstant(None).value, None)
445
446 self.assertEqual(ast.Constant(42).value, 42)
447 self.assertEqual(ast.Constant(4.25).value, 4.25)
448 self.assertEqual(ast.Constant(4.25j).value, 4.25j)
449 self.assertEqual(ast.Constant('42').value, '42')
450 self.assertEqual(ast.Constant(b'42').value, b'42')
451 self.assertIs(ast.Constant(True).value, True)
452 self.assertIs(ast.Constant(False).value, False)
453 self.assertIs(ast.Constant(None).value, None)
454 self.assertIs(ast.Constant(...).value, ...)
455
456 def test_realtype(self):
457 self.assertEqual(type(ast.Num(42)), ast.Constant)
458 self.assertEqual(type(ast.Num(4.25)), ast.Constant)
459 self.assertEqual(type(ast.Num(4.25j)), ast.Constant)
460 self.assertEqual(type(ast.Str('42')), ast.Constant)
461 self.assertEqual(type(ast.Bytes(b'42')), ast.Constant)
462 self.assertEqual(type(ast.NameConstant(True)), ast.Constant)
463 self.assertEqual(type(ast.NameConstant(False)), ast.Constant)
464 self.assertEqual(type(ast.NameConstant(None)), ast.Constant)
465 self.assertEqual(type(ast.Ellipsis()), ast.Constant)
466
467 def test_isinstance(self):
468 self.assertTrue(isinstance(ast.Num(42), ast.Num))
469 self.assertTrue(isinstance(ast.Num(4.2), ast.Num))
470 self.assertTrue(isinstance(ast.Num(4.2j), ast.Num))
471 self.assertTrue(isinstance(ast.Str('42'), ast.Str))
472 self.assertTrue(isinstance(ast.Bytes(b'42'), ast.Bytes))
473 self.assertTrue(isinstance(ast.NameConstant(True), ast.NameConstant))
474 self.assertTrue(isinstance(ast.NameConstant(False), ast.NameConstant))
475 self.assertTrue(isinstance(ast.NameConstant(None), ast.NameConstant))
476 self.assertTrue(isinstance(ast.Ellipsis(), ast.Ellipsis))
477
478 self.assertTrue(isinstance(ast.Constant(42), ast.Num))
479 self.assertTrue(isinstance(ast.Constant(4.2), ast.Num))
480 self.assertTrue(isinstance(ast.Constant(4.2j), ast.Num))
481 self.assertTrue(isinstance(ast.Constant('42'), ast.Str))
482 self.assertTrue(isinstance(ast.Constant(b'42'), ast.Bytes))
483 self.assertTrue(isinstance(ast.Constant(True), ast.NameConstant))
484 self.assertTrue(isinstance(ast.Constant(False), ast.NameConstant))
485 self.assertTrue(isinstance(ast.Constant(None), ast.NameConstant))
486 self.assertTrue(isinstance(ast.Constant(...), ast.Ellipsis))
487
488 self.assertFalse(isinstance(ast.Str('42'), ast.Num))
489 self.assertFalse(isinstance(ast.Num(42), ast.Str))
490 self.assertFalse(isinstance(ast.Str('42'), ast.Bytes))
491 self.assertFalse(isinstance(ast.Num(42), ast.NameConstant))
492 self.assertFalse(isinstance(ast.Num(42), ast.Ellipsis))
Anthony Sottile74176222019-01-18 11:30:28 -0800493 self.assertFalse(isinstance(ast.NameConstant(True), ast.Num))
494 self.assertFalse(isinstance(ast.NameConstant(False), ast.Num))
Serhiy Storchaka3f228112018-09-27 17:42:37 +0300495
496 self.assertFalse(isinstance(ast.Constant('42'), ast.Num))
497 self.assertFalse(isinstance(ast.Constant(42), ast.Str))
498 self.assertFalse(isinstance(ast.Constant('42'), ast.Bytes))
499 self.assertFalse(isinstance(ast.Constant(42), ast.NameConstant))
500 self.assertFalse(isinstance(ast.Constant(42), ast.Ellipsis))
Anthony Sottile74176222019-01-18 11:30:28 -0800501 self.assertFalse(isinstance(ast.Constant(True), ast.Num))
502 self.assertFalse(isinstance(ast.Constant(False), ast.Num))
Serhiy Storchaka3f228112018-09-27 17:42:37 +0300503
504 self.assertFalse(isinstance(ast.Constant(), ast.Num))
505 self.assertFalse(isinstance(ast.Constant(), ast.Str))
506 self.assertFalse(isinstance(ast.Constant(), ast.Bytes))
507 self.assertFalse(isinstance(ast.Constant(), ast.NameConstant))
508 self.assertFalse(isinstance(ast.Constant(), ast.Ellipsis))
509
Serhiy Storchaka6015cc52018-10-28 13:43:03 +0200510 class S(str): pass
511 self.assertTrue(isinstance(ast.Constant(S('42')), ast.Str))
512 self.assertFalse(isinstance(ast.Constant(S('42')), ast.Num))
513
Serhiy Storchaka3f228112018-09-27 17:42:37 +0300514 def test_subclasses(self):
515 class N(ast.Num):
516 def __init__(self, *args, **kwargs):
517 super().__init__(*args, **kwargs)
518 self.z = 'spam'
519 class N2(ast.Num):
520 pass
521
522 n = N(42)
523 self.assertEqual(n.n, 42)
524 self.assertEqual(n.z, 'spam')
525 self.assertEqual(type(n), N)
526 self.assertTrue(isinstance(n, N))
527 self.assertTrue(isinstance(n, ast.Num))
528 self.assertFalse(isinstance(n, N2))
529 self.assertFalse(isinstance(ast.Num(42), N))
530 n = N(n=42)
531 self.assertEqual(n.n, 42)
532 self.assertEqual(type(n), N)
533
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500534 def test_module(self):
535 body = [ast.Num(42)]
Guido van Rossumdcfcd142019-01-31 03:40:27 -0800536 x = ast.Module(body, [])
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500537 self.assertEqual(x.body, body)
538
Neal Norwitzee9b10a2008-03-31 05:29:39 +0000539 def test_nodeclasses(self):
Florent Xicluna992d9e02011-11-11 19:35:42 +0100540 # Zero arguments constructor explicitly allowed
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500541 x = ast.BinOp()
542 self.assertEqual(x._fields, ('left', 'op', 'right'))
543
544 # Random attribute allowed too
545 x.foobarbaz = 5
546 self.assertEqual(x.foobarbaz, 5)
547
548 n1 = ast.Num(1)
549 n3 = ast.Num(3)
550 addop = ast.Add()
551 x = ast.BinOp(n1, addop, n3)
552 self.assertEqual(x.left, n1)
553 self.assertEqual(x.op, addop)
554 self.assertEqual(x.right, n3)
Benjamin Peterson68b543a2011-06-27 17:51:18 -0500555
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500556 x = ast.BinOp(1, 2, 3)
557 self.assertEqual(x.left, 1)
558 self.assertEqual(x.op, 2)
559 self.assertEqual(x.right, 3)
560
Georg Brandl0c77a822008-06-10 16:37:50 +0000561 x = ast.BinOp(1, 2, 3, lineno=0)
Ezio Melottib3aedd42010-11-20 19:04:17 +0000562 self.assertEqual(x.left, 1)
563 self.assertEqual(x.op, 2)
564 self.assertEqual(x.right, 3)
565 self.assertEqual(x.lineno, 0)
Neal Norwitzee9b10a2008-03-31 05:29:39 +0000566
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500567 # node raises exception when given too many arguments
568 self.assertRaises(TypeError, ast.BinOp, 1, 2, 3, 4)
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500569 # node raises exception when given too many arguments
570 self.assertRaises(TypeError, ast.BinOp, 1, 2, 3, 4, lineno=0)
Neal Norwitzee9b10a2008-03-31 05:29:39 +0000571
572 # can set attributes through kwargs too
Georg Brandl0c77a822008-06-10 16:37:50 +0000573 x = ast.BinOp(left=1, op=2, right=3, lineno=0)
Ezio Melottib3aedd42010-11-20 19:04:17 +0000574 self.assertEqual(x.left, 1)
575 self.assertEqual(x.op, 2)
576 self.assertEqual(x.right, 3)
577 self.assertEqual(x.lineno, 0)
Neal Norwitzee9b10a2008-03-31 05:29:39 +0000578
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500579 # Random kwargs also allowed
580 x = ast.BinOp(1, 2, 3, foobarbaz=42)
581 self.assertEqual(x.foobarbaz, 42)
582
583 def test_no_fields(self):
Neal Norwitzee9b10a2008-03-31 05:29:39 +0000584 # this used to fail because Sub._fields was None
Georg Brandl0c77a822008-06-10 16:37:50 +0000585 x = ast.Sub()
Benjamin Peterson6ccfe852011-06-27 17:46:06 -0500586 self.assertEqual(x._fields, ())
Neal Norwitzee9b10a2008-03-31 05:29:39 +0000587
588 def test_pickling(self):
589 import pickle
590 mods = [pickle]
591 try:
592 import cPickle
593 mods.append(cPickle)
594 except ImportError:
595 pass
596 protocols = [0, 1, 2]
597 for mod in mods:
598 for protocol in protocols:
599 for ast in (compile(i, "?", "exec", 0x400) for i in exec_tests):
600 ast2 = mod.loads(mod.dumps(ast, protocol))
Ezio Melottib3aedd42010-11-20 19:04:17 +0000601 self.assertEqual(to_tuple(ast2), to_tuple(ast))
Neal Norwitzee9b10a2008-03-31 05:29:39 +0000602
Benjamin Peterson5b066812010-11-20 01:38:49 +0000603 def test_invalid_sum(self):
604 pos = dict(lineno=2, col_offset=3)
Guido van Rossumdcfcd142019-01-31 03:40:27 -0800605 m = ast.Module([ast.Expr(ast.expr(**pos), **pos)], [])
Benjamin Peterson5b066812010-11-20 01:38:49 +0000606 with self.assertRaises(TypeError) as cm:
607 compile(m, "<test>", "exec")
Serhiy Storchakabace59d2020-03-22 20:33:34 +0200608 self.assertIn("but got <ast.expr", str(cm.exception))
Benjamin Peterson5b066812010-11-20 01:38:49 +0000609
Min ho Kimc4cacc82019-07-31 08:16:13 +1000610 def test_invalid_identifier(self):
Guido van Rossumdcfcd142019-01-31 03:40:27 -0800611 m = ast.Module([ast.Expr(ast.Name(42, ast.Load()))], [])
Benjamin Peterson2193d2b2011-07-22 10:50:23 -0500612 ast.fix_missing_locations(m)
613 with self.assertRaises(TypeError) as cm:
614 compile(m, "<test>", "exec")
615 self.assertIn("identifier must be of type str", str(cm.exception))
616
Batuhan TaĹźkaya0ac59f92020-03-19 14:32:28 +0300617 def test_invalid_constant(self):
618 for invalid_constant in int, (1, 2, int), frozenset((1, 2, int)):
619 e = ast.Expression(body=ast.Constant(invalid_constant))
620 ast.fix_missing_locations(e)
621 with self.assertRaisesRegex(
622 TypeError, "invalid type in Constant: type"
623 ):
624 compile(e, "<test>", "eval")
625
Mark Dickinsonded35ae2012-11-25 14:36:26 +0000626 def test_empty_yield_from(self):
627 # Issue 16546: yield from value is not optional.
628 empty_yield_from = ast.parse("def f():\n yield from g()")
629 empty_yield_from.body[0].body[0].value.value = None
630 with self.assertRaises(ValueError) as cm:
631 compile(empty_yield_from, "<test>", "exec")
Batuhan Taskaya091951a2020-05-06 17:29:32 +0300632 self.assertIn("field 'value' is required", str(cm.exception))
Mark Dickinsonded35ae2012-11-25 14:36:26 +0000633
Oren Milman7dc46d82017-09-30 20:16:24 +0300634 @support.cpython_only
635 def test_issue31592(self):
636 # There shouldn't be an assertion failure in case of a bad
637 # unicodedata.normalize().
638 import unicodedata
639 def bad_normalize(*args):
640 return None
641 with support.swap_attr(unicodedata, 'normalize', bad_normalize):
642 self.assertRaises(TypeError, ast.parse, '\u03D5')
643
Carl Friedrich Bolz-Tereick110a47c2019-07-08 23:17:56 +0200644 def test_issue18374_binop_col_offset(self):
645 tree = ast.parse('4+5+6+7')
646 parent_binop = tree.body[0].value
647 child_binop = parent_binop.left
648 grandchild_binop = child_binop.left
649 self.assertEqual(parent_binop.col_offset, 0)
650 self.assertEqual(parent_binop.end_col_offset, 7)
651 self.assertEqual(child_binop.col_offset, 0)
652 self.assertEqual(child_binop.end_col_offset, 5)
653 self.assertEqual(grandchild_binop.col_offset, 0)
654 self.assertEqual(grandchild_binop.end_col_offset, 3)
655
656 tree = ast.parse('4+5-\\\n 6-7')
657 parent_binop = tree.body[0].value
658 child_binop = parent_binop.left
659 grandchild_binop = child_binop.left
660 self.assertEqual(parent_binop.col_offset, 0)
661 self.assertEqual(parent_binop.lineno, 1)
662 self.assertEqual(parent_binop.end_col_offset, 4)
663 self.assertEqual(parent_binop.end_lineno, 2)
664
665 self.assertEqual(child_binop.col_offset, 0)
Carl Friedrich Bolz-Tereick430a9f42019-07-09 14:20:01 +0200666 self.assertEqual(child_binop.lineno, 1)
Carl Friedrich Bolz-Tereick110a47c2019-07-08 23:17:56 +0200667 self.assertEqual(child_binop.end_col_offset, 2)
Carl Friedrich Bolz-Tereick430a9f42019-07-09 14:20:01 +0200668 self.assertEqual(child_binop.end_lineno, 2)
Carl Friedrich Bolz-Tereick110a47c2019-07-08 23:17:56 +0200669
670 self.assertEqual(grandchild_binop.col_offset, 0)
Carl Friedrich Bolz-Tereick430a9f42019-07-09 14:20:01 +0200671 self.assertEqual(grandchild_binop.lineno, 1)
Carl Friedrich Bolz-Tereick110a47c2019-07-08 23:17:56 +0200672 self.assertEqual(grandchild_binop.end_col_offset, 3)
Carl Friedrich Bolz-Tereick430a9f42019-07-09 14:20:01 +0200673 self.assertEqual(grandchild_binop.end_lineno, 1)
Georg Brandl0c77a822008-06-10 16:37:50 +0000674
Lysandros Nikolaoud2e10982020-02-08 00:36:32 +0100675 def test_issue39579_dotted_name_end_col_offset(self):
676 tree = ast.parse('@a.b.c\ndef f(): pass')
677 attr_b = tree.body[0].decorator_list[0].value
678 self.assertEqual(attr_b.end_col_offset, 4)
679
Batuhan TaĹźkaya4ab362c2020-03-16 11:12:53 +0300680 def test_ast_asdl_signature(self):
681 self.assertEqual(ast.withitem.__doc__, "withitem(expr context_expr, expr? optional_vars)")
682 self.assertEqual(ast.GtE.__doc__, "GtE")
683 self.assertEqual(ast.Name.__doc__, "Name(identifier id, expr_context ctx)")
684 self.assertEqual(ast.cmpop.__doc__, "cmpop = Eq | NotEq | Lt | LtE | Gt | GtE | Is | IsNot | In | NotIn")
685 expressions = [f" | {node.__doc__}" for node in ast.expr.__subclasses__()]
686 expressions[0] = f"expr = {ast.expr.__subclasses__()[0].__doc__}"
687 self.assertCountEqual(ast.expr.__doc__.split("\n"), expressions)
688
Shantanuc116c942020-05-27 13:30:38 -0700689 def test_issue40614_feature_version(self):
690 ast.parse('f"{x=}"', feature_version=(3, 8))
691 with self.assertRaises(SyntaxError):
692 ast.parse('f"{x=}"', feature_version=(3, 7))
693
Batuhan Taskaya68874a82020-06-06 15:44:16 +0300694 def test_constant_as_name(self):
695 for constant in "True", "False", "None":
696 expr = ast.Expression(ast.Name(constant, ast.Load()))
697 ast.fix_missing_locations(expr)
698 with self.assertRaisesRegex(ValueError, f"Name node can't be used with '{constant}' constant"):
699 compile(expr, "<test>", "eval")
700
Batuhan TaĹźkaya4ab362c2020-03-16 11:12:53 +0300701
Georg Brandl0c77a822008-06-10 16:37:50 +0000702class ASTHelpers_Test(unittest.TestCase):
Guido van Rossum10f8ce62019-03-13 13:00:46 -0700703 maxDiff = None
Georg Brandl0c77a822008-06-10 16:37:50 +0000704
705 def test_parse(self):
706 a = ast.parse('foo(1 + 1)')
707 b = compile('foo(1 + 1)', '<unknown>', 'exec', ast.PyCF_ONLY_AST)
708 self.assertEqual(ast.dump(a), ast.dump(b))
709
Benjamin Peterson2e2c9032012-09-02 14:23:15 -0400710 def test_parse_in_error(self):
711 try:
712 1/0
713 except Exception:
Benjamin Petersonbd0df502012-09-02 15:04:51 -0400714 with self.assertRaises(SyntaxError) as e:
715 ast.literal_eval(r"'\U'")
716 self.assertIsNotNone(e.exception.__context__)
Benjamin Peterson2e2c9032012-09-02 14:23:15 -0400717
Georg Brandl0c77a822008-06-10 16:37:50 +0000718 def test_dump(self):
719 node = ast.parse('spam(eggs, "and cheese")')
720 self.assertEqual(ast.dump(node),
721 "Module(body=[Expr(value=Call(func=Name(id='spam', ctx=Load()), "
Serhiy Storchakab7e95252020-03-10 00:07:47 +0200722 "args=[Name(id='eggs', ctx=Load()), Constant(value='and cheese')], "
Guido van Rossumdcfcd142019-01-31 03:40:27 -0800723 "keywords=[]))], type_ignores=[])"
Georg Brandl0c77a822008-06-10 16:37:50 +0000724 )
725 self.assertEqual(ast.dump(node, annotate_fields=False),
726 "Module([Expr(Call(Name('spam', Load()), [Name('eggs', Load()), "
Serhiy Storchakab7e95252020-03-10 00:07:47 +0200727 "Constant('and cheese')], []))], [])"
Georg Brandl0c77a822008-06-10 16:37:50 +0000728 )
729 self.assertEqual(ast.dump(node, include_attributes=True),
730 "Module(body=[Expr(value=Call(func=Name(id='spam', ctx=Load(), "
Ivan Levkivskyi9932a222019-01-22 11:18:22 +0000731 "lineno=1, col_offset=0, end_lineno=1, end_col_offset=4), "
732 "args=[Name(id='eggs', ctx=Load(), lineno=1, col_offset=5, "
Serhiy Storchakab7e95252020-03-10 00:07:47 +0200733 "end_lineno=1, end_col_offset=9), Constant(value='and cheese', "
Ivan Levkivskyi9932a222019-01-22 11:18:22 +0000734 "lineno=1, col_offset=11, end_lineno=1, end_col_offset=23)], keywords=[], "
735 "lineno=1, col_offset=0, end_lineno=1, end_col_offset=24), "
Guido van Rossumdcfcd142019-01-31 03:40:27 -0800736 "lineno=1, col_offset=0, end_lineno=1, end_col_offset=24)], type_ignores=[])"
Georg Brandl0c77a822008-06-10 16:37:50 +0000737 )
738
Serhiy Storchaka850573b2019-09-09 19:33:13 +0300739 def test_dump_indent(self):
740 node = ast.parse('spam(eggs, "and cheese")')
741 self.assertEqual(ast.dump(node, indent=3), """\
742Module(
743 body=[
744 Expr(
745 value=Call(
746 func=Name(id='spam', ctx=Load()),
747 args=[
748 Name(id='eggs', ctx=Load()),
Serhiy Storchakab7e95252020-03-10 00:07:47 +0200749 Constant(value='and cheese')],
Serhiy Storchaka850573b2019-09-09 19:33:13 +0300750 keywords=[]))],
751 type_ignores=[])""")
752 self.assertEqual(ast.dump(node, annotate_fields=False, indent='\t'), """\
753Module(
754\t[
755\t\tExpr(
756\t\t\tCall(
757\t\t\t\tName('spam', Load()),
758\t\t\t\t[
759\t\t\t\t\tName('eggs', Load()),
Serhiy Storchakab7e95252020-03-10 00:07:47 +0200760\t\t\t\t\tConstant('and cheese')],
Serhiy Storchaka850573b2019-09-09 19:33:13 +0300761\t\t\t\t[]))],
762\t[])""")
763 self.assertEqual(ast.dump(node, include_attributes=True, indent=3), """\
764Module(
765 body=[
766 Expr(
767 value=Call(
768 func=Name(
769 id='spam',
770 ctx=Load(),
771 lineno=1,
772 col_offset=0,
773 end_lineno=1,
774 end_col_offset=4),
775 args=[
776 Name(
777 id='eggs',
778 ctx=Load(),
779 lineno=1,
780 col_offset=5,
781 end_lineno=1,
782 end_col_offset=9),
783 Constant(
784 value='and cheese',
Serhiy Storchaka850573b2019-09-09 19:33:13 +0300785 lineno=1,
786 col_offset=11,
787 end_lineno=1,
788 end_col_offset=23)],
789 keywords=[],
790 lineno=1,
791 col_offset=0,
792 end_lineno=1,
793 end_col_offset=24),
794 lineno=1,
795 col_offset=0,
796 end_lineno=1,
797 end_col_offset=24)],
798 type_ignores=[])""")
799
Serhiy Storchakae64f9482019-08-29 09:30:23 +0300800 def test_dump_incomplete(self):
801 node = ast.Raise(lineno=3, col_offset=4)
802 self.assertEqual(ast.dump(node),
803 "Raise()"
804 )
805 self.assertEqual(ast.dump(node, include_attributes=True),
806 "Raise(lineno=3, col_offset=4)"
807 )
808 node = ast.Raise(exc=ast.Name(id='e', ctx=ast.Load()), lineno=3, col_offset=4)
809 self.assertEqual(ast.dump(node),
810 "Raise(exc=Name(id='e', ctx=Load()))"
811 )
812 self.assertEqual(ast.dump(node, annotate_fields=False),
813 "Raise(Name('e', Load()))"
814 )
815 self.assertEqual(ast.dump(node, include_attributes=True),
816 "Raise(exc=Name(id='e', ctx=Load()), lineno=3, col_offset=4)"
817 )
818 self.assertEqual(ast.dump(node, annotate_fields=False, include_attributes=True),
819 "Raise(Name('e', Load()), lineno=3, col_offset=4)"
820 )
821 node = ast.Raise(cause=ast.Name(id='e', ctx=ast.Load()))
822 self.assertEqual(ast.dump(node),
823 "Raise(cause=Name(id='e', ctx=Load()))"
824 )
825 self.assertEqual(ast.dump(node, annotate_fields=False),
826 "Raise(cause=Name('e', Load()))"
827 )
828
Georg Brandl0c77a822008-06-10 16:37:50 +0000829 def test_copy_location(self):
830 src = ast.parse('1 + 1', mode='eval')
831 src.body.right = ast.copy_location(ast.Num(2), src.body.right)
832 self.assertEqual(ast.dump(src, include_attributes=True),
Serhiy Storchakab7e95252020-03-10 00:07:47 +0200833 'Expression(body=BinOp(left=Constant(value=1, lineno=1, col_offset=0, '
Ivan Levkivskyi9932a222019-01-22 11:18:22 +0000834 'end_lineno=1, end_col_offset=1), op=Add(), right=Constant(value=2, '
835 'lineno=1, col_offset=4, end_lineno=1, end_col_offset=5), lineno=1, '
836 'col_offset=0, end_lineno=1, end_col_offset=5))'
Georg Brandl0c77a822008-06-10 16:37:50 +0000837 )
Batuhan Taskaya8f4380d2020-08-05 16:32:32 +0300838 src = ast.Call(col_offset=1, lineno=1, end_lineno=1, end_col_offset=1)
839 new = ast.copy_location(src, ast.Call(col_offset=None, lineno=None))
840 self.assertIsNone(new.end_lineno)
841 self.assertIsNone(new.end_col_offset)
842 self.assertEqual(new.lineno, 1)
843 self.assertEqual(new.col_offset, 1)
Georg Brandl0c77a822008-06-10 16:37:50 +0000844
845 def test_fix_missing_locations(self):
846 src = ast.parse('write("spam")')
847 src.body.append(ast.Expr(ast.Call(ast.Name('spam', ast.Load()),
Benjamin Peterson025e9eb2015-05-05 20:16:41 -0400848 [ast.Str('eggs')], [])))
Georg Brandl0c77a822008-06-10 16:37:50 +0000849 self.assertEqual(src, ast.fix_missing_locations(src))
Ivan Levkivskyi9932a222019-01-22 11:18:22 +0000850 self.maxDiff = None
Georg Brandl0c77a822008-06-10 16:37:50 +0000851 self.assertEqual(ast.dump(src, include_attributes=True),
852 "Module(body=[Expr(value=Call(func=Name(id='write', ctx=Load(), "
Ivan Levkivskyi9932a222019-01-22 11:18:22 +0000853 "lineno=1, col_offset=0, end_lineno=1, end_col_offset=5), "
Serhiy Storchakab7e95252020-03-10 00:07:47 +0200854 "args=[Constant(value='spam', lineno=1, col_offset=6, end_lineno=1, "
Ivan Levkivskyi9932a222019-01-22 11:18:22 +0000855 "end_col_offset=12)], keywords=[], lineno=1, col_offset=0, end_lineno=1, "
856 "end_col_offset=13), lineno=1, col_offset=0, end_lineno=1, "
857 "end_col_offset=13), Expr(value=Call(func=Name(id='spam', ctx=Load(), "
858 "lineno=1, col_offset=0, end_lineno=1, end_col_offset=0), "
859 "args=[Constant(value='eggs', lineno=1, col_offset=0, end_lineno=1, "
860 "end_col_offset=0)], keywords=[], lineno=1, col_offset=0, end_lineno=1, "
Guido van Rossumdcfcd142019-01-31 03:40:27 -0800861 "end_col_offset=0), lineno=1, col_offset=0, end_lineno=1, end_col_offset=0)], "
862 "type_ignores=[])"
Georg Brandl0c77a822008-06-10 16:37:50 +0000863 )
864
865 def test_increment_lineno(self):
866 src = ast.parse('1 + 1', mode='eval')
867 self.assertEqual(ast.increment_lineno(src, n=3), src)
868 self.assertEqual(ast.dump(src, include_attributes=True),
Serhiy Storchakab7e95252020-03-10 00:07:47 +0200869 'Expression(body=BinOp(left=Constant(value=1, lineno=4, col_offset=0, '
870 'end_lineno=4, end_col_offset=1), op=Add(), right=Constant(value=1, '
Ivan Levkivskyi9932a222019-01-22 11:18:22 +0000871 'lineno=4, col_offset=4, end_lineno=4, end_col_offset=5), lineno=4, '
872 'col_offset=0, end_lineno=4, end_col_offset=5))'
Georg Brandl0c77a822008-06-10 16:37:50 +0000873 )
Georg Brandl619e7ba2011-01-09 07:38:51 +0000874 # issue10869: do not increment lineno of root twice
Georg Brandlefb69022011-01-09 07:50:48 +0000875 src = ast.parse('1 + 1', mode='eval')
Georg Brandl619e7ba2011-01-09 07:38:51 +0000876 self.assertEqual(ast.increment_lineno(src.body, n=3), src.body)
877 self.assertEqual(ast.dump(src, include_attributes=True),
Serhiy Storchakab7e95252020-03-10 00:07:47 +0200878 'Expression(body=BinOp(left=Constant(value=1, lineno=4, col_offset=0, '
879 'end_lineno=4, end_col_offset=1), op=Add(), right=Constant(value=1, '
Ivan Levkivskyi9932a222019-01-22 11:18:22 +0000880 'lineno=4, col_offset=4, end_lineno=4, end_col_offset=5), lineno=4, '
881 'col_offset=0, end_lineno=4, end_col_offset=5))'
Georg Brandl619e7ba2011-01-09 07:38:51 +0000882 )
Batuhan Taskaya8f4380d2020-08-05 16:32:32 +0300883 src = ast.Call(
884 func=ast.Name("test", ast.Load()), args=[], keywords=[], lineno=1
885 )
886 self.assertEqual(ast.increment_lineno(src).lineno, 2)
887 self.assertIsNone(ast.increment_lineno(src).end_lineno)
Georg Brandl0c77a822008-06-10 16:37:50 +0000888
889 def test_iter_fields(self):
890 node = ast.parse('foo()', mode='eval')
891 d = dict(ast.iter_fields(node.body))
892 self.assertEqual(d.pop('func').id, 'foo')
Benjamin Peterson025e9eb2015-05-05 20:16:41 -0400893 self.assertEqual(d, {'keywords': [], 'args': []})
Georg Brandl0c77a822008-06-10 16:37:50 +0000894
895 def test_iter_child_nodes(self):
896 node = ast.parse("spam(23, 42, eggs='leek')", mode='eval')
897 self.assertEqual(len(list(ast.iter_child_nodes(node.body))), 4)
898 iterator = ast.iter_child_nodes(node.body)
899 self.assertEqual(next(iterator).id, 'spam')
Serhiy Storchaka3f228112018-09-27 17:42:37 +0300900 self.assertEqual(next(iterator).value, 23)
901 self.assertEqual(next(iterator).value, 42)
Georg Brandl0c77a822008-06-10 16:37:50 +0000902 self.assertEqual(ast.dump(next(iterator)),
Serhiy Storchakab7e95252020-03-10 00:07:47 +0200903 "keyword(arg='eggs', value=Constant(value='leek'))"
Georg Brandl0c77a822008-06-10 16:37:50 +0000904 )
905
906 def test_get_docstring(self):
Serhiy Storchaka08f127a2018-06-15 11:05:15 +0300907 node = ast.parse('"""line one\n line two"""')
908 self.assertEqual(ast.get_docstring(node),
909 'line one\nline two')
910
911 node = ast.parse('class foo:\n """line one\n line two"""')
912 self.assertEqual(ast.get_docstring(node.body[0]),
913 'line one\nline two')
914
Georg Brandl0c77a822008-06-10 16:37:50 +0000915 node = ast.parse('def foo():\n """line one\n line two"""')
916 self.assertEqual(ast.get_docstring(node.body[0]),
917 'line one\nline two')
918
Yury Selivanov2f07a662015-07-23 08:54:35 +0300919 node = ast.parse('async def foo():\n """spam\n ham"""')
920 self.assertEqual(ast.get_docstring(node.body[0]), 'spam\nham')
Serhiy Storchaka08f127a2018-06-15 11:05:15 +0300921
922 def test_get_docstring_none(self):
Matthias Bussonnier41cea702017-02-23 22:44:19 -0800923 self.assertIsNone(ast.get_docstring(ast.parse('')))
Serhiy Storchaka08f127a2018-06-15 11:05:15 +0300924 node = ast.parse('x = "not docstring"')
925 self.assertIsNone(ast.get_docstring(node))
926 node = ast.parse('def foo():\n pass')
927 self.assertIsNone(ast.get_docstring(node))
928
929 node = ast.parse('class foo:\n pass')
930 self.assertIsNone(ast.get_docstring(node.body[0]))
931 node = ast.parse('class foo:\n x = "not docstring"')
932 self.assertIsNone(ast.get_docstring(node.body[0]))
933 node = ast.parse('class foo:\n def bar(self): pass')
934 self.assertIsNone(ast.get_docstring(node.body[0]))
935
936 node = ast.parse('def foo():\n pass')
937 self.assertIsNone(ast.get_docstring(node.body[0]))
938 node = ast.parse('def foo():\n x = "not docstring"')
939 self.assertIsNone(ast.get_docstring(node.body[0]))
940
941 node = ast.parse('async def foo():\n pass')
942 self.assertIsNone(ast.get_docstring(node.body[0]))
943 node = ast.parse('async def foo():\n x = "not docstring"')
944 self.assertIsNone(ast.get_docstring(node.body[0]))
Yury Selivanov2f07a662015-07-23 08:54:35 +0300945
Anthony Sottile995d9b92019-01-12 20:05:13 -0800946 def test_multi_line_docstring_col_offset_and_lineno_issue16806(self):
947 node = ast.parse(
948 '"""line one\nline two"""\n\n'
949 'def foo():\n """line one\n line two"""\n\n'
950 ' def bar():\n """line one\n line two"""\n'
951 ' """line one\n line two"""\n'
952 '"""line one\nline two"""\n\n'
953 )
954 self.assertEqual(node.body[0].col_offset, 0)
955 self.assertEqual(node.body[0].lineno, 1)
956 self.assertEqual(node.body[1].body[0].col_offset, 2)
957 self.assertEqual(node.body[1].body[0].lineno, 5)
958 self.assertEqual(node.body[1].body[1].body[0].col_offset, 4)
959 self.assertEqual(node.body[1].body[1].body[0].lineno, 9)
960 self.assertEqual(node.body[1].body[2].col_offset, 2)
961 self.assertEqual(node.body[1].body[2].lineno, 11)
962 self.assertEqual(node.body[2].col_offset, 0)
963 self.assertEqual(node.body[2].lineno, 13)
964
Lysandros Nikolaou025a6022019-12-12 22:40:21 +0100965 def test_elif_stmt_start_position(self):
966 node = ast.parse('if a:\n pass\nelif b:\n pass\n')
967 elif_stmt = node.body[0].orelse[0]
968 self.assertEqual(elif_stmt.lineno, 3)
969 self.assertEqual(elif_stmt.col_offset, 0)
970
Lysandros Nikolaou5936a4c2019-12-14 11:24:57 +0100971 def test_elif_stmt_start_position_with_else(self):
972 node = ast.parse('if a:\n pass\nelif b:\n pass\nelse:\n pass\n')
973 elif_stmt = node.body[0].orelse[0]
974 self.assertEqual(elif_stmt.lineno, 3)
975 self.assertEqual(elif_stmt.col_offset, 0)
976
Lysandros Nikolaou50d4f122019-12-18 01:20:55 +0100977 def test_starred_expr_end_position_within_call(self):
978 node = ast.parse('f(*[0, 1])')
979 starred_expr = node.body[0].value.args[0]
980 self.assertEqual(starred_expr.end_lineno, 1)
981 self.assertEqual(starred_expr.end_col_offset, 9)
982
Georg Brandl0c77a822008-06-10 16:37:50 +0000983 def test_literal_eval(self):
984 self.assertEqual(ast.literal_eval('[1, 2, 3]'), [1, 2, 3])
985 self.assertEqual(ast.literal_eval('{"foo": 42}'), {"foo": 42})
986 self.assertEqual(ast.literal_eval('(True, False, None)'), (True, False, None))
Benjamin Peterson3e742892010-07-11 12:59:24 +0000987 self.assertEqual(ast.literal_eval('{1, 2, 3}'), {1, 2, 3})
Benjamin Peterson5ef96e52010-07-11 23:06:06 +0000988 self.assertEqual(ast.literal_eval('b"hi"'), b"hi")
Raymond Hettinger4fcf5c12020-01-02 22:21:18 -0700989 self.assertEqual(ast.literal_eval('set()'), set())
Georg Brandl0c77a822008-06-10 16:37:50 +0000990 self.assertRaises(ValueError, ast.literal_eval, 'foo()')
Serhiy Storchakad8ac4d12018-01-04 11:15:39 +0200991 self.assertEqual(ast.literal_eval('6'), 6)
992 self.assertEqual(ast.literal_eval('+6'), 6)
Raymond Hettingerbc959732010-10-08 00:47:45 +0000993 self.assertEqual(ast.literal_eval('-6'), -6)
Raymond Hettingerbc959732010-10-08 00:47:45 +0000994 self.assertEqual(ast.literal_eval('3.25'), 3.25)
Serhiy Storchakad8ac4d12018-01-04 11:15:39 +0200995 self.assertEqual(ast.literal_eval('+3.25'), 3.25)
996 self.assertEqual(ast.literal_eval('-3.25'), -3.25)
997 self.assertEqual(repr(ast.literal_eval('-0.0')), '-0.0')
998 self.assertRaises(ValueError, ast.literal_eval, '++6')
999 self.assertRaises(ValueError, ast.literal_eval, '+True')
1000 self.assertRaises(ValueError, ast.literal_eval, '2+3')
Georg Brandl0c77a822008-06-10 16:37:50 +00001001
Serhiy Storchakad8ac4d12018-01-04 11:15:39 +02001002 def test_literal_eval_complex(self):
1003 # Issue #4907
1004 self.assertEqual(ast.literal_eval('6j'), 6j)
1005 self.assertEqual(ast.literal_eval('-6j'), -6j)
1006 self.assertEqual(ast.literal_eval('6.75j'), 6.75j)
1007 self.assertEqual(ast.literal_eval('-6.75j'), -6.75j)
1008 self.assertEqual(ast.literal_eval('3+6j'), 3+6j)
1009 self.assertEqual(ast.literal_eval('-3+6j'), -3+6j)
1010 self.assertEqual(ast.literal_eval('3-6j'), 3-6j)
1011 self.assertEqual(ast.literal_eval('-3-6j'), -3-6j)
1012 self.assertEqual(ast.literal_eval('3.25+6.75j'), 3.25+6.75j)
1013 self.assertEqual(ast.literal_eval('-3.25+6.75j'), -3.25+6.75j)
1014 self.assertEqual(ast.literal_eval('3.25-6.75j'), 3.25-6.75j)
1015 self.assertEqual(ast.literal_eval('-3.25-6.75j'), -3.25-6.75j)
1016 self.assertEqual(ast.literal_eval('(3+6j)'), 3+6j)
1017 self.assertRaises(ValueError, ast.literal_eval, '-6j+3')
1018 self.assertRaises(ValueError, ast.literal_eval, '-6j+3j')
1019 self.assertRaises(ValueError, ast.literal_eval, '3+-6j')
1020 self.assertRaises(ValueError, ast.literal_eval, '3+(0+6j)')
1021 self.assertRaises(ValueError, ast.literal_eval, '-(3+6j)')
Benjamin Peterson058e31e2009-01-16 03:54:08 +00001022
Curtis Bucherc21c5122020-05-05 12:40:56 -07001023 def test_literal_eval_malformed_dict_nodes(self):
1024 malformed = ast.Dict(keys=[ast.Constant(1), ast.Constant(2)], values=[ast.Constant(3)])
1025 self.assertRaises(ValueError, ast.literal_eval, malformed)
1026 malformed = ast.Dict(keys=[ast.Constant(1)], values=[ast.Constant(2), ast.Constant(3)])
1027 self.assertRaises(ValueError, ast.literal_eval, malformed)
1028
Batuhan Taskayae799aa82020-10-04 03:46:44 +03001029 def test_literal_eval_trailing_ws(self):
1030 self.assertEqual(ast.literal_eval(" -1"), -1)
1031 self.assertEqual(ast.literal_eval("\t\t-1"), -1)
1032 self.assertEqual(ast.literal_eval(" \t -1"), -1)
1033 self.assertRaises(IndentationError, ast.literal_eval, "\n -1")
1034
Irit Katriel586f3db2020-12-25 17:04:31 +00001035 def test_literal_eval_malformed_lineno(self):
1036 msg = r'malformed node or string on line 3:'
1037 with self.assertRaisesRegex(ValueError, msg):
1038 ast.literal_eval("{'a': 1,\n'b':2,\n'c':++3,\n'd':4}")
1039
1040 node = ast.UnaryOp(
1041 ast.UAdd(), ast.UnaryOp(ast.UAdd(), ast.Constant(6)))
1042 self.assertIsNone(getattr(node, 'lineno', None))
1043 msg = r'malformed node or string:'
1044 with self.assertRaisesRegex(ValueError, msg):
1045 ast.literal_eval(node)
1046
Amaury Forgeot d'Arc58e87612011-11-22 21:51:55 +01001047 def test_bad_integer(self):
1048 # issue13436: Bad error message with invalid numeric values
1049 body = [ast.ImportFrom(module='time',
1050 names=[ast.alias(name='sleep')],
1051 level=None,
1052 lineno=None, col_offset=None)]
Guido van Rossumdcfcd142019-01-31 03:40:27 -08001053 mod = ast.Module(body, [])
Amaury Forgeot d'Arc58e87612011-11-22 21:51:55 +01001054 with self.assertRaises(ValueError) as cm:
1055 compile(mod, 'test', 'exec')
1056 self.assertIn("invalid integer value: None", str(cm.exception))
1057
Berker Peksag0a5bd512016-04-29 19:50:02 +03001058 def test_level_as_none(self):
1059 body = [ast.ImportFrom(module='time',
Matthew Suozzo75a06f02021-04-10 16:56:28 -04001060 names=[ast.alias(name='sleep',
1061 lineno=0, col_offset=0)],
Berker Peksag0a5bd512016-04-29 19:50:02 +03001062 level=None,
1063 lineno=0, col_offset=0)]
Guido van Rossumdcfcd142019-01-31 03:40:27 -08001064 mod = ast.Module(body, [])
Berker Peksag0a5bd512016-04-29 19:50:02 +03001065 code = compile(mod, 'test', 'exec')
1066 ns = {}
1067 exec(code, ns)
1068 self.assertIn('sleep', ns)
1069
Miss Islington (bot)976598d2021-06-03 13:27:00 -07001070 def test_recursion_direct(self):
1071 e = ast.UnaryOp(op=ast.Not(), lineno=0, col_offset=0)
1072 e.operand = e
1073 with self.assertRaises(RecursionError):
Batuhan Taskayabd6f0d32021-06-08 20:39:30 +03001074 with support.infinite_recursion():
1075 compile(ast.Expression(e), "<test>", "eval")
Miss Islington (bot)976598d2021-06-03 13:27:00 -07001076
1077 def test_recursion_indirect(self):
1078 e = ast.UnaryOp(op=ast.Not(), lineno=0, col_offset=0)
1079 f = ast.UnaryOp(op=ast.Not(), lineno=0, col_offset=0)
1080 e.operand = f
1081 f.operand = e
1082 with self.assertRaises(RecursionError):
Batuhan Taskayabd6f0d32021-06-08 20:39:30 +03001083 with support.infinite_recursion():
1084 compile(ast.Expression(e), "<test>", "eval")
Miss Islington (bot)976598d2021-06-03 13:27:00 -07001085
Georg Brandl0c77a822008-06-10 16:37:50 +00001086
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001087class ASTValidatorTests(unittest.TestCase):
1088
1089 def mod(self, mod, msg=None, mode="exec", *, exc=ValueError):
1090 mod.lineno = mod.col_offset = 0
1091 ast.fix_missing_locations(mod)
Serhiy Storchaka3f228112018-09-27 17:42:37 +03001092 if msg is None:
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001093 compile(mod, "<test>", mode)
Serhiy Storchaka3f228112018-09-27 17:42:37 +03001094 else:
1095 with self.assertRaises(exc) as cm:
1096 compile(mod, "<test>", mode)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001097 self.assertIn(msg, str(cm.exception))
1098
1099 def expr(self, node, msg=None, *, exc=ValueError):
Guido van Rossumdcfcd142019-01-31 03:40:27 -08001100 mod = ast.Module([ast.Expr(node)], [])
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001101 self.mod(mod, msg, exc=exc)
1102
1103 def stmt(self, stmt, msg=None):
Guido van Rossumdcfcd142019-01-31 03:40:27 -08001104 mod = ast.Module([stmt], [])
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001105 self.mod(mod, msg)
1106
1107 def test_module(self):
1108 m = ast.Interactive([ast.Expr(ast.Name("x", ast.Store()))])
1109 self.mod(m, "must have Load context", "single")
1110 m = ast.Expression(ast.Name("x", ast.Store()))
1111 self.mod(m, "must have Load context", "eval")
1112
1113 def _check_arguments(self, fac, check):
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01001114 def arguments(args=None, posonlyargs=None, vararg=None,
Benjamin Petersoncda75be2013-03-18 10:48:58 -07001115 kwonlyargs=None, kwarg=None,
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001116 defaults=None, kw_defaults=None):
1117 if args is None:
1118 args = []
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01001119 if posonlyargs is None:
1120 posonlyargs = []
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001121 if kwonlyargs is None:
1122 kwonlyargs = []
1123 if defaults is None:
1124 defaults = []
1125 if kw_defaults is None:
1126 kw_defaults = []
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01001127 args = ast.arguments(args, posonlyargs, vararg, kwonlyargs,
1128 kw_defaults, kwarg, defaults)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001129 return fac(args)
1130 args = [ast.arg("x", ast.Name("x", ast.Store()))]
1131 check(arguments(args=args), "must have Load context")
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01001132 check(arguments(posonlyargs=args), "must have Load context")
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001133 check(arguments(kwonlyargs=args), "must have Load context")
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001134 check(arguments(defaults=[ast.Num(3)]),
1135 "more positional defaults than args")
1136 check(arguments(kw_defaults=[ast.Num(4)]),
1137 "length of kwonlyargs is not the same as kw_defaults")
1138 args = [ast.arg("x", ast.Name("x", ast.Load()))]
1139 check(arguments(args=args, defaults=[ast.Name("x", ast.Store())]),
1140 "must have Load context")
1141 args = [ast.arg("a", ast.Name("x", ast.Load())),
1142 ast.arg("b", ast.Name("y", ast.Load()))]
1143 check(arguments(kwonlyargs=args,
1144 kw_defaults=[None, ast.Name("x", ast.Store())]),
1145 "must have Load context")
1146
1147 def test_funcdef(self):
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01001148 a = ast.arguments([], [], None, [], [], None, [])
Serhiy Storchaka73cbe7a2018-05-29 12:04:55 +03001149 f = ast.FunctionDef("x", a, [], [], None)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001150 self.stmt(f, "empty body on FunctionDef")
1151 f = ast.FunctionDef("x", a, [ast.Pass()], [ast.Name("x", ast.Store())],
Serhiy Storchaka73cbe7a2018-05-29 12:04:55 +03001152 None)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001153 self.stmt(f, "must have Load context")
1154 f = ast.FunctionDef("x", a, [ast.Pass()], [],
Serhiy Storchaka73cbe7a2018-05-29 12:04:55 +03001155 ast.Name("x", ast.Store()))
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001156 self.stmt(f, "must have Load context")
1157 def fac(args):
Serhiy Storchaka73cbe7a2018-05-29 12:04:55 +03001158 return ast.FunctionDef("x", args, [ast.Pass()], [], None)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001159 self._check_arguments(fac, self.stmt)
1160
1161 def test_classdef(self):
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04001162 def cls(bases=None, keywords=None, body=None, decorator_list=None):
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001163 if bases is None:
1164 bases = []
1165 if keywords is None:
1166 keywords = []
1167 if body is None:
1168 body = [ast.Pass()]
1169 if decorator_list is None:
1170 decorator_list = []
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04001171 return ast.ClassDef("myclass", bases, keywords,
Serhiy Storchaka73cbe7a2018-05-29 12:04:55 +03001172 body, decorator_list)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001173 self.stmt(cls(bases=[ast.Name("x", ast.Store())]),
1174 "must have Load context")
1175 self.stmt(cls(keywords=[ast.keyword("x", ast.Name("x", ast.Store()))]),
1176 "must have Load context")
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001177 self.stmt(cls(body=[]), "empty body on ClassDef")
1178 self.stmt(cls(body=[None]), "None disallowed")
1179 self.stmt(cls(decorator_list=[ast.Name("x", ast.Store())]),
1180 "must have Load context")
1181
1182 def test_delete(self):
1183 self.stmt(ast.Delete([]), "empty targets on Delete")
1184 self.stmt(ast.Delete([None]), "None disallowed")
1185 self.stmt(ast.Delete([ast.Name("x", ast.Load())]),
1186 "must have Del context")
1187
1188 def test_assign(self):
1189 self.stmt(ast.Assign([], ast.Num(3)), "empty targets on Assign")
1190 self.stmt(ast.Assign([None], ast.Num(3)), "None disallowed")
1191 self.stmt(ast.Assign([ast.Name("x", ast.Load())], ast.Num(3)),
1192 "must have Store context")
1193 self.stmt(ast.Assign([ast.Name("x", ast.Store())],
1194 ast.Name("y", ast.Store())),
1195 "must have Load context")
1196
1197 def test_augassign(self):
1198 aug = ast.AugAssign(ast.Name("x", ast.Load()), ast.Add(),
1199 ast.Name("y", ast.Load()))
1200 self.stmt(aug, "must have Store context")
1201 aug = ast.AugAssign(ast.Name("x", ast.Store()), ast.Add(),
1202 ast.Name("y", ast.Store()))
1203 self.stmt(aug, "must have Load context")
1204
1205 def test_for(self):
1206 x = ast.Name("x", ast.Store())
1207 y = ast.Name("y", ast.Load())
1208 p = ast.Pass()
1209 self.stmt(ast.For(x, y, [], []), "empty body on For")
1210 self.stmt(ast.For(ast.Name("x", ast.Load()), y, [p], []),
1211 "must have Store context")
1212 self.stmt(ast.For(x, ast.Name("y", ast.Store()), [p], []),
1213 "must have Load context")
1214 e = ast.Expr(ast.Name("x", ast.Store()))
1215 self.stmt(ast.For(x, y, [e], []), "must have Load context")
1216 self.stmt(ast.For(x, y, [p], [e]), "must have Load context")
1217
1218 def test_while(self):
1219 self.stmt(ast.While(ast.Num(3), [], []), "empty body on While")
1220 self.stmt(ast.While(ast.Name("x", ast.Store()), [ast.Pass()], []),
1221 "must have Load context")
1222 self.stmt(ast.While(ast.Num(3), [ast.Pass()],
1223 [ast.Expr(ast.Name("x", ast.Store()))]),
1224 "must have Load context")
1225
1226 def test_if(self):
1227 self.stmt(ast.If(ast.Num(3), [], []), "empty body on If")
1228 i = ast.If(ast.Name("x", ast.Store()), [ast.Pass()], [])
1229 self.stmt(i, "must have Load context")
1230 i = ast.If(ast.Num(3), [ast.Expr(ast.Name("x", ast.Store()))], [])
1231 self.stmt(i, "must have Load context")
1232 i = ast.If(ast.Num(3), [ast.Pass()],
1233 [ast.Expr(ast.Name("x", ast.Store()))])
1234 self.stmt(i, "must have Load context")
1235
1236 def test_with(self):
1237 p = ast.Pass()
1238 self.stmt(ast.With([], [p]), "empty items on With")
1239 i = ast.withitem(ast.Num(3), None)
1240 self.stmt(ast.With([i], []), "empty body on With")
1241 i = ast.withitem(ast.Name("x", ast.Store()), None)
1242 self.stmt(ast.With([i], [p]), "must have Load context")
1243 i = ast.withitem(ast.Num(3), ast.Name("x", ast.Load()))
1244 self.stmt(ast.With([i], [p]), "must have Store context")
1245
1246 def test_raise(self):
1247 r = ast.Raise(None, ast.Num(3))
1248 self.stmt(r, "Raise with cause but no exception")
1249 r = ast.Raise(ast.Name("x", ast.Store()), None)
1250 self.stmt(r, "must have Load context")
1251 r = ast.Raise(ast.Num(4), ast.Name("x", ast.Store()))
1252 self.stmt(r, "must have Load context")
1253
1254 def test_try(self):
1255 p = ast.Pass()
1256 t = ast.Try([], [], [], [p])
1257 self.stmt(t, "empty body on Try")
1258 t = ast.Try([ast.Expr(ast.Name("x", ast.Store()))], [], [], [p])
1259 self.stmt(t, "must have Load context")
1260 t = ast.Try([p], [], [], [])
1261 self.stmt(t, "Try has neither except handlers nor finalbody")
1262 t = ast.Try([p], [], [p], [p])
1263 self.stmt(t, "Try has orelse but no except handlers")
1264 t = ast.Try([p], [ast.ExceptHandler(None, "x", [])], [], [])
1265 self.stmt(t, "empty body on ExceptHandler")
1266 e = [ast.ExceptHandler(ast.Name("x", ast.Store()), "y", [p])]
1267 self.stmt(ast.Try([p], e, [], []), "must have Load context")
1268 e = [ast.ExceptHandler(None, "x", [p])]
1269 t = ast.Try([p], e, [ast.Expr(ast.Name("x", ast.Store()))], [p])
1270 self.stmt(t, "must have Load context")
1271 t = ast.Try([p], e, [p], [ast.Expr(ast.Name("x", ast.Store()))])
1272 self.stmt(t, "must have Load context")
1273
1274 def test_assert(self):
1275 self.stmt(ast.Assert(ast.Name("x", ast.Store()), None),
1276 "must have Load context")
1277 assrt = ast.Assert(ast.Name("x", ast.Load()),
1278 ast.Name("y", ast.Store()))
1279 self.stmt(assrt, "must have Load context")
1280
1281 def test_import(self):
1282 self.stmt(ast.Import([]), "empty names on Import")
1283
1284 def test_importfrom(self):
1285 imp = ast.ImportFrom(None, [ast.alias("x", None)], -42)
Serhiy Storchaka7de28402016-06-27 23:40:43 +03001286 self.stmt(imp, "Negative ImportFrom level")
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001287 self.stmt(ast.ImportFrom(None, [], 0), "empty names on ImportFrom")
1288
1289 def test_global(self):
1290 self.stmt(ast.Global([]), "empty names on Global")
1291
1292 def test_nonlocal(self):
1293 self.stmt(ast.Nonlocal([]), "empty names on Nonlocal")
1294
1295 def test_expr(self):
1296 e = ast.Expr(ast.Name("x", ast.Store()))
1297 self.stmt(e, "must have Load context")
1298
1299 def test_boolop(self):
1300 b = ast.BoolOp(ast.And(), [])
1301 self.expr(b, "less than 2 values")
1302 b = ast.BoolOp(ast.And(), [ast.Num(3)])
1303 self.expr(b, "less than 2 values")
1304 b = ast.BoolOp(ast.And(), [ast.Num(4), None])
1305 self.expr(b, "None disallowed")
1306 b = ast.BoolOp(ast.And(), [ast.Num(4), ast.Name("x", ast.Store())])
1307 self.expr(b, "must have Load context")
1308
1309 def test_unaryop(self):
1310 u = ast.UnaryOp(ast.Not(), ast.Name("x", ast.Store()))
1311 self.expr(u, "must have Load context")
1312
1313 def test_lambda(self):
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01001314 a = ast.arguments([], [], None, [], [], None, [])
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001315 self.expr(ast.Lambda(a, ast.Name("x", ast.Store())),
1316 "must have Load context")
1317 def fac(args):
1318 return ast.Lambda(args, ast.Name("x", ast.Load()))
1319 self._check_arguments(fac, self.expr)
1320
1321 def test_ifexp(self):
1322 l = ast.Name("x", ast.Load())
1323 s = ast.Name("y", ast.Store())
1324 for args in (s, l, l), (l, s, l), (l, l, s):
Benjamin Peterson71ce8972011-08-09 16:17:12 -05001325 self.expr(ast.IfExp(*args), "must have Load context")
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001326
1327 def test_dict(self):
1328 d = ast.Dict([], [ast.Name("x", ast.Load())])
1329 self.expr(d, "same number of keys as values")
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001330 d = ast.Dict([ast.Name("x", ast.Load())], [None])
1331 self.expr(d, "None disallowed")
1332
1333 def test_set(self):
1334 self.expr(ast.Set([None]), "None disallowed")
1335 s = ast.Set([ast.Name("x", ast.Store())])
1336 self.expr(s, "must have Load context")
1337
1338 def _check_comprehension(self, fac):
1339 self.expr(fac([]), "comprehension with no generators")
1340 g = ast.comprehension(ast.Name("x", ast.Load()),
Yury Selivanov52c4e7c2016-09-09 10:36:01 -07001341 ast.Name("x", ast.Load()), [], 0)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001342 self.expr(fac([g]), "must have Store context")
1343 g = ast.comprehension(ast.Name("x", ast.Store()),
Yury Selivanov52c4e7c2016-09-09 10:36:01 -07001344 ast.Name("x", ast.Store()), [], 0)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001345 self.expr(fac([g]), "must have Load context")
1346 x = ast.Name("x", ast.Store())
1347 y = ast.Name("y", ast.Load())
Yury Selivanov52c4e7c2016-09-09 10:36:01 -07001348 g = ast.comprehension(x, y, [None], 0)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001349 self.expr(fac([g]), "None disallowed")
Yury Selivanov52c4e7c2016-09-09 10:36:01 -07001350 g = ast.comprehension(x, y, [ast.Name("x", ast.Store())], 0)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001351 self.expr(fac([g]), "must have Load context")
1352
1353 def _simple_comp(self, fac):
1354 g = ast.comprehension(ast.Name("x", ast.Store()),
Yury Selivanov52c4e7c2016-09-09 10:36:01 -07001355 ast.Name("x", ast.Load()), [], 0)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001356 self.expr(fac(ast.Name("x", ast.Store()), [g]),
1357 "must have Load context")
1358 def wrap(gens):
1359 return fac(ast.Name("x", ast.Store()), gens)
1360 self._check_comprehension(wrap)
1361
1362 def test_listcomp(self):
1363 self._simple_comp(ast.ListComp)
1364
1365 def test_setcomp(self):
1366 self._simple_comp(ast.SetComp)
1367
1368 def test_generatorexp(self):
1369 self._simple_comp(ast.GeneratorExp)
1370
1371 def test_dictcomp(self):
1372 g = ast.comprehension(ast.Name("y", ast.Store()),
Yury Selivanov52c4e7c2016-09-09 10:36:01 -07001373 ast.Name("p", ast.Load()), [], 0)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001374 c = ast.DictComp(ast.Name("x", ast.Store()),
1375 ast.Name("y", ast.Load()), [g])
1376 self.expr(c, "must have Load context")
1377 c = ast.DictComp(ast.Name("x", ast.Load()),
1378 ast.Name("y", ast.Store()), [g])
1379 self.expr(c, "must have Load context")
1380 def factory(comps):
1381 k = ast.Name("x", ast.Load())
1382 v = ast.Name("y", ast.Load())
1383 return ast.DictComp(k, v, comps)
1384 self._check_comprehension(factory)
1385
1386 def test_yield(self):
Benjamin Peterson527c6222012-01-14 08:58:23 -05001387 self.expr(ast.Yield(ast.Name("x", ast.Store())), "must have Load")
1388 self.expr(ast.YieldFrom(ast.Name("x", ast.Store())), "must have Load")
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001389
1390 def test_compare(self):
1391 left = ast.Name("x", ast.Load())
1392 comp = ast.Compare(left, [ast.In()], [])
1393 self.expr(comp, "no comparators")
1394 comp = ast.Compare(left, [ast.In()], [ast.Num(4), ast.Num(5)])
1395 self.expr(comp, "different number of comparators and operands")
1396 comp = ast.Compare(ast.Num("blah"), [ast.In()], [left])
Serhiy Storchaka3f228112018-09-27 17:42:37 +03001397 self.expr(comp)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001398 comp = ast.Compare(left, [ast.In()], [ast.Num("blah")])
Serhiy Storchaka3f228112018-09-27 17:42:37 +03001399 self.expr(comp)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001400
1401 def test_call(self):
1402 func = ast.Name("x", ast.Load())
1403 args = [ast.Name("y", ast.Load())]
1404 keywords = [ast.keyword("w", ast.Name("z", ast.Load()))]
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04001405 call = ast.Call(ast.Name("x", ast.Store()), args, keywords)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001406 self.expr(call, "must have Load context")
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04001407 call = ast.Call(func, [None], keywords)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001408 self.expr(call, "None disallowed")
1409 bad_keywords = [ast.keyword("w", ast.Name("z", ast.Store()))]
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04001410 call = ast.Call(func, args, bad_keywords)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001411 self.expr(call, "must have Load context")
1412
1413 def test_num(self):
1414 class subint(int):
1415 pass
1416 class subfloat(float):
1417 pass
1418 class subcomplex(complex):
1419 pass
Serhiy Storchaka3f228112018-09-27 17:42:37 +03001420 for obj in "0", "hello":
1421 self.expr(ast.Num(obj))
1422 for obj in subint(), subfloat(), subcomplex():
1423 self.expr(ast.Num(obj), "invalid type", exc=TypeError)
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001424
1425 def test_attribute(self):
1426 attr = ast.Attribute(ast.Name("x", ast.Store()), "y", ast.Load())
1427 self.expr(attr, "must have Load context")
1428
1429 def test_subscript(self):
Serhiy Storchaka13d52c22020-03-10 18:52:34 +02001430 sub = ast.Subscript(ast.Name("x", ast.Store()), ast.Num(3),
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001431 ast.Load())
1432 self.expr(sub, "must have Load context")
1433 x = ast.Name("x", ast.Load())
Serhiy Storchaka13d52c22020-03-10 18:52:34 +02001434 sub = ast.Subscript(x, ast.Name("y", ast.Store()),
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001435 ast.Load())
1436 self.expr(sub, "must have Load context")
1437 s = ast.Name("x", ast.Store())
1438 for args in (s, None, None), (None, s, None), (None, None, s):
1439 sl = ast.Slice(*args)
1440 self.expr(ast.Subscript(x, sl, ast.Load()),
1441 "must have Load context")
Serhiy Storchaka13d52c22020-03-10 18:52:34 +02001442 sl = ast.Tuple([], ast.Load())
1443 self.expr(ast.Subscript(x, sl, ast.Load()))
1444 sl = ast.Tuple([s], ast.Load())
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001445 self.expr(ast.Subscript(x, sl, ast.Load()), "must have Load context")
1446
1447 def test_starred(self):
1448 left = ast.List([ast.Starred(ast.Name("x", ast.Load()), ast.Store())],
1449 ast.Store())
1450 assign = ast.Assign([left], ast.Num(4))
1451 self.stmt(assign, "must have Store context")
1452
1453 def _sequence(self, fac):
1454 self.expr(fac([None], ast.Load()), "None disallowed")
1455 self.expr(fac([ast.Name("x", ast.Store())], ast.Load()),
1456 "must have Load context")
1457
1458 def test_list(self):
1459 self._sequence(ast.List)
1460
1461 def test_tuple(self):
1462 self._sequence(ast.Tuple)
1463
Benjamin Peterson442f2092012-12-06 17:41:04 -05001464 def test_nameconstant(self):
Serhiy Storchaka3f228112018-09-27 17:42:37 +03001465 self.expr(ast.NameConstant(4))
Benjamin Peterson442f2092012-12-06 17:41:04 -05001466
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001467 def test_stdlib_validates(self):
1468 stdlib = os.path.dirname(ast.__file__)
1469 tests = [fn for fn in os.listdir(stdlib) if fn.endswith(".py")]
1470 tests.extend(["test/test_grammar.py", "test/test_unpack_ex.py"])
1471 for module in tests:
Serhiy Storchaka3bcbedc2019-01-18 07:47:48 +02001472 with self.subTest(module):
1473 fn = os.path.join(stdlib, module)
1474 with open(fn, "r", encoding="utf-8") as fp:
1475 source = fp.read()
1476 mod = ast.parse(source, fn)
1477 compile(mod, fn, "exec")
Benjamin Peterson832bfe22011-08-09 16:15:04 -05001478
1479
Victor Stinnerf2c1aa12016-01-26 00:40:57 +01001480class ConstantTests(unittest.TestCase):
1481 """Tests on the ast.Constant node type."""
1482
1483 def compile_constant(self, value):
1484 tree = ast.parse("x = 123")
1485
1486 node = tree.body[0].value
1487 new_node = ast.Constant(value=value)
1488 ast.copy_location(new_node, node)
1489 tree.body[0].value = new_node
1490
1491 code = compile(tree, "<string>", "exec")
1492
1493 ns = {}
1494 exec(code, ns)
1495 return ns['x']
1496
Victor Stinnerbe59d142016-01-27 00:39:12 +01001497 def test_validation(self):
1498 with self.assertRaises(TypeError) as cm:
1499 self.compile_constant([1, 2, 3])
1500 self.assertEqual(str(cm.exception),
1501 "got an invalid type in Constant: list")
1502
Victor Stinnerf2c1aa12016-01-26 00:40:57 +01001503 def test_singletons(self):
1504 for const in (None, False, True, Ellipsis, b'', frozenset()):
1505 with self.subTest(const=const):
1506 value = self.compile_constant(const)
1507 self.assertIs(value, const)
1508
1509 def test_values(self):
1510 nested_tuple = (1,)
1511 nested_frozenset = frozenset({1})
1512 for level in range(3):
1513 nested_tuple = (nested_tuple, 2)
1514 nested_frozenset = frozenset({nested_frozenset, 2})
1515 values = (123, 123.0, 123j,
1516 "unicode", b'bytes',
1517 tuple("tuple"), frozenset("frozenset"),
1518 nested_tuple, nested_frozenset)
1519 for value in values:
1520 with self.subTest(value=value):
1521 result = self.compile_constant(value)
1522 self.assertEqual(result, value)
1523
1524 def test_assign_to_constant(self):
1525 tree = ast.parse("x = 1")
1526
1527 target = tree.body[0].targets[0]
1528 new_target = ast.Constant(value=1)
1529 ast.copy_location(new_target, target)
1530 tree.body[0].targets[0] = new_target
1531
1532 with self.assertRaises(ValueError) as cm:
1533 compile(tree, "string", "exec")
1534 self.assertEqual(str(cm.exception),
1535 "expression which can't be assigned "
1536 "to in Store context")
1537
1538 def test_get_docstring(self):
1539 tree = ast.parse("'docstring'\nx = 1")
1540 self.assertEqual(ast.get_docstring(tree), 'docstring')
1541
Victor Stinnerf2c1aa12016-01-26 00:40:57 +01001542 def get_load_const(self, tree):
1543 # Compile to bytecode, disassemble and get parameter of LOAD_CONST
1544 # instructions
1545 co = compile(tree, '<string>', 'exec')
1546 consts = []
1547 for instr in dis.get_instructions(co):
1548 if instr.opname == 'LOAD_CONST':
1549 consts.append(instr.argval)
1550 return consts
1551
1552 @support.cpython_only
1553 def test_load_const(self):
1554 consts = [None,
1555 True, False,
1556 124,
1557 2.0,
1558 3j,
1559 "unicode",
1560 b'bytes',
1561 (1, 2, 3)]
1562
Victor Stinnera2724092016-02-08 18:17:58 +01001563 code = '\n'.join(['x={!r}'.format(const) for const in consts])
1564 code += '\nx = ...'
1565 consts.extend((Ellipsis, None))
Victor Stinnerf2c1aa12016-01-26 00:40:57 +01001566
1567 tree = ast.parse(code)
Victor Stinnera2724092016-02-08 18:17:58 +01001568 self.assertEqual(self.get_load_const(tree),
1569 consts)
Victor Stinnerf2c1aa12016-01-26 00:40:57 +01001570
1571 # Replace expression nodes with constants
Victor Stinnera2724092016-02-08 18:17:58 +01001572 for assign, const in zip(tree.body, consts):
1573 assert isinstance(assign, ast.Assign), ast.dump(assign)
Victor Stinnerf2c1aa12016-01-26 00:40:57 +01001574 new_node = ast.Constant(value=const)
Victor Stinnera2724092016-02-08 18:17:58 +01001575 ast.copy_location(new_node, assign.value)
1576 assign.value = new_node
Victor Stinnerf2c1aa12016-01-26 00:40:57 +01001577
Victor Stinnera2724092016-02-08 18:17:58 +01001578 self.assertEqual(self.get_load_const(tree),
1579 consts)
Victor Stinnerf2c1aa12016-01-26 00:40:57 +01001580
1581 def test_literal_eval(self):
1582 tree = ast.parse("1 + 2")
1583 binop = tree.body[0].value
1584
1585 new_left = ast.Constant(value=10)
1586 ast.copy_location(new_left, binop.left)
1587 binop.left = new_left
1588
Serhiy Storchakad8ac4d12018-01-04 11:15:39 +02001589 new_right = ast.Constant(value=20j)
Victor Stinnerf2c1aa12016-01-26 00:40:57 +01001590 ast.copy_location(new_right, binop.right)
1591 binop.right = new_right
1592
Serhiy Storchakad8ac4d12018-01-04 11:15:39 +02001593 self.assertEqual(ast.literal_eval(binop), 10+20j)
Victor Stinnerf2c1aa12016-01-26 00:40:57 +01001594
Guido van Rossum10f8ce62019-03-13 13:00:46 -07001595 def test_string_kind(self):
1596 c = ast.parse('"x"', mode='eval').body
1597 self.assertEqual(c.value, "x")
1598 self.assertEqual(c.kind, None)
1599
1600 c = ast.parse('u"x"', mode='eval').body
1601 self.assertEqual(c.value, "x")
1602 self.assertEqual(c.kind, "u")
1603
1604 c = ast.parse('r"x"', mode='eval').body
1605 self.assertEqual(c.value, "x")
1606 self.assertEqual(c.kind, None)
1607
1608 c = ast.parse('b"x"', mode='eval').body
1609 self.assertEqual(c.value, b"x")
1610 self.assertEqual(c.kind, None)
1611
Victor Stinnerf2c1aa12016-01-26 00:40:57 +01001612
Ivan Levkivskyi9932a222019-01-22 11:18:22 +00001613class EndPositionTests(unittest.TestCase):
1614 """Tests for end position of AST nodes.
1615
1616 Testing end positions of nodes requires a bit of extra care
1617 because of how LL parsers work.
1618 """
1619 def _check_end_pos(self, ast_node, end_lineno, end_col_offset):
1620 self.assertEqual(ast_node.end_lineno, end_lineno)
1621 self.assertEqual(ast_node.end_col_offset, end_col_offset)
1622
1623 def _check_content(self, source, ast_node, content):
1624 self.assertEqual(ast.get_source_segment(source, ast_node), content)
1625
1626 def _parse_value(self, s):
1627 # Use duck-typing to support both single expression
1628 # and a right hand side of an assignment statement.
1629 return ast.parse(s).body[0].value
1630
1631 def test_lambda(self):
1632 s = 'lambda x, *y: None'
1633 lam = self._parse_value(s)
1634 self._check_content(s, lam.body, 'None')
1635 self._check_content(s, lam.args.args[0], 'x')
1636 self._check_content(s, lam.args.vararg, 'y')
1637
1638 def test_func_def(self):
1639 s = dedent('''
1640 def func(x: int,
1641 *args: str,
1642 z: float = 0,
1643 **kwargs: Any) -> bool:
1644 return True
1645 ''').strip()
1646 fdef = ast.parse(s).body[0]
1647 self._check_end_pos(fdef, 5, 15)
1648 self._check_content(s, fdef.body[0], 'return True')
1649 self._check_content(s, fdef.args.args[0], 'x: int')
1650 self._check_content(s, fdef.args.args[0].annotation, 'int')
1651 self._check_content(s, fdef.args.kwarg, 'kwargs: Any')
1652 self._check_content(s, fdef.args.kwarg.annotation, 'Any')
1653
1654 def test_call(self):
1655 s = 'func(x, y=2, **kw)'
1656 call = self._parse_value(s)
1657 self._check_content(s, call.func, 'func')
1658 self._check_content(s, call.keywords[0].value, '2')
1659 self._check_content(s, call.keywords[1].value, 'kw')
1660
1661 def test_call_noargs(self):
1662 s = 'x[0]()'
1663 call = self._parse_value(s)
1664 self._check_content(s, call.func, 'x[0]')
1665 self._check_end_pos(call, 1, 6)
1666
1667 def test_class_def(self):
1668 s = dedent('''
1669 class C(A, B):
1670 x: int = 0
1671 ''').strip()
1672 cdef = ast.parse(s).body[0]
1673 self._check_end_pos(cdef, 2, 14)
1674 self._check_content(s, cdef.bases[1], 'B')
1675 self._check_content(s, cdef.body[0], 'x: int = 0')
1676
1677 def test_class_kw(self):
1678 s = 'class S(metaclass=abc.ABCMeta): pass'
1679 cdef = ast.parse(s).body[0]
1680 self._check_content(s, cdef.keywords[0].value, 'abc.ABCMeta')
1681
1682 def test_multi_line_str(self):
1683 s = dedent('''
1684 x = """Some multi-line text.
1685
1686 It goes on starting from same indent."""
1687 ''').strip()
1688 assign = ast.parse(s).body[0]
1689 self._check_end_pos(assign, 3, 40)
1690 self._check_end_pos(assign.value, 3, 40)
1691
1692 def test_continued_str(self):
1693 s = dedent('''
1694 x = "first part" \\
1695 "second part"
1696 ''').strip()
1697 assign = ast.parse(s).body[0]
1698 self._check_end_pos(assign, 2, 13)
1699 self._check_end_pos(assign.value, 2, 13)
1700
1701 def test_suites(self):
1702 # We intentionally put these into the same string to check
1703 # that empty lines are not part of the suite.
1704 s = dedent('''
1705 while True:
1706 pass
1707
1708 if one():
1709 x = None
1710 elif other():
1711 y = None
1712 else:
1713 z = None
1714
1715 for x, y in stuff:
1716 assert True
1717
1718 try:
1719 raise RuntimeError
1720 except TypeError as e:
1721 pass
1722
1723 pass
1724 ''').strip()
1725 mod = ast.parse(s)
1726 while_loop = mod.body[0]
1727 if_stmt = mod.body[1]
1728 for_loop = mod.body[2]
1729 try_stmt = mod.body[3]
1730 pass_stmt = mod.body[4]
1731
1732 self._check_end_pos(while_loop, 2, 8)
1733 self._check_end_pos(if_stmt, 9, 12)
1734 self._check_end_pos(for_loop, 12, 15)
1735 self._check_end_pos(try_stmt, 17, 8)
1736 self._check_end_pos(pass_stmt, 19, 4)
1737
1738 self._check_content(s, while_loop.test, 'True')
1739 self._check_content(s, if_stmt.body[0], 'x = None')
1740 self._check_content(s, if_stmt.orelse[0].test, 'other()')
1741 self._check_content(s, for_loop.target, 'x, y')
1742 self._check_content(s, try_stmt.body[0], 'raise RuntimeError')
1743 self._check_content(s, try_stmt.handlers[0].type, 'TypeError')
1744
1745 def test_fstring(self):
1746 s = 'x = f"abc {x + y} abc"'
1747 fstr = self._parse_value(s)
1748 binop = fstr.values[1].value
1749 self._check_content(s, binop, 'x + y')
1750
1751 def test_fstring_multi_line(self):
1752 s = dedent('''
1753 f"""Some multi-line text.
1754 {
1755 arg_one
1756 +
1757 arg_two
1758 }
1759 It goes on..."""
1760 ''').strip()
1761 fstr = self._parse_value(s)
1762 binop = fstr.values[1].value
1763 self._check_end_pos(binop, 5, 7)
1764 self._check_content(s, binop.left, 'arg_one')
1765 self._check_content(s, binop.right, 'arg_two')
1766
1767 def test_import_from_multi_line(self):
1768 s = dedent('''
1769 from x.y.z import (
1770 a, b, c as c
1771 )
1772 ''').strip()
1773 imp = ast.parse(s).body[0]
1774 self._check_end_pos(imp, 3, 1)
Matthew Suozzo75a06f02021-04-10 16:56:28 -04001775 self._check_end_pos(imp.names[2], 2, 16)
Ivan Levkivskyi9932a222019-01-22 11:18:22 +00001776
1777 def test_slices(self):
1778 s1 = 'f()[1, 2] [0]'
1779 s2 = 'x[ a.b: c.d]'
1780 sm = dedent('''
1781 x[ a.b: f () ,
1782 g () : c.d
1783 ]
1784 ''').strip()
1785 i1, i2, im = map(self._parse_value, (s1, s2, sm))
1786 self._check_content(s1, i1.value, 'f()[1, 2]')
Serhiy Storchaka13d52c22020-03-10 18:52:34 +02001787 self._check_content(s1, i1.value.slice, '1, 2')
Ivan Levkivskyi9932a222019-01-22 11:18:22 +00001788 self._check_content(s2, i2.slice.lower, 'a.b')
1789 self._check_content(s2, i2.slice.upper, 'c.d')
Serhiy Storchaka13d52c22020-03-10 18:52:34 +02001790 self._check_content(sm, im.slice.elts[0].upper, 'f ()')
1791 self._check_content(sm, im.slice.elts[1].lower, 'g ()')
Ivan Levkivskyi9932a222019-01-22 11:18:22 +00001792 self._check_end_pos(im, 3, 3)
1793
1794 def test_binop(self):
1795 s = dedent('''
1796 (1 * 2 + (3 ) +
1797 4
1798 )
1799 ''').strip()
1800 binop = self._parse_value(s)
1801 self._check_end_pos(binop, 2, 6)
1802 self._check_content(s, binop.right, '4')
1803 self._check_content(s, binop.left, '1 * 2 + (3 )')
1804 self._check_content(s, binop.left.right, '3')
1805
1806 def test_boolop(self):
1807 s = dedent('''
1808 if (one_condition and
1809 (other_condition or yet_another_one)):
1810 pass
1811 ''').strip()
1812 bop = ast.parse(s).body[0].test
1813 self._check_end_pos(bop, 2, 44)
1814 self._check_content(s, bop.values[1],
1815 'other_condition or yet_another_one')
1816
1817 def test_tuples(self):
1818 s1 = 'x = () ;'
1819 s2 = 'x = 1 , ;'
1820 s3 = 'x = (1 , 2 ) ;'
1821 sm = dedent('''
1822 x = (
1823 a, b,
1824 )
1825 ''').strip()
1826 t1, t2, t3, tm = map(self._parse_value, (s1, s2, s3, sm))
1827 self._check_content(s1, t1, '()')
1828 self._check_content(s2, t2, '1 ,')
1829 self._check_content(s3, t3, '(1 , 2 )')
1830 self._check_end_pos(tm, 3, 1)
1831
1832 def test_attribute_spaces(self):
1833 s = 'func(x. y .z)'
1834 call = self._parse_value(s)
1835 self._check_content(s, call, s)
1836 self._check_content(s, call.args[0], 'x. y .z')
1837
Serhiy Storchaka6e619c42020-02-12 22:37:49 +02001838 def test_redundant_parenthesis(self):
1839 s = '( ( ( a + b ) ) )'
1840 v = ast.parse(s).body[0].value
1841 self.assertEqual(type(v).__name__, 'BinOp')
1842 self._check_content(s, v, 'a + b')
1843 s2 = 'await ' + s
1844 v = ast.parse(s2).body[0].value.value
1845 self.assertEqual(type(v).__name__, 'BinOp')
1846 self._check_content(s2, v, 'a + b')
1847
1848 def test_trailers_with_redundant_parenthesis(self):
1849 tests = (
1850 ('( ( ( a ) ) ) ( )', 'Call'),
1851 ('( ( ( a ) ) ) ( b )', 'Call'),
1852 ('( ( ( a ) ) ) [ b ]', 'Subscript'),
1853 ('( ( ( a ) ) ) . b', 'Attribute'),
1854 )
1855 for s, t in tests:
1856 with self.subTest(s):
1857 v = ast.parse(s).body[0].value
1858 self.assertEqual(type(v).__name__, t)
1859 self._check_content(s, v, s)
1860 s2 = 'await ' + s
1861 v = ast.parse(s2).body[0].value.value
1862 self.assertEqual(type(v).__name__, t)
1863 self._check_content(s2, v, s)
1864
Ivan Levkivskyi9932a222019-01-22 11:18:22 +00001865 def test_displays(self):
1866 s1 = '[{}, {1, }, {1, 2,} ]'
1867 s2 = '{a: b, f (): g () ,}'
1868 c1 = self._parse_value(s1)
1869 c2 = self._parse_value(s2)
1870 self._check_content(s1, c1.elts[0], '{}')
1871 self._check_content(s1, c1.elts[1], '{1, }')
1872 self._check_content(s1, c1.elts[2], '{1, 2,}')
1873 self._check_content(s2, c2.keys[1], 'f ()')
1874 self._check_content(s2, c2.values[1], 'g ()')
1875
1876 def test_comprehensions(self):
1877 s = dedent('''
1878 x = [{x for x, y in stuff
1879 if cond.x} for stuff in things]
1880 ''').strip()
1881 cmp = self._parse_value(s)
1882 self._check_end_pos(cmp, 2, 37)
1883 self._check_content(s, cmp.generators[0].iter, 'things')
1884 self._check_content(s, cmp.elt.generators[0].iter, 'stuff')
1885 self._check_content(s, cmp.elt.generators[0].ifs[0], 'cond.x')
1886 self._check_content(s, cmp.elt.generators[0].target, 'x, y')
1887
1888 def test_yield_await(self):
1889 s = dedent('''
1890 async def f():
1891 yield x
1892 await y
1893 ''').strip()
1894 fdef = ast.parse(s).body[0]
1895 self._check_content(s, fdef.body[0].value, 'yield x')
1896 self._check_content(s, fdef.body[1].value, 'await y')
1897
1898 def test_source_segment_multi(self):
1899 s_orig = dedent('''
1900 x = (
1901 a, b,
1902 ) + ()
1903 ''').strip()
1904 s_tuple = dedent('''
1905 (
1906 a, b,
1907 )
1908 ''').strip()
1909 binop = self._parse_value(s_orig)
1910 self.assertEqual(ast.get_source_segment(s_orig, binop.left), s_tuple)
1911
1912 def test_source_segment_padded(self):
1913 s_orig = dedent('''
1914 class C:
1915 def fun(self) -> None:
1916 "Đ–Đ–Đ–Đ–Đ–"
1917 ''').strip()
1918 s_method = ' def fun(self) -> None:\n' \
1919 ' "Đ–Đ–Đ–Đ–Đ–"'
1920 cdef = ast.parse(s_orig).body[0]
1921 self.assertEqual(ast.get_source_segment(s_orig, cdef.body[0], padded=True),
1922 s_method)
1923
1924 def test_source_segment_endings(self):
1925 s = 'v = 1\r\nw = 1\nx = 1\n\ry = 1\rz = 1\r\n'
1926 v, w, x, y, z = ast.parse(s).body
1927 self._check_content(s, v, 'v = 1')
1928 self._check_content(s, w, 'w = 1')
1929 self._check_content(s, x, 'x = 1')
1930 self._check_content(s, y, 'y = 1')
1931 self._check_content(s, z, 'z = 1')
1932
1933 def test_source_segment_tabs(self):
1934 s = dedent('''
1935 class C:
1936 \t\f def fun(self) -> None:
1937 \t\f pass
1938 ''').strip()
1939 s_method = ' \t\f def fun(self) -> None:\n' \
1940 ' \t\f pass'
1941
1942 cdef = ast.parse(s).body[0]
1943 self.assertEqual(ast.get_source_segment(s, cdef.body[0], padded=True), s_method)
1944
Irit Katriele6578a22020-05-18 19:14:12 +01001945 def test_source_segment_missing_info(self):
1946 s = 'v = 1\r\nw = 1\nx = 1\n\ry = 1\r\n'
1947 v, w, x, y = ast.parse(s).body
1948 del v.lineno
1949 del w.end_lineno
1950 del x.col_offset
1951 del y.end_col_offset
1952 self.assertIsNone(ast.get_source_segment(s, v))
1953 self.assertIsNone(ast.get_source_segment(s, w))
1954 self.assertIsNone(ast.get_source_segment(s, x))
1955 self.assertIsNone(ast.get_source_segment(s, y))
Ivan Levkivskyi9932a222019-01-22 11:18:22 +00001956
Serhiy Storchakac3ea41e2019-08-26 10:13:19 +03001957class NodeVisitorTests(unittest.TestCase):
1958 def test_old_constant_nodes(self):
1959 class Visitor(ast.NodeVisitor):
1960 def visit_Num(self, node):
1961 log.append((node.lineno, 'Num', node.n))
1962 def visit_Str(self, node):
1963 log.append((node.lineno, 'Str', node.s))
1964 def visit_Bytes(self, node):
1965 log.append((node.lineno, 'Bytes', node.s))
1966 def visit_NameConstant(self, node):
1967 log.append((node.lineno, 'NameConstant', node.value))
1968 def visit_Ellipsis(self, node):
1969 log.append((node.lineno, 'Ellipsis', ...))
1970 mod = ast.parse(dedent('''\
1971 i = 42
1972 f = 4.25
1973 c = 4.25j
1974 s = 'string'
1975 b = b'bytes'
1976 t = True
1977 n = None
1978 e = ...
1979 '''))
1980 visitor = Visitor()
1981 log = []
1982 with warnings.catch_warnings(record=True) as wlog:
1983 warnings.filterwarnings('always', '', DeprecationWarning)
1984 visitor.visit(mod)
1985 self.assertEqual(log, [
1986 (1, 'Num', 42),
1987 (2, 'Num', 4.25),
1988 (3, 'Num', 4.25j),
1989 (4, 'Str', 'string'),
1990 (5, 'Bytes', b'bytes'),
1991 (6, 'NameConstant', True),
1992 (7, 'NameConstant', None),
1993 (8, 'Ellipsis', ...),
1994 ])
1995 self.assertEqual([str(w.message) for w in wlog], [
1996 'visit_Num is deprecated; add visit_Constant',
1997 'visit_Num is deprecated; add visit_Constant',
1998 'visit_Num is deprecated; add visit_Constant',
1999 'visit_Str is deprecated; add visit_Constant',
2000 'visit_Bytes is deprecated; add visit_Constant',
2001 'visit_NameConstant is deprecated; add visit_Constant',
2002 'visit_NameConstant is deprecated; add visit_Constant',
2003 'visit_Ellipsis is deprecated; add visit_Constant',
2004 ])
2005
2006
Victor Stinnere5fbe0c2020-09-15 18:03:34 +02002007@support.cpython_only
2008class ModuleStateTests(unittest.TestCase):
2009 # bpo-41194, bpo-41261, bpo-41631: The _ast module uses a global state.
2010
2011 def check_ast_module(self):
2012 # Check that the _ast module still works as expected
2013 code = 'x + 1'
2014 filename = '<string>'
2015 mode = 'eval'
2016
2017 # Create _ast.AST subclasses instances
2018 ast_tree = compile(code, filename, mode, flags=ast.PyCF_ONLY_AST)
2019
2020 # Call PyAST_Check()
2021 code = compile(ast_tree, filename, mode)
2022 self.assertIsInstance(code, types.CodeType)
2023
2024 def test_reload_module(self):
2025 # bpo-41194: Importing the _ast module twice must not crash.
2026 with support.swap_item(sys.modules, '_ast', None):
2027 del sys.modules['_ast']
2028 import _ast as ast1
2029
2030 del sys.modules['_ast']
2031 import _ast as ast2
2032
2033 self.check_ast_module()
2034
2035 # Unloading the two _ast module instances must not crash.
2036 del ast1
2037 del ast2
2038 support.gc_collect()
2039
2040 self.check_ast_module()
2041
2042 def test_sys_modules(self):
2043 # bpo-41631: Test reproducing a Mercurial crash when PyAST_Check()
2044 # imported the _ast module internally.
2045 lazy_mod = object()
2046
2047 def my_import(name, *args, **kw):
2048 sys.modules[name] = lazy_mod
2049 return lazy_mod
2050
2051 with support.swap_item(sys.modules, '_ast', None):
2052 del sys.modules['_ast']
2053
2054 with support.swap_attr(builtins, '__import__', my_import):
2055 # Test that compile() does not import the _ast module
2056 self.check_ast_module()
2057 self.assertNotIn('_ast', sys.modules)
2058
2059 # Sanity check of the test itself
2060 import _ast
2061 self.assertIs(_ast, lazy_mod)
2062
2063 def test_subinterpreter(self):
2064 # bpo-41631: Importing and using the _ast module in a subinterpreter
2065 # must not crash.
2066 code = dedent('''
2067 import _ast
2068 import ast
2069 import gc
2070 import sys
2071 import types
2072
2073 # Create _ast.AST subclasses instances and call PyAST_Check()
2074 ast_tree = compile('x+1', '<string>', 'eval',
2075 flags=ast.PyCF_ONLY_AST)
2076 code = compile(ast_tree, 'string', 'eval')
2077 if not isinstance(code, types.CodeType):
2078 raise AssertionError
2079
2080 # Unloading the _ast module must not crash.
2081 del ast, _ast
2082 del sys.modules['ast'], sys.modules['_ast']
2083 gc.collect()
2084 ''')
2085 res = support.run_in_subinterp(code)
2086 self.assertEqual(res, 0)
2087
2088
Neal Norwitzee9b10a2008-03-31 05:29:39 +00002089def main():
2090 if __name__ != '__main__':
Martin v. Löwis49c5da12006-03-01 22:49:05 +00002091 return
Neal Norwitzee9b10a2008-03-31 05:29:39 +00002092 if sys.argv[1:] == ['-g']:
2093 for statements, kind in ((exec_tests, "exec"), (single_tests, "single"),
2094 (eval_tests, "eval")):
2095 print(kind+"_results = [")
Victor Stinnerf0891962016-02-08 17:15:21 +01002096 for statement in statements:
2097 tree = ast.parse(statement, "?", kind)
2098 print("%r," % (to_tuple(tree),))
Neal Norwitzee9b10a2008-03-31 05:29:39 +00002099 print("]")
2100 print("main()")
2101 raise SystemExit
Brett Cannon3e9a9ae2013-06-12 21:25:59 -04002102 unittest.main()
Tim Peters400cbc32006-02-28 18:44:41 +00002103
Guido van Rossumdcfcd142019-01-31 03:40:27 -08002104#### EVERYTHING BELOW IS GENERATED BY python Lib/test/test_ast.py -g #####
Tim Peters400cbc32006-02-28 18:44:41 +00002105exec_results = [
Serhiy Storchaka850a8852020-01-10 10:12:55 +02002106('Module', [('Expr', (1, 0, 1, 4), ('Constant', (1, 0, 1, 4), None, None))], []),
2107('Module', [('Expr', (1, 0, 1, 18), ('Constant', (1, 0, 1, 18), 'module docstring', None))], []),
2108('Module', [('FunctionDef', (1, 0, 1, 13), 'f', ('arguments', [], [], None, [], [], None, []), [('Pass', (1, 9, 1, 13))], [], None, None)], []),
2109('Module', [('FunctionDef', (1, 0, 1, 29), 'f', ('arguments', [], [], None, [], [], None, []), [('Expr', (1, 9, 1, 29), ('Constant', (1, 9, 1, 29), 'function docstring', None))], [], None, None)], []),
2110('Module', [('FunctionDef', (1, 0, 1, 14), 'f', ('arguments', [], [('arg', (1, 6, 1, 7), 'a', None, None)], None, [], [], None, []), [('Pass', (1, 10, 1, 14))], [], None, None)], []),
2111('Module', [('FunctionDef', (1, 0, 1, 16), 'f', ('arguments', [], [('arg', (1, 6, 1, 7), 'a', None, None)], None, [], [], None, [('Constant', (1, 8, 1, 9), 0, None)]), [('Pass', (1, 12, 1, 16))], [], None, None)], []),
2112('Module', [('FunctionDef', (1, 0, 1, 18), 'f', ('arguments', [], [], ('arg', (1, 7, 1, 11), 'args', None, None), [], [], None, []), [('Pass', (1, 14, 1, 18))], [], None, None)], []),
2113('Module', [('FunctionDef', (1, 0, 1, 21), 'f', ('arguments', [], [], None, [], [], ('arg', (1, 8, 1, 14), 'kwargs', None, None), []), [('Pass', (1, 17, 1, 21))], [], None, None)], []),
2114('Module', [('FunctionDef', (1, 0, 1, 71), 'f', ('arguments', [], [('arg', (1, 6, 1, 7), 'a', None, None), ('arg', (1, 9, 1, 10), 'b', None, None), ('arg', (1, 14, 1, 15), 'c', None, None), ('arg', (1, 22, 1, 23), 'd', None, None), ('arg', (1, 28, 1, 29), 'e', None, None)], ('arg', (1, 35, 1, 39), 'args', None, None), [('arg', (1, 41, 1, 42), 'f', None, None)], [('Constant', (1, 43, 1, 45), 42, None)], ('arg', (1, 49, 1, 55), 'kwargs', None, None), [('Constant', (1, 11, 1, 12), 1, None), ('Constant', (1, 16, 1, 20), None, None), ('List', (1, 24, 1, 26), [], ('Load',)), ('Dict', (1, 30, 1, 32), [], [])]), [('Expr', (1, 58, 1, 71), ('Constant', (1, 58, 1, 71), 'doc for f()', None))], [], None, None)], []),
2115('Module', [('ClassDef', (1, 0, 1, 12), 'C', [], [], [('Pass', (1, 8, 1, 12))], [])], []),
2116('Module', [('ClassDef', (1, 0, 1, 32), 'C', [], [], [('Expr', (1, 9, 1, 32), ('Constant', (1, 9, 1, 32), 'docstring for class C', None))], [])], []),
2117('Module', [('ClassDef', (1, 0, 1, 21), 'C', [('Name', (1, 8, 1, 14), 'object', ('Load',))], [], [('Pass', (1, 17, 1, 21))], [])], []),
2118('Module', [('FunctionDef', (1, 0, 1, 16), 'f', ('arguments', [], [], None, [], [], None, []), [('Return', (1, 8, 1, 16), ('Constant', (1, 15, 1, 16), 1, None))], [], None, None)], []),
2119('Module', [('Delete', (1, 0, 1, 5), [('Name', (1, 4, 1, 5), 'v', ('Del',))])], []),
2120('Module', [('Assign', (1, 0, 1, 5), [('Name', (1, 0, 1, 1), 'v', ('Store',))], ('Constant', (1, 4, 1, 5), 1, None), None)], []),
2121('Module', [('Assign', (1, 0, 1, 7), [('Tuple', (1, 0, 1, 3), [('Name', (1, 0, 1, 1), 'a', ('Store',)), ('Name', (1, 2, 1, 3), 'b', ('Store',))], ('Store',))], ('Name', (1, 6, 1, 7), 'c', ('Load',)), None)], []),
2122('Module', [('Assign', (1, 0, 1, 9), [('Tuple', (1, 0, 1, 5), [('Name', (1, 1, 1, 2), 'a', ('Store',)), ('Name', (1, 3, 1, 4), 'b', ('Store',))], ('Store',))], ('Name', (1, 8, 1, 9), 'c', ('Load',)), None)], []),
2123('Module', [('Assign', (1, 0, 1, 9), [('List', (1, 0, 1, 5), [('Name', (1, 1, 1, 2), 'a', ('Store',)), ('Name', (1, 3, 1, 4), 'b', ('Store',))], ('Store',))], ('Name', (1, 8, 1, 9), 'c', ('Load',)), None)], []),
2124('Module', [('AugAssign', (1, 0, 1, 6), ('Name', (1, 0, 1, 1), 'v', ('Store',)), ('Add',), ('Constant', (1, 5, 1, 6), 1, None))], []),
2125('Module', [('For', (1, 0, 1, 15), ('Name', (1, 4, 1, 5), 'v', ('Store',)), ('Name', (1, 9, 1, 10), 'v', ('Load',)), [('Pass', (1, 11, 1, 15))], [], None)], []),
2126('Module', [('While', (1, 0, 1, 12), ('Name', (1, 6, 1, 7), 'v', ('Load',)), [('Pass', (1, 8, 1, 12))], [])], []),
2127('Module', [('If', (1, 0, 1, 9), ('Name', (1, 3, 1, 4), 'v', ('Load',)), [('Pass', (1, 5, 1, 9))], [])], []),
2128('Module', [('If', (1, 0, 4, 6), ('Name', (1, 3, 1, 4), 'a', ('Load',)), [('Pass', (2, 2, 2, 6))], [('If', (3, 0, 4, 6), ('Name', (3, 5, 3, 6), 'b', ('Load',)), [('Pass', (4, 2, 4, 6))], [])])], []),
2129('Module', [('If', (1, 0, 6, 6), ('Name', (1, 3, 1, 4), 'a', ('Load',)), [('Pass', (2, 2, 2, 6))], [('If', (3, 0, 6, 6), ('Name', (3, 5, 3, 6), 'b', ('Load',)), [('Pass', (4, 2, 4, 6))], [('Pass', (6, 2, 6, 6))])])], []),
2130('Module', [('With', (1, 0, 1, 17), [('withitem', ('Name', (1, 5, 1, 6), 'x', ('Load',)), ('Name', (1, 10, 1, 11), 'y', ('Store',)))], [('Pass', (1, 13, 1, 17))], None)], []),
2131('Module', [('With', (1, 0, 1, 25), [('withitem', ('Name', (1, 5, 1, 6), 'x', ('Load',)), ('Name', (1, 10, 1, 11), 'y', ('Store',))), ('withitem', ('Name', (1, 13, 1, 14), 'z', ('Load',)), ('Name', (1, 18, 1, 19), 'q', ('Store',)))], [('Pass', (1, 21, 1, 25))], None)], []),
2132('Module', [('Raise', (1, 0, 1, 25), ('Call', (1, 6, 1, 25), ('Name', (1, 6, 1, 15), 'Exception', ('Load',)), [('Constant', (1, 16, 1, 24), 'string', None)], []), None)], []),
2133('Module', [('Try', (1, 0, 4, 6), [('Pass', (2, 2, 2, 6))], [('ExceptHandler', (3, 0, 4, 6), ('Name', (3, 7, 3, 16), 'Exception', ('Load',)), None, [('Pass', (4, 2, 4, 6))])], [], [])], []),
2134('Module', [('Try', (1, 0, 4, 6), [('Pass', (2, 2, 2, 6))], [], [], [('Pass', (4, 2, 4, 6))])], []),
2135('Module', [('Assert', (1, 0, 1, 8), ('Name', (1, 7, 1, 8), 'v', ('Load',)), None)], []),
Matthew Suozzo75a06f02021-04-10 16:56:28 -04002136('Module', [('Import', (1, 0, 1, 10), [('alias', (1, 7, 1, 10), 'sys', None)])], []),
2137('Module', [('ImportFrom', (1, 0, 1, 17), 'sys', [('alias', (1, 16, 1, 17), 'v', None)], 0)], []),
Serhiy Storchaka850a8852020-01-10 10:12:55 +02002138('Module', [('Global', (1, 0, 1, 8), ['v'])], []),
2139('Module', [('Expr', (1, 0, 1, 1), ('Constant', (1, 0, 1, 1), 1, None))], []),
2140('Module', [('Pass', (1, 0, 1, 4))], []),
2141('Module', [('For', (1, 0, 1, 16), ('Name', (1, 4, 1, 5), 'v', ('Store',)), ('Name', (1, 9, 1, 10), 'v', ('Load',)), [('Break', (1, 11, 1, 16))], [], None)], []),
2142('Module', [('For', (1, 0, 1, 19), ('Name', (1, 4, 1, 5), 'v', ('Store',)), ('Name', (1, 9, 1, 10), 'v', ('Load',)), [('Continue', (1, 11, 1, 19))], [], None)], []),
2143('Module', [('For', (1, 0, 1, 18), ('Tuple', (1, 4, 1, 7), [('Name', (1, 4, 1, 5), 'a', ('Store',)), ('Name', (1, 6, 1, 7), 'b', ('Store',))], ('Store',)), ('Name', (1, 11, 1, 12), 'c', ('Load',)), [('Pass', (1, 14, 1, 18))], [], None)], []),
2144('Module', [('For', (1, 0, 1, 20), ('Tuple', (1, 4, 1, 9), [('Name', (1, 5, 1, 6), 'a', ('Store',)), ('Name', (1, 7, 1, 8), 'b', ('Store',))], ('Store',)), ('Name', (1, 13, 1, 14), 'c', ('Load',)), [('Pass', (1, 16, 1, 20))], [], None)], []),
2145('Module', [('For', (1, 0, 1, 20), ('List', (1, 4, 1, 9), [('Name', (1, 5, 1, 6), 'a', ('Store',)), ('Name', (1, 7, 1, 8), 'b', ('Store',))], ('Store',)), ('Name', (1, 13, 1, 14), 'c', ('Load',)), [('Pass', (1, 16, 1, 20))], [], None)], []),
2146('Module', [('Expr', (1, 0, 11, 5), ('GeneratorExp', (1, 0, 11, 5), ('Tuple', (2, 4, 6, 5), [('Name', (3, 4, 3, 6), 'Aa', ('Load',)), ('Name', (5, 7, 5, 9), 'Bb', ('Load',))], ('Load',)), [('comprehension', ('Tuple', (8, 4, 10, 6), [('Name', (8, 4, 8, 6), 'Aa', ('Store',)), ('Name', (10, 4, 10, 6), 'Bb', ('Store',))], ('Store',)), ('Name', (10, 10, 10, 12), 'Cc', ('Load',)), [], 0)]))], []),
2147('Module', [('Expr', (1, 0, 1, 34), ('DictComp', (1, 0, 1, 34), ('Name', (1, 1, 1, 2), 'a', ('Load',)), ('Name', (1, 5, 1, 6), 'b', ('Load',)), [('comprehension', ('Name', (1, 11, 1, 12), 'w', ('Store',)), ('Name', (1, 16, 1, 17), 'x', ('Load',)), [], 0), ('comprehension', ('Name', (1, 22, 1, 23), 'm', ('Store',)), ('Name', (1, 27, 1, 28), 'p', ('Load',)), [('Name', (1, 32, 1, 33), 'g', ('Load',))], 0)]))], []),
2148('Module', [('Expr', (1, 0, 1, 20), ('DictComp', (1, 0, 1, 20), ('Name', (1, 1, 1, 2), 'a', ('Load',)), ('Name', (1, 5, 1, 6), 'b', ('Load',)), [('comprehension', ('Tuple', (1, 11, 1, 14), [('Name', (1, 11, 1, 12), 'v', ('Store',)), ('Name', (1, 13, 1, 14), 'w', ('Store',))], ('Store',)), ('Name', (1, 18, 1, 19), 'x', ('Load',)), [], 0)]))], []),
2149('Module', [('Expr', (1, 0, 1, 19), ('SetComp', (1, 0, 1, 19), ('Name', (1, 1, 1, 2), 'r', ('Load',)), [('comprehension', ('Name', (1, 7, 1, 8), 'l', ('Store',)), ('Name', (1, 12, 1, 13), 'x', ('Load',)), [('Name', (1, 17, 1, 18), 'g', ('Load',))], 0)]))], []),
2150('Module', [('Expr', (1, 0, 1, 16), ('SetComp', (1, 0, 1, 16), ('Name', (1, 1, 1, 2), 'r', ('Load',)), [('comprehension', ('Tuple', (1, 7, 1, 10), [('Name', (1, 7, 1, 8), 'l', ('Store',)), ('Name', (1, 9, 1, 10), 'm', ('Store',))], ('Store',)), ('Name', (1, 14, 1, 15), 'x', ('Load',)), [], 0)]))], []),
2151('Module', [('AsyncFunctionDef', (1, 0, 3, 18), 'f', ('arguments', [], [], None, [], [], None, []), [('Expr', (2, 1, 2, 17), ('Constant', (2, 1, 2, 17), 'async function', None)), ('Expr', (3, 1, 3, 18), ('Await', (3, 1, 3, 18), ('Call', (3, 7, 3, 18), ('Name', (3, 7, 3, 16), 'something', ('Load',)), [], [])))], [], None, None)], []),
2152('Module', [('AsyncFunctionDef', (1, 0, 3, 8), 'f', ('arguments', [], [], None, [], [], None, []), [('AsyncFor', (2, 1, 3, 8), ('Name', (2, 11, 2, 12), 'e', ('Store',)), ('Name', (2, 16, 2, 17), 'i', ('Load',)), [('Expr', (2, 19, 2, 20), ('Constant', (2, 19, 2, 20), 1, None))], [('Expr', (3, 7, 3, 8), ('Constant', (3, 7, 3, 8), 2, None))], None)], [], None, None)], []),
2153('Module', [('AsyncFunctionDef', (1, 0, 2, 21), 'f', ('arguments', [], [], None, [], [], None, []), [('AsyncWith', (2, 1, 2, 21), [('withitem', ('Name', (2, 12, 2, 13), 'a', ('Load',)), ('Name', (2, 17, 2, 18), 'b', ('Store',)))], [('Expr', (2, 20, 2, 21), ('Constant', (2, 20, 2, 21), 1, None))], None)], [], None, None)], []),
2154('Module', [('Expr', (1, 0, 1, 14), ('Dict', (1, 0, 1, 14), [None, ('Constant', (1, 10, 1, 11), 2, None)], [('Dict', (1, 3, 1, 8), [('Constant', (1, 4, 1, 5), 1, None)], [('Constant', (1, 6, 1, 7), 2, None)]), ('Constant', (1, 12, 1, 13), 3, None)]))], []),
2155('Module', [('Expr', (1, 0, 1, 12), ('Set', (1, 0, 1, 12), [('Starred', (1, 1, 1, 8), ('Set', (1, 2, 1, 8), [('Constant', (1, 3, 1, 4), 1, None), ('Constant', (1, 6, 1, 7), 2, None)]), ('Load',)), ('Constant', (1, 10, 1, 11), 3, None)]))], []),
2156('Module', [('AsyncFunctionDef', (1, 0, 2, 21), 'f', ('arguments', [], [], None, [], [], None, []), [('Expr', (2, 1, 2, 21), ('ListComp', (2, 1, 2, 21), ('Name', (2, 2, 2, 3), 'i', ('Load',)), [('comprehension', ('Name', (2, 14, 2, 15), 'b', ('Store',)), ('Name', (2, 19, 2, 20), 'c', ('Load',)), [], 1)]))], [], None, None)], []),
2157('Module', [('FunctionDef', (4, 0, 4, 13), 'f', ('arguments', [], [], None, [], [], None, []), [('Pass', (4, 9, 4, 13))], [('Name', (1, 1, 1, 6), 'deco1', ('Load',)), ('Call', (2, 1, 2, 8), ('Name', (2, 1, 2, 6), 'deco2', ('Load',)), [], []), ('Call', (3, 1, 3, 9), ('Name', (3, 1, 3, 6), 'deco3', ('Load',)), [('Constant', (3, 7, 3, 8), 1, None)], [])], None, None)], []),
2158('Module', [('AsyncFunctionDef', (4, 0, 4, 19), 'f', ('arguments', [], [], None, [], [], None, []), [('Pass', (4, 15, 4, 19))], [('Name', (1, 1, 1, 6), 'deco1', ('Load',)), ('Call', (2, 1, 2, 8), ('Name', (2, 1, 2, 6), 'deco2', ('Load',)), [], []), ('Call', (3, 1, 3, 9), ('Name', (3, 1, 3, 6), 'deco3', ('Load',)), [('Constant', (3, 7, 3, 8), 1, None)], [])], None, None)], []),
2159('Module', [('ClassDef', (4, 0, 4, 13), 'C', [], [], [('Pass', (4, 9, 4, 13))], [('Name', (1, 1, 1, 6), 'deco1', ('Load',)), ('Call', (2, 1, 2, 8), ('Name', (2, 1, 2, 6), 'deco2', ('Load',)), [], []), ('Call', (3, 1, 3, 9), ('Name', (3, 1, 3, 6), 'deco3', ('Load',)), [('Constant', (3, 7, 3, 8), 1, None)], [])])], []),
2160('Module', [('FunctionDef', (2, 0, 2, 13), 'f', ('arguments', [], [], None, [], [], None, []), [('Pass', (2, 9, 2, 13))], [('Call', (1, 1, 1, 19), ('Name', (1, 1, 1, 5), 'deco', ('Load',)), [('GeneratorExp', (1, 5, 1, 19), ('Name', (1, 6, 1, 7), 'a', ('Load',)), [('comprehension', ('Name', (1, 12, 1, 13), 'a', ('Store',)), ('Name', (1, 17, 1, 18), 'b', ('Load',)), [], 0)])], [])], None, None)], []),
Lysandros Nikolaoud2e10982020-02-08 00:36:32 +01002161('Module', [('FunctionDef', (2, 0, 2, 13), 'f', ('arguments', [], [], None, [], [], None, []), [('Pass', (2, 9, 2, 13))], [('Attribute', (1, 1, 1, 6), ('Attribute', (1, 1, 1, 4), ('Name', (1, 1, 1, 2), 'a', ('Load',)), 'b', ('Load',)), 'c', ('Load',))], None, None)], []),
Serhiy Storchaka850a8852020-01-10 10:12:55 +02002162('Module', [('Expr', (1, 0, 1, 8), ('NamedExpr', (1, 1, 1, 7), ('Name', (1, 1, 1, 2), 'a', ('Store',)), ('Constant', (1, 6, 1, 7), 1, None)))], []),
2163('Module', [('FunctionDef', (1, 0, 1, 18), 'f', ('arguments', [('arg', (1, 6, 1, 7), 'a', None, None)], [], None, [], [], None, []), [('Pass', (1, 14, 1, 18))], [], None, None)], []),
2164('Module', [('FunctionDef', (1, 0, 1, 26), 'f', ('arguments', [('arg', (1, 6, 1, 7), 'a', None, None)], [('arg', (1, 12, 1, 13), 'c', None, None), ('arg', (1, 15, 1, 16), 'd', None, None), ('arg', (1, 18, 1, 19), 'e', None, None)], None, [], [], None, []), [('Pass', (1, 22, 1, 26))], [], None, None)], []),
2165('Module', [('FunctionDef', (1, 0, 1, 29), 'f', ('arguments', [('arg', (1, 6, 1, 7), 'a', None, None)], [('arg', (1, 12, 1, 13), 'c', None, None)], None, [('arg', (1, 18, 1, 19), 'd', None, None), ('arg', (1, 21, 1, 22), 'e', None, None)], [None, None], None, []), [('Pass', (1, 25, 1, 29))], [], None, None)], []),
2166('Module', [('FunctionDef', (1, 0, 1, 39), 'f', ('arguments', [('arg', (1, 6, 1, 7), 'a', None, None)], [('arg', (1, 12, 1, 13), 'c', None, None)], None, [('arg', (1, 18, 1, 19), 'd', None, None), ('arg', (1, 21, 1, 22), 'e', None, None)], [None, None], ('arg', (1, 26, 1, 32), 'kwargs', None, None), []), [('Pass', (1, 35, 1, 39))], [], None, None)], []),
2167('Module', [('FunctionDef', (1, 0, 1, 20), 'f', ('arguments', [('arg', (1, 6, 1, 7), 'a', None, None)], [], None, [], [], None, [('Constant', (1, 8, 1, 9), 1, None)]), [('Pass', (1, 16, 1, 20))], [], None, None)], []),
2168('Module', [('FunctionDef', (1, 0, 1, 29), 'f', ('arguments', [('arg', (1, 6, 1, 7), 'a', None, None)], [('arg', (1, 14, 1, 15), 'b', None, None), ('arg', (1, 19, 1, 20), 'c', None, None)], None, [], [], None, [('Constant', (1, 8, 1, 9), 1, None), ('Constant', (1, 16, 1, 17), 2, None), ('Constant', (1, 21, 1, 22), 4, None)]), [('Pass', (1, 25, 1, 29))], [], None, None)], []),
2169('Module', [('FunctionDef', (1, 0, 1, 32), 'f', ('arguments', [('arg', (1, 6, 1, 7), 'a', None, None)], [('arg', (1, 14, 1, 15), 'b', None, None)], None, [('arg', (1, 22, 1, 23), 'c', None, None)], [('Constant', (1, 24, 1, 25), 4, None)], None, [('Constant', (1, 8, 1, 9), 1, None), ('Constant', (1, 16, 1, 17), 2, None)]), [('Pass', (1, 28, 1, 32))], [], None, None)], []),
2170('Module', [('FunctionDef', (1, 0, 1, 30), 'f', ('arguments', [('arg', (1, 6, 1, 7), 'a', None, None)], [('arg', (1, 14, 1, 15), 'b', None, None)], None, [('arg', (1, 22, 1, 23), 'c', None, None)], [None], None, [('Constant', (1, 8, 1, 9), 1, None), ('Constant', (1, 16, 1, 17), 2, None)]), [('Pass', (1, 26, 1, 30))], [], None, None)], []),
2171('Module', [('FunctionDef', (1, 0, 1, 42), 'f', ('arguments', [('arg', (1, 6, 1, 7), 'a', None, None)], [('arg', (1, 14, 1, 15), 'b', None, None)], None, [('arg', (1, 22, 1, 23), 'c', None, None)], [('Constant', (1, 24, 1, 25), 4, None)], ('arg', (1, 29, 1, 35), 'kwargs', None, None), [('Constant', (1, 8, 1, 9), 1, None), ('Constant', (1, 16, 1, 17), 2, None)]), [('Pass', (1, 38, 1, 42))], [], None, None)], []),
2172('Module', [('FunctionDef', (1, 0, 1, 40), 'f', ('arguments', [('arg', (1, 6, 1, 7), 'a', None, None)], [('arg', (1, 14, 1, 15), 'b', None, None)], None, [('arg', (1, 22, 1, 23), 'c', None, None)], [None], ('arg', (1, 27, 1, 33), 'kwargs', None, None), [('Constant', (1, 8, 1, 9), 1, None), ('Constant', (1, 16, 1, 17), 2, None)]), [('Pass', (1, 36, 1, 40))], [], None, None)], []),
Tim Peters400cbc32006-02-28 18:44:41 +00002173]
2174single_results = [
Serhiy Storchaka850a8852020-01-10 10:12:55 +02002175('Interactive', [('Expr', (1, 0, 1, 3), ('BinOp', (1, 0, 1, 3), ('Constant', (1, 0, 1, 1), 1, None), ('Add',), ('Constant', (1, 2, 1, 3), 2, None)))]),
Tim Peters400cbc32006-02-28 18:44:41 +00002176]
2177eval_results = [
Serhiy Storchaka850a8852020-01-10 10:12:55 +02002178('Expression', ('Constant', (1, 0, 1, 4), None, None)),
2179('Expression', ('BoolOp', (1, 0, 1, 7), ('And',), [('Name', (1, 0, 1, 1), 'a', ('Load',)), ('Name', (1, 6, 1, 7), 'b', ('Load',))])),
2180('Expression', ('BinOp', (1, 0, 1, 5), ('Name', (1, 0, 1, 1), 'a', ('Load',)), ('Add',), ('Name', (1, 4, 1, 5), 'b', ('Load',)))),
2181('Expression', ('UnaryOp', (1, 0, 1, 5), ('Not',), ('Name', (1, 4, 1, 5), 'v', ('Load',)))),
2182('Expression', ('Lambda', (1, 0, 1, 11), ('arguments', [], [], None, [], [], None, []), ('Constant', (1, 7, 1, 11), None, None))),
2183('Expression', ('Dict', (1, 0, 1, 7), [('Constant', (1, 2, 1, 3), 1, None)], [('Constant', (1, 4, 1, 5), 2, None)])),
2184('Expression', ('Dict', (1, 0, 1, 2), [], [])),
2185('Expression', ('Set', (1, 0, 1, 7), [('Constant', (1, 1, 1, 5), None, None)])),
2186('Expression', ('Dict', (1, 0, 5, 6), [('Constant', (2, 6, 2, 7), 1, None)], [('Constant', (4, 10, 4, 11), 2, None)])),
2187('Expression', ('ListComp', (1, 0, 1, 19), ('Name', (1, 1, 1, 2), 'a', ('Load',)), [('comprehension', ('Name', (1, 7, 1, 8), 'b', ('Store',)), ('Name', (1, 12, 1, 13), 'c', ('Load',)), [('Name', (1, 17, 1, 18), 'd', ('Load',))], 0)])),
2188('Expression', ('GeneratorExp', (1, 0, 1, 19), ('Name', (1, 1, 1, 2), 'a', ('Load',)), [('comprehension', ('Name', (1, 7, 1, 8), 'b', ('Store',)), ('Name', (1, 12, 1, 13), 'c', ('Load',)), [('Name', (1, 17, 1, 18), 'd', ('Load',))], 0)])),
2189('Expression', ('ListComp', (1, 0, 1, 20), ('Tuple', (1, 1, 1, 6), [('Name', (1, 2, 1, 3), 'a', ('Load',)), ('Name', (1, 4, 1, 5), 'b', ('Load',))], ('Load',)), [('comprehension', ('Tuple', (1, 11, 1, 14), [('Name', (1, 11, 1, 12), 'a', ('Store',)), ('Name', (1, 13, 1, 14), 'b', ('Store',))], ('Store',)), ('Name', (1, 18, 1, 19), 'c', ('Load',)), [], 0)])),
2190('Expression', ('ListComp', (1, 0, 1, 22), ('Tuple', (1, 1, 1, 6), [('Name', (1, 2, 1, 3), 'a', ('Load',)), ('Name', (1, 4, 1, 5), 'b', ('Load',))], ('Load',)), [('comprehension', ('Tuple', (1, 11, 1, 16), [('Name', (1, 12, 1, 13), 'a', ('Store',)), ('Name', (1, 14, 1, 15), 'b', ('Store',))], ('Store',)), ('Name', (1, 20, 1, 21), 'c', ('Load',)), [], 0)])),
2191('Expression', ('ListComp', (1, 0, 1, 22), ('Tuple', (1, 1, 1, 6), [('Name', (1, 2, 1, 3), 'a', ('Load',)), ('Name', (1, 4, 1, 5), 'b', ('Load',))], ('Load',)), [('comprehension', ('List', (1, 11, 1, 16), [('Name', (1, 12, 1, 13), 'a', ('Store',)), ('Name', (1, 14, 1, 15), 'b', ('Store',))], ('Store',)), ('Name', (1, 20, 1, 21), 'c', ('Load',)), [], 0)])),
2192('Expression', ('SetComp', (1, 0, 1, 20), ('Tuple', (1, 1, 1, 6), [('Name', (1, 2, 1, 3), 'a', ('Load',)), ('Name', (1, 4, 1, 5), 'b', ('Load',))], ('Load',)), [('comprehension', ('Tuple', (1, 11, 1, 14), [('Name', (1, 11, 1, 12), 'a', ('Store',)), ('Name', (1, 13, 1, 14), 'b', ('Store',))], ('Store',)), ('Name', (1, 18, 1, 19), 'c', ('Load',)), [], 0)])),
2193('Expression', ('SetComp', (1, 0, 1, 22), ('Tuple', (1, 1, 1, 6), [('Name', (1, 2, 1, 3), 'a', ('Load',)), ('Name', (1, 4, 1, 5), 'b', ('Load',))], ('Load',)), [('comprehension', ('Tuple', (1, 11, 1, 16), [('Name', (1, 12, 1, 13), 'a', ('Store',)), ('Name', (1, 14, 1, 15), 'b', ('Store',))], ('Store',)), ('Name', (1, 20, 1, 21), 'c', ('Load',)), [], 0)])),
2194('Expression', ('SetComp', (1, 0, 1, 22), ('Tuple', (1, 1, 1, 6), [('Name', (1, 2, 1, 3), 'a', ('Load',)), ('Name', (1, 4, 1, 5), 'b', ('Load',))], ('Load',)), [('comprehension', ('List', (1, 11, 1, 16), [('Name', (1, 12, 1, 13), 'a', ('Store',)), ('Name', (1, 14, 1, 15), 'b', ('Store',))], ('Store',)), ('Name', (1, 20, 1, 21), 'c', ('Load',)), [], 0)])),
2195('Expression', ('GeneratorExp', (1, 0, 1, 20), ('Tuple', (1, 1, 1, 6), [('Name', (1, 2, 1, 3), 'a', ('Load',)), ('Name', (1, 4, 1, 5), 'b', ('Load',))], ('Load',)), [('comprehension', ('Tuple', (1, 11, 1, 14), [('Name', (1, 11, 1, 12), 'a', ('Store',)), ('Name', (1, 13, 1, 14), 'b', ('Store',))], ('Store',)), ('Name', (1, 18, 1, 19), 'c', ('Load',)), [], 0)])),
2196('Expression', ('GeneratorExp', (1, 0, 1, 22), ('Tuple', (1, 1, 1, 6), [('Name', (1, 2, 1, 3), 'a', ('Load',)), ('Name', (1, 4, 1, 5), 'b', ('Load',))], ('Load',)), [('comprehension', ('Tuple', (1, 11, 1, 16), [('Name', (1, 12, 1, 13), 'a', ('Store',)), ('Name', (1, 14, 1, 15), 'b', ('Store',))], ('Store',)), ('Name', (1, 20, 1, 21), 'c', ('Load',)), [], 0)])),
2197('Expression', ('GeneratorExp', (1, 0, 1, 22), ('Tuple', (1, 1, 1, 6), [('Name', (1, 2, 1, 3), 'a', ('Load',)), ('Name', (1, 4, 1, 5), 'b', ('Load',))], ('Load',)), [('comprehension', ('List', (1, 11, 1, 16), [('Name', (1, 12, 1, 13), 'a', ('Store',)), ('Name', (1, 14, 1, 15), 'b', ('Store',))], ('Store',)), ('Name', (1, 20, 1, 21), 'c', ('Load',)), [], 0)])),
2198('Expression', ('Compare', (1, 0, 1, 9), ('Constant', (1, 0, 1, 1), 1, None), [('Lt',), ('Lt',)], [('Constant', (1, 4, 1, 5), 2, None), ('Constant', (1, 8, 1, 9), 3, None)])),
Pablo Galindo40cf35c2020-04-03 21:02:26 +01002199('Expression', ('Call', (1, 0, 1, 17), ('Name', (1, 0, 1, 1), 'f', ('Load',)), [('Constant', (1, 2, 1, 3), 1, None), ('Constant', (1, 4, 1, 5), 2, None), ('Starred', (1, 10, 1, 12), ('Name', (1, 11, 1, 12), 'd', ('Load',)), ('Load',))], [('keyword', (1, 6, 1, 9), 'c', ('Constant', (1, 8, 1, 9), 3, None)), ('keyword', (1, 13, 1, 16), None, ('Name', (1, 15, 1, 16), 'e', ('Load',)))])),
Serhiy Storchaka850a8852020-01-10 10:12:55 +02002200('Expression', ('Call', (1, 0, 1, 10), ('Name', (1, 0, 1, 1), 'f', ('Load',)), [('Starred', (1, 2, 1, 9), ('List', (1, 3, 1, 9), [('Constant', (1, 4, 1, 5), 0, None), ('Constant', (1, 7, 1, 8), 1, None)], ('Load',)), ('Load',))], [])),
2201('Expression', ('Call', (1, 0, 1, 15), ('Name', (1, 0, 1, 1), 'f', ('Load',)), [('GeneratorExp', (1, 1, 1, 15), ('Name', (1, 2, 1, 3), 'a', ('Load',)), [('comprehension', ('Name', (1, 8, 1, 9), 'a', ('Store',)), ('Name', (1, 13, 1, 14), 'b', ('Load',)), [], 0)])], [])),
2202('Expression', ('Constant', (1, 0, 1, 2), 10, None)),
2203('Expression', ('Constant', (1, 0, 1, 8), 'string', None)),
2204('Expression', ('Attribute', (1, 0, 1, 3), ('Name', (1, 0, 1, 1), 'a', ('Load',)), 'b', ('Load',))),
Serhiy Storchaka13d52c22020-03-10 18:52:34 +02002205('Expression', ('Subscript', (1, 0, 1, 6), ('Name', (1, 0, 1, 1), 'a', ('Load',)), ('Slice', (1, 2, 1, 5), ('Name', (1, 2, 1, 3), 'b', ('Load',)), ('Name', (1, 4, 1, 5), 'c', ('Load',)), None), ('Load',))),
Serhiy Storchaka850a8852020-01-10 10:12:55 +02002206('Expression', ('Name', (1, 0, 1, 1), 'v', ('Load',))),
2207('Expression', ('List', (1, 0, 1, 7), [('Constant', (1, 1, 1, 2), 1, None), ('Constant', (1, 3, 1, 4), 2, None), ('Constant', (1, 5, 1, 6), 3, None)], ('Load',))),
2208('Expression', ('List', (1, 0, 1, 2), [], ('Load',))),
2209('Expression', ('Tuple', (1, 0, 1, 5), [('Constant', (1, 0, 1, 1), 1, None), ('Constant', (1, 2, 1, 3), 2, None), ('Constant', (1, 4, 1, 5), 3, None)], ('Load',))),
2210('Expression', ('Tuple', (1, 0, 1, 7), [('Constant', (1, 1, 1, 2), 1, None), ('Constant', (1, 3, 1, 4), 2, None), ('Constant', (1, 5, 1, 6), 3, None)], ('Load',))),
2211('Expression', ('Tuple', (1, 0, 1, 2), [], ('Load',))),
Serhiy Storchaka13d52c22020-03-10 18:52:34 +02002212('Expression', ('Call', (1, 0, 1, 17), ('Attribute', (1, 0, 1, 7), ('Attribute', (1, 0, 1, 5), ('Attribute', (1, 0, 1, 3), ('Name', (1, 0, 1, 1), 'a', ('Load',)), 'b', ('Load',)), 'c', ('Load',)), 'd', ('Load',)), [('Subscript', (1, 8, 1, 16), ('Attribute', (1, 8, 1, 11), ('Name', (1, 8, 1, 9), 'a', ('Load',)), 'b', ('Load',)), ('Slice', (1, 12, 1, 15), ('Constant', (1, 12, 1, 13), 1, None), ('Constant', (1, 14, 1, 15), 2, None), None), ('Load',))], [])),
Tim Peters400cbc32006-02-28 18:44:41 +00002213]
Neal Norwitzee9b10a2008-03-31 05:29:39 +00002214main()