blob: ef56b889f5ac7ff010a1ee5cf7a0834323e239e5 [file] [log] [blame]
Thomas Wouters89f507f2006-12-13 04:49:30 +00001import unittest
Benjamin Petersonee8712c2008-05-20 21:35:26 +00002from test.support import check_syntax_error, run_unittest
Jeremy Hylton4588c782001-01-25 20:11:23 +00003
Jeremy Hyltoncd738362001-08-07 16:38:19 +00004import warnings
Thomas Wouters89f507f2006-12-13 04:49:30 +00005warnings.filterwarnings("ignore", r"import \*", SyntaxWarning, "<test string>")
Guido van Rossum796e1e02001-12-15 18:04:10 +00006warnings.filterwarnings("ignore", r"import \*", SyntaxWarning, "<string>")
Jeremy Hyltoncd738362001-08-07 16:38:19 +00007
Thomas Wouters89f507f2006-12-13 04:49:30 +00008class ScopeTests(unittest.TestCase):
Jeremy Hylton4588c782001-01-25 20:11:23 +00009
Thomas Wouters89f507f2006-12-13 04:49:30 +000010 def testSimpleNesting(self):
Jeremy Hylton4588c782001-01-25 20:11:23 +000011
Thomas Wouters89f507f2006-12-13 04:49:30 +000012 def make_adder(x):
Jeremy Hylton4588c782001-01-25 20:11:23 +000013 def adder(y):
Thomas Wouters89f507f2006-12-13 04:49:30 +000014 return x + y
Jeremy Hylton4588c782001-01-25 20:11:23 +000015 return adder
Jeremy Hylton4588c782001-01-25 20:11:23 +000016
Thomas Wouters89f507f2006-12-13 04:49:30 +000017 inc = make_adder(1)
18 plus10 = make_adder(10)
Jeremy Hylton4588c782001-01-25 20:11:23 +000019
Thomas Wouters89f507f2006-12-13 04:49:30 +000020 self.assertEqual(inc(1), 2)
21 self.assertEqual(plus10(-2), 8)
Jeremy Hylton4588c782001-01-25 20:11:23 +000022
Thomas Wouters89f507f2006-12-13 04:49:30 +000023 def testExtraNesting(self):
Jeremy Hylton4588c782001-01-25 20:11:23 +000024
Thomas Wouters89f507f2006-12-13 04:49:30 +000025 def make_adder2(x):
26 def extra(): # check freevars passing through non-use scopes
27 def adder(y):
28 return x + y
29 return adder
30 return extra()
Jeremy Hylton4588c782001-01-25 20:11:23 +000031
Thomas Wouters89f507f2006-12-13 04:49:30 +000032 inc = make_adder2(1)
33 plus10 = make_adder2(10)
Jeremy Hylton4588c782001-01-25 20:11:23 +000034
Thomas Wouters89f507f2006-12-13 04:49:30 +000035 self.assertEqual(inc(1), 2)
36 self.assertEqual(plus10(-2), 8)
Jeremy Hylton4588c782001-01-25 20:11:23 +000037
Thomas Wouters89f507f2006-12-13 04:49:30 +000038 def testSimpleAndRebinding(self):
Jeremy Hylton4588c782001-01-25 20:11:23 +000039
Thomas Wouters89f507f2006-12-13 04:49:30 +000040 def make_adder3(x):
41 def adder(y):
42 return x + y
43 x = x + 1 # check tracking of assignment to x in defining scope
44 return adder
Jeremy Hylton4588c782001-01-25 20:11:23 +000045
Thomas Wouters89f507f2006-12-13 04:49:30 +000046 inc = make_adder3(0)
47 plus10 = make_adder3(9)
Jeremy Hylton4588c782001-01-25 20:11:23 +000048
Thomas Wouters89f507f2006-12-13 04:49:30 +000049 self.assertEqual(inc(1), 2)
50 self.assertEqual(plus10(-2), 8)
Jeremy Hylton4588c782001-01-25 20:11:23 +000051
Thomas Wouters89f507f2006-12-13 04:49:30 +000052 def testNestingGlobalNoFree(self):
Jeremy Hylton4588c782001-01-25 20:11:23 +000053
Thomas Wouters89f507f2006-12-13 04:49:30 +000054 def make_adder4(): # XXX add exta level of indirection
55 def nest():
56 def nest():
57 def adder(y):
58 return global_x + y # check that plain old globals work
59 return adder
60 return nest()
61 return nest()
Jeremy Hylton4588c782001-01-25 20:11:23 +000062
Thomas Wouters89f507f2006-12-13 04:49:30 +000063 global_x = 1
64 adder = make_adder4()
65 self.assertEqual(adder(1), 2)
Jeremy Hylton4588c782001-01-25 20:11:23 +000066
Thomas Wouters89f507f2006-12-13 04:49:30 +000067 global_x = 10
68 self.assertEqual(adder(-2), 8)
Jeremy Hylton4588c782001-01-25 20:11:23 +000069
Thomas Wouters89f507f2006-12-13 04:49:30 +000070 def testNestingThroughClass(self):
Jeremy Hylton4588c782001-01-25 20:11:23 +000071
Thomas Wouters89f507f2006-12-13 04:49:30 +000072 def make_adder5(x):
73 class Adder:
74 def __call__(self, y):
75 return x + y
76 return Adder()
Jeremy Hylton4588c782001-01-25 20:11:23 +000077
Thomas Wouters89f507f2006-12-13 04:49:30 +000078 inc = make_adder5(1)
79 plus10 = make_adder5(10)
Jeremy Hylton4588c782001-01-25 20:11:23 +000080
Thomas Wouters89f507f2006-12-13 04:49:30 +000081 self.assertEqual(inc(1), 2)
82 self.assertEqual(plus10(-2), 8)
Jeremy Hylton4588c782001-01-25 20:11:23 +000083
Thomas Wouters89f507f2006-12-13 04:49:30 +000084 def testNestingPlusFreeRefToGlobal(self):
Jeremy Hylton4588c782001-01-25 20:11:23 +000085
Thomas Wouters89f507f2006-12-13 04:49:30 +000086 def make_adder6(x):
87 global global_nest_x
88 def adder(y):
89 return global_nest_x + y
90 global_nest_x = x
91 return adder
Jeremy Hylton4588c782001-01-25 20:11:23 +000092
Thomas Wouters89f507f2006-12-13 04:49:30 +000093 inc = make_adder6(1)
94 plus10 = make_adder6(10)
Jeremy Hylton4588c782001-01-25 20:11:23 +000095
Thomas Wouters89f507f2006-12-13 04:49:30 +000096 self.assertEqual(inc(1), 11) # there's only one global
97 self.assertEqual(plus10(-2), 8)
Jeremy Hylton4588c782001-01-25 20:11:23 +000098
Thomas Wouters89f507f2006-12-13 04:49:30 +000099 def testNearestEnclosingScope(self):
Jeremy Hylton4588c782001-01-25 20:11:23 +0000100
Thomas Wouters89f507f2006-12-13 04:49:30 +0000101 def f(x):
102 def g(y):
103 x = 42 # check that this masks binding in f()
104 def h(z):
105 return x + z
106 return h
107 return g(2)
Jeremy Hylton4588c782001-01-25 20:11:23 +0000108
Thomas Wouters89f507f2006-12-13 04:49:30 +0000109 test_func = f(10)
110 self.assertEqual(test_func(5), 47)
111
112 def testMixedFreevarsAndCellvars(self):
113
114 def identity(x):
115 return x
116
117 def f(x, y, z):
118 def g(a, b, c):
119 a = a + x # 3
120 def h():
121 # z * (4 + 9)
122 # 3 * 13
123 return identity(z * (b + y))
124 y = c + z # 9
125 return h
126 return g
127
128 g = f(1, 2, 3)
129 h = g(2, 4, 6)
130 self.assertEqual(h(), 39)
131
132 def testFreeVarInMethod(self):
133
134 def test():
135 method_and_var = "var"
136 class Test:
137 def method_and_var(self):
138 return "method"
139 def test(self):
140 return method_and_var
141 def actual_global(self):
142 return str("global")
143 def str(self):
144 return str(self)
145 return Test()
146
147 t = test()
148 self.assertEqual(t.test(), "var")
149 self.assertEqual(t.method_and_var(), "method")
150 self.assertEqual(t.actual_global(), "global")
151
152 method_and_var = "var"
153 class Test:
154 # this class is not nested, so the rules are different
155 def method_and_var(self):
156 return "method"
157 def test(self):
158 return method_and_var
159 def actual_global(self):
160 return str("global")
161 def str(self):
162 return str(self)
163
164 t = Test()
165 self.assertEqual(t.test(), "var")
166 self.assertEqual(t.method_and_var(), "method")
167 self.assertEqual(t.actual_global(), "global")
168
Amaury Forgeot d'Arce670bd42007-11-24 00:29:24 +0000169 def testCellIsKwonlyArg(self):
170 # Issue 1409: Initialisation of a cell value,
171 # when it comes from a keyword-only parameter
172 def foo(*, a=17):
173 def bar():
174 return a + 5
175 return bar() + 3
176
177 self.assertEqual(foo(a=42), 50)
178 self.assertEqual(foo(), 25)
179
Thomas Wouters89f507f2006-12-13 04:49:30 +0000180 def testRecursion(self):
181
182 def f(x):
183 def fact(n):
184 if n == 0:
185 return 1
186 else:
187 return n * fact(n - 1)
188 if x >= 0:
189 return fact(x)
190 else:
Collin Winter3add4d72007-08-29 23:37:32 +0000191 raise ValueError("x must be >= 0")
Thomas Wouters89f507f2006-12-13 04:49:30 +0000192
193 self.assertEqual(f(6), 720)
Jeremy Hylton4588c782001-01-25 20:11:23 +0000194
195
Thomas Wouters89f507f2006-12-13 04:49:30 +0000196 def testUnoptimizedNamespaces(self):
Jeremy Hylton4588c782001-01-25 20:11:23 +0000197
Thomas Wouters89f507f2006-12-13 04:49:30 +0000198 check_syntax_error(self, """\
Jeremy Hylton5941d192001-02-27 20:23:58 +0000199def unoptimized_clash1(strip):
Jeremy Hylton4588c782001-01-25 20:11:23 +0000200 def f(s):
Neal Norwitz9d72bb42007-04-17 08:48:32 +0000201 from sys import *
202 return getrefcount(s) # ambiguity: free or local
Jeremy Hylton4588c782001-01-25 20:11:23 +0000203 return f
Jeremy Hylton97a01672001-02-09 22:56:46 +0000204""")
Jeremy Hylton4588c782001-01-25 20:11:23 +0000205
Thomas Wouters89f507f2006-12-13 04:49:30 +0000206 check_syntax_error(self, """\
Jeremy Hylton5941d192001-02-27 20:23:58 +0000207def unoptimized_clash2():
Neal Norwitz9d72bb42007-04-17 08:48:32 +0000208 from sys import *
Jeremy Hylton4588c782001-01-25 20:11:23 +0000209 def f(s):
Neal Norwitz9d72bb42007-04-17 08:48:32 +0000210 return getrefcount(s) # ambiguity: global or local
Jeremy Hylton4588c782001-01-25 20:11:23 +0000211 return f
Jeremy Hylton97a01672001-02-09 22:56:46 +0000212""")
Jeremy Hylton4588c782001-01-25 20:11:23 +0000213
Thomas Wouters89f507f2006-12-13 04:49:30 +0000214 check_syntax_error(self, """\
Jeremy Hylton5941d192001-02-27 20:23:58 +0000215def unoptimized_clash2():
Neal Norwitz9d72bb42007-04-17 08:48:32 +0000216 from sys import *
Jeremy Hylton97a01672001-02-09 22:56:46 +0000217 def g():
218 def f(s):
Neal Norwitz9d72bb42007-04-17 08:48:32 +0000219 return getrefcount(s) # ambiguity: global or local
Jeremy Hylton97a01672001-02-09 22:56:46 +0000220 return f
221""")
222
Thomas Wouters89f507f2006-12-13 04:49:30 +0000223 check_syntax_error(self, """\
Jeremy Hylton5941d192001-02-27 20:23:58 +0000224def f(x):
Jeremy Hylton4588c782001-01-25 20:11:23 +0000225 def g():
226 return x
Jeremy Hylton97a01672001-02-09 22:56:46 +0000227 del x # can't del name
228""")
229
Thomas Wouters89f507f2006-12-13 04:49:30 +0000230 check_syntax_error(self, """\
Jeremy Hylton5941d192001-02-27 20:23:58 +0000231def f():
Jeremy Hylton97a01672001-02-09 22:56:46 +0000232 def g():
Neal Norwitz9d72bb42007-04-17 08:48:32 +0000233 from sys import *
234 return getrefcount # global or local?
Tim Peters0e6d2132001-02-15 23:56:39 +0000235""")
Jeremy Hylton97a01672001-02-09 22:56:46 +0000236
Thomas Wouters89f507f2006-12-13 04:49:30 +0000237 def testLambdas(self):
Jeremy Hylton4588c782001-01-25 20:11:23 +0000238
Thomas Wouters89f507f2006-12-13 04:49:30 +0000239 f1 = lambda x: lambda y: x + y
240 inc = f1(1)
241 plus10 = f1(10)
242 self.assertEqual(inc(1), 2)
243 self.assertEqual(plus10(5), 15)
Jeremy Hylton4588c782001-01-25 20:11:23 +0000244
Thomas Wouters89f507f2006-12-13 04:49:30 +0000245 f2 = lambda x: (lambda : lambda y: x + y)()
246 inc = f2(1)
247 plus10 = f2(10)
248 self.assertEqual(inc(1), 2)
249 self.assertEqual(plus10(5), 15)
Jeremy Hylton4588c782001-01-25 20:11:23 +0000250
Thomas Wouters89f507f2006-12-13 04:49:30 +0000251 f3 = lambda x: lambda y: global_x + y
252 global_x = 1
253 inc = f3(None)
254 self.assertEqual(inc(2), 3)
Jeremy Hylton4588c782001-01-25 20:11:23 +0000255
Thomas Wouters89f507f2006-12-13 04:49:30 +0000256 f8 = lambda x, y, z: lambda a, b, c: lambda : z * (b + y)
257 g = f8(1, 2, 3)
258 h = g(2, 4, 6)
259 self.assertEqual(h(), 18)
Jeremy Hyltonde602482001-02-05 17:35:20 +0000260
Thomas Wouters89f507f2006-12-13 04:49:30 +0000261 def testUnboundLocal(self):
Jeremy Hyltonde602482001-02-05 17:35:20 +0000262
Thomas Wouters89f507f2006-12-13 04:49:30 +0000263 def errorInOuter():
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000264 print(y)
Thomas Wouters89f507f2006-12-13 04:49:30 +0000265 def inner():
266 return y
267 y = 1
Jeremy Hyltonde602482001-02-05 17:35:20 +0000268
Thomas Wouters89f507f2006-12-13 04:49:30 +0000269 def errorInInner():
270 def inner():
271 return y
272 inner()
273 y = 1
Jeremy Hyltonde602482001-02-05 17:35:20 +0000274
Alexandre Vassalotti6f828182009-07-21 02:51:58 +0000275 self.assertRaises(UnboundLocalError, errorInOuter)
276 self.assertRaises(NameError, errorInInner)
Jeremy Hylton97a01672001-02-09 22:56:46 +0000277
Thomas Wouters89f507f2006-12-13 04:49:30 +0000278 # test for bug #1501934: incorrect LOAD/STORE_GLOBAL generation
279 exec("""
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000280global_x = 1
281def f():
282 global_x += 1
283try:
284 f()
285except UnboundLocalError:
286 pass
287else:
Thomas Wouters89f507f2006-12-13 04:49:30 +0000288 fail('scope of global_x not correctly determined')
289""", {'fail': self.fail})
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000290
Thomas Wouters89f507f2006-12-13 04:49:30 +0000291 def testComplexDefinitions(self):
Jeremy Hylton97a01672001-02-09 22:56:46 +0000292
Thomas Wouters89f507f2006-12-13 04:49:30 +0000293 def makeReturner(*lst):
294 def returner():
295 return lst
296 return returner
Tim Peters0e6d2132001-02-15 23:56:39 +0000297
Thomas Wouters89f507f2006-12-13 04:49:30 +0000298 self.assertEqual(makeReturner(1,2,3)(), (1,2,3))
Tim Peters0e6d2132001-02-15 23:56:39 +0000299
Thomas Wouters89f507f2006-12-13 04:49:30 +0000300 def makeReturner2(**kwargs):
301 def returner():
302 return kwargs
303 return returner
Jeremy Hylton97a01672001-02-09 22:56:46 +0000304
Thomas Wouters89f507f2006-12-13 04:49:30 +0000305 self.assertEqual(makeReturner2(a=11)()['a'], 11)
Jeremy Hylton97a01672001-02-09 22:56:46 +0000306
Thomas Wouters89f507f2006-12-13 04:49:30 +0000307 def testScopeOfGlobalStmt(self):
Guido van Rossum9aa643c2001-03-01 20:35:45 +0000308# Examples posted by Samuele Pedroni to python-dev on 3/1/2001
309
Thomas Wouters89f507f2006-12-13 04:49:30 +0000310 exec("""\
Guido van Rossum9aa643c2001-03-01 20:35:45 +0000311# I
312x = 7
313def f():
314 x = 1
315 def g():
316 global x
317 def i():
318 def h():
319 return x
320 return h()
321 return i()
322 return g()
Thomas Wouters89f507f2006-12-13 04:49:30 +0000323self.assertEqual(f(), 7)
324self.assertEqual(x, 7)
Guido van Rossum9aa643c2001-03-01 20:35:45 +0000325
326# II
327x = 7
328def f():
329 x = 1
330 def g():
331 x = 2
332 def i():
333 def h():
334 return x
335 return h()
336 return i()
337 return g()
Thomas Wouters89f507f2006-12-13 04:49:30 +0000338self.assertEqual(f(), 2)
339self.assertEqual(x, 7)
Guido van Rossum9aa643c2001-03-01 20:35:45 +0000340
341# III
342x = 7
343def f():
344 x = 1
345 def g():
346 global x
347 x = 2
348 def i():
349 def h():
350 return x
351 return h()
352 return i()
353 return g()
Thomas Wouters89f507f2006-12-13 04:49:30 +0000354self.assertEqual(f(), 2)
355self.assertEqual(x, 2)
Guido van Rossum9aa643c2001-03-01 20:35:45 +0000356
357# IV
358x = 7
359def f():
360 x = 3
361 def g():
362 global x
363 x = 2
364 def i():
365 def h():
366 return x
367 return h()
368 return i()
369 return g()
Thomas Wouters89f507f2006-12-13 04:49:30 +0000370self.assertEqual(f(), 2)
371self.assertEqual(x, 2)
Jeremy Hylton3e0055f2005-10-20 19:59:25 +0000372
373# XXX what about global statements in class blocks?
374# do they affect methods?
375
376x = 12
377class Global:
378 global x
379 x = 13
380 def set(self, val):
381 x = val
382 def get(self):
383 return x
384
385g = Global()
Thomas Wouters89f507f2006-12-13 04:49:30 +0000386self.assertEqual(g.get(), 13)
Jeremy Hylton3e0055f2005-10-20 19:59:25 +0000387g.set(15)
Thomas Wouters89f507f2006-12-13 04:49:30 +0000388self.assertEqual(g.get(), 13)
389""")
Jeremy Hylton5b44a672001-03-13 02:01:12 +0000390
Thomas Wouters89f507f2006-12-13 04:49:30 +0000391 def testLeaks(self):
Jeremy Hylton5b44a672001-03-13 02:01:12 +0000392
Thomas Wouters89f507f2006-12-13 04:49:30 +0000393 class Foo:
394 count = 0
Tim Peters30edd232001-03-16 08:29:48 +0000395
Thomas Wouters89f507f2006-12-13 04:49:30 +0000396 def __init__(self):
397 Foo.count += 1
Jeremy Hylton5b44a672001-03-13 02:01:12 +0000398
Thomas Wouters89f507f2006-12-13 04:49:30 +0000399 def __del__(self):
400 Foo.count -= 1
Jeremy Hylton5b44a672001-03-13 02:01:12 +0000401
Thomas Wouters89f507f2006-12-13 04:49:30 +0000402 def f1():
403 x = Foo()
404 def f2():
405 return x
406 f2()
Tim Peters30edd232001-03-16 08:29:48 +0000407
Thomas Wouters89f507f2006-12-13 04:49:30 +0000408 for i in range(100):
409 f1()
Jeremy Hylton5b44a672001-03-13 02:01:12 +0000410
Thomas Wouters89f507f2006-12-13 04:49:30 +0000411 self.assertEqual(Foo.count, 0)
Jeremy Hylton5c7a2512001-03-21 16:44:39 +0000412
Thomas Wouters89f507f2006-12-13 04:49:30 +0000413 def testClassAndGlobal(self):
Jeremy Hylton5c7a2512001-03-21 16:44:39 +0000414
Thomas Wouters89f507f2006-12-13 04:49:30 +0000415 exec("""\
Jeremy Hylton5c7a2512001-03-21 16:44:39 +0000416def test(x):
417 class Foo:
418 global x
419 def __call__(self, y):
420 return x + y
421 return Foo()
422
423x = 0
Thomas Wouters89f507f2006-12-13 04:49:30 +0000424self.assertEqual(test(6)(2), 8)
Jeremy Hylton5c7a2512001-03-21 16:44:39 +0000425x = -1
Thomas Wouters89f507f2006-12-13 04:49:30 +0000426self.assertEqual(test(3)(2), 5)
Jeremy Hylton5c7a2512001-03-21 16:44:39 +0000427
Neil Schemenauerd403c452005-10-23 04:24:49 +0000428looked_up_by_load_name = False
429class X:
430 # Implicit globals inside classes are be looked up by LOAD_NAME, not
431 # LOAD_GLOBAL.
432 locals()['looked_up_by_load_name'] = True
433 passed = looked_up_by_load_name
434
Benjamin Petersonc9c0f202009-06-30 23:06:06 +0000435self.assertTrue(X.passed)
Thomas Wouters89f507f2006-12-13 04:49:30 +0000436""")
Neil Schemenauerd403c452005-10-23 04:24:49 +0000437
Thomas Wouters89f507f2006-12-13 04:49:30 +0000438 def testLocalsFunction(self):
Jeremy Hylton5c7a2512001-03-21 16:44:39 +0000439
Thomas Wouters89f507f2006-12-13 04:49:30 +0000440 def f(x):
441 def g(y):
442 def h(z):
443 return y + z
444 w = x + y
445 y += 3
446 return locals()
447 return g
Jeremy Hylton5c7a2512001-03-21 16:44:39 +0000448
Thomas Wouters89f507f2006-12-13 04:49:30 +0000449 d = f(2)(4)
Benjamin Petersonc9c0f202009-06-30 23:06:06 +0000450 self.assertTrue('h' in d)
Thomas Wouters89f507f2006-12-13 04:49:30 +0000451 del d['h']
452 self.assertEqual(d, {'x': 2, 'y': 7, 'w': 6})
Jeremy Hyltonc76770c2001-04-13 16:51:46 +0000453
Guido van Rossumd8faa362007-04-27 19:54:29 +0000454 def testLocalsClass(self):
455 # This test verifies that calling locals() does not pollute
456 # the local namespace of the class with free variables. Old
457 # versions of Python had a bug, where a free variable being
458 # passed through a class namespace would be inserted into
459 # locals() by locals() or exec or a trace function.
460 #
461 # The real bug lies in frame code that copies variables
462 # between fast locals and the locals dict, e.g. when executing
463 # a trace function.
464
465 def f(x):
466 class C:
467 x = 12
468 def m(self):
469 return x
470 locals()
471 return C
472
473 self.assertEqual(f(1).x, 12)
474
475 def f(x):
476 class C:
477 y = x
478 def m(self):
479 return x
480 z = list(locals())
481 return C
482
483 varnames = f(1).z
Benjamin Petersonc9c0f202009-06-30 23:06:06 +0000484 self.assertTrue("x" not in varnames)
485 self.assertTrue("y" in varnames)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000486
Georg Brandl3dbca812008-07-23 16:10:53 +0000487 def testLocalsClass_WithTrace(self):
488 # Issue23728: after the trace function returns, the locals()
489 # dictionary is used to update all variables, this used to
490 # include free variables. But in class statements, free
491 # variables are not inserted...
492 import sys
493 sys.settrace(lambda a,b,c:None)
494 try:
495 x = 12
496
497 class C:
498 def f(self):
499 return x
500
501 self.assertEquals(x, 12) # Used to raise UnboundLocalError
502 finally:
503 sys.settrace(None)
504
Thomas Wouters89f507f2006-12-13 04:49:30 +0000505 def testBoundAndFree(self):
506 # var is bound and free in class
Jeremy Hyltonddc4fd02001-04-27 02:29:40 +0000507
Thomas Wouters89f507f2006-12-13 04:49:30 +0000508 def f(x):
509 class C:
510 def m(self):
511 return x
512 a = x
513 return C
Jeremy Hyltonddc4fd02001-04-27 02:29:40 +0000514
Thomas Wouters89f507f2006-12-13 04:49:30 +0000515 inst = f(3)()
516 self.assertEqual(inst.a, inst.m())
Jeremy Hylton4c889012001-05-08 04:08:59 +0000517
Thomas Wouters89f507f2006-12-13 04:49:30 +0000518 def testInteractionWithTraceFunc(self):
Jeremy Hylton4c889012001-05-08 04:08:59 +0000519
Thomas Wouters89f507f2006-12-13 04:49:30 +0000520 import sys
521 def tracer(a,b,c):
522 return tracer
Jeremy Hylton4c889012001-05-08 04:08:59 +0000523
Thomas Wouters89f507f2006-12-13 04:49:30 +0000524 def adaptgetter(name, klass, getter):
525 kind, des = getter
526 if kind == 1: # AV happens when stepping from this line to next
527 if des == "":
528 des = "_%s__%s" % (klass.__name__, name)
529 return lambda obj: getattr(obj, des)
Jeremy Hylton4c889012001-05-08 04:08:59 +0000530
Thomas Wouters89f507f2006-12-13 04:49:30 +0000531 class TestClass:
532 pass
Jeremy Hylton4c889012001-05-08 04:08:59 +0000533
Thomas Wouters89f507f2006-12-13 04:49:30 +0000534 sys.settrace(tracer)
535 adaptgetter("foo", TestClass, (1, ""))
536 sys.settrace(None)
Jeremy Hylton5121e7d2001-07-30 21:55:29 +0000537
Thomas Wouters89f507f2006-12-13 04:49:30 +0000538 self.assertRaises(TypeError, sys.settrace)
Neal Norwitz290d31e2002-03-03 15:12:58 +0000539
Thomas Wouters89f507f2006-12-13 04:49:30 +0000540 def testEvalExecFreeVars(self):
Jeremy Hylton5121e7d2001-07-30 21:55:29 +0000541
Thomas Wouters89f507f2006-12-13 04:49:30 +0000542 def f(x):
543 return lambda: x + 1
Jeremy Hylton5121e7d2001-07-30 21:55:29 +0000544
Thomas Wouters89f507f2006-12-13 04:49:30 +0000545 g = f(3)
Neal Norwitz221085d2007-02-25 20:55:47 +0000546 self.assertRaises(TypeError, eval, g.__code__)
Jeremy Hyltoncd738362001-08-07 16:38:19 +0000547
Thomas Wouters89f507f2006-12-13 04:49:30 +0000548 try:
Neal Norwitz221085d2007-02-25 20:55:47 +0000549 exec(g.__code__, {})
Thomas Wouters89f507f2006-12-13 04:49:30 +0000550 except TypeError:
551 pass
552 else:
553 self.fail("exec should have failed, because code contained free vars")
Jeremy Hyltonccae83772001-12-13 19:45:04 +0000554
Thomas Wouters89f507f2006-12-13 04:49:30 +0000555 def testListCompLocalVars(self):
Jeremy Hyltoncf672f12001-10-18 16:23:11 +0000556
Thomas Wouters89f507f2006-12-13 04:49:30 +0000557 try:
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000558 print(bad)
Thomas Wouters89f507f2006-12-13 04:49:30 +0000559 except NameError:
560 pass
561 else:
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000562 print("bad should not be defined")
Jeremy Hyltoncf672f12001-10-18 16:23:11 +0000563
Thomas Wouters89f507f2006-12-13 04:49:30 +0000564 def x():
565 [bad for s in 'a b' for bad in s.split()]
Jeremy Hyltoncf672f12001-10-18 16:23:11 +0000566
Thomas Wouters89f507f2006-12-13 04:49:30 +0000567 x()
568 try:
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000569 print(bad)
Thomas Wouters89f507f2006-12-13 04:49:30 +0000570 except NameError:
571 pass
Jeremy Hylton954aed82002-04-20 04:51:39 +0000572
Thomas Wouters89f507f2006-12-13 04:49:30 +0000573 def testEvalFreeVars(self):
Jeremy Hylton954aed82002-04-20 04:51:39 +0000574
Thomas Wouters89f507f2006-12-13 04:49:30 +0000575 def f(x):
576 def g():
577 x
578 eval("x + 1")
579 return g
Jeremy Hylton954aed82002-04-20 04:51:39 +0000580
Thomas Wouters89f507f2006-12-13 04:49:30 +0000581 f(4)()
582
Christian Heimes18c66892008-02-17 13:31:39 +0000583 def testFreeingCell(self):
584 # Test what happens when a finalizer accesses
585 # the cell where the object was stored.
586 class Special:
587 def __del__(self):
588 nestedcell_get()
589
Jeremy Hylton81e95022007-02-27 06:50:52 +0000590 def testNonLocalFunction(self):
591
592 def f(x):
593 def inc():
594 nonlocal x
595 x += 1
596 return x
597 def dec():
598 nonlocal x
599 x -= 1
600 return x
601 return inc, dec
602
603 inc, dec = f(0)
604 self.assertEqual(inc(), 1)
605 self.assertEqual(inc(), 2)
606 self.assertEqual(dec(), 1)
607 self.assertEqual(dec(), 0)
608
609 def testNonLocalMethod(self):
Jeremy Hylton81e95022007-02-27 06:50:52 +0000610 def f(x):
611 class c:
612 def inc(self):
613 nonlocal x
614 x += 1
615 return x
616 def dec(self):
617 nonlocal x
618 x -= 1
619 return x
620 return c()
Jeremy Hylton81e95022007-02-27 06:50:52 +0000621 c = f(0)
622 self.assertEqual(c.inc(), 1)
623 self.assertEqual(c.inc(), 2)
624 self.assertEqual(c.dec(), 1)
625 self.assertEqual(c.dec(), 0)
626
Jeremy Hyltonf37708e2009-03-31 15:26:37 +0000627 def testGlobalInParallelNestedFunctions(self):
628 # A symbol table bug leaked the global statement from one
629 # function to other nested functions in the same block.
630 # This test verifies that a global statement in the first
631 # function does not affect the second function.
632 CODE = """def f():
633 y = 1
634 def g():
635 global y
636 return y
637 def h():
638 return y + 1
639 return g, h
640y = 9
641g, h = f()
642result9 = g()
643result2 = h()
644"""
645 local_ns = {}
646 global_ns = {}
647 exec(CODE, local_ns, global_ns)
648 self.assertEqual(2, global_ns["result2"])
649 self.assertEqual(9, global_ns["result9"])
650
Jeremy Hylton81e95022007-02-27 06:50:52 +0000651 def testNonLocalClass(self):
652
653 def f(x):
654 class c:
655 nonlocal x
656 x += 1
657 def get(self):
658 return x
659 return c()
660
661 c = f(0)
662 self.assertEqual(c.get(), 1)
Benjamin Petersonc9c0f202009-06-30 23:06:06 +0000663 self.assertTrue("x" not in c.__class__.__dict__)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000664
Jeremy Hylton81e95022007-02-27 06:50:52 +0000665
666 def testNonLocalGenerator(self):
667
668 def f(x):
669 def g(y):
670 nonlocal x
671 for i in range(y):
672 x += 1
673 yield x
674 return g
675
676 g = f(0)
677 self.assertEqual(list(g(5)), [1, 2, 3, 4, 5])
678
679 def testNestedNonLocal(self):
680
681 def f(x):
682 def g():
683 nonlocal x
684 x -= 2
685 def h():
686 nonlocal x
687 x += 4
688 return x
689 return h
690 return g
691
692 g = f(1)
693 h = g()
694 self.assertEqual(h(), 3)
695
Thomas Wouters89f507f2006-12-13 04:49:30 +0000696
697def test_main():
698 run_unittest(ScopeTests)
699
700if __name__ == '__main__':
701 test_main()