blob: 7f7db334ed06370dcd575e29b289c32b75823bb3 [file] [log] [blame]
Michael W. Hudson53d58bb2002-08-30 13:09:51 +00001# Testing the line trace facility.
2
3from test import test_support
4import unittest
5import sys
6import difflib
7
8# A very basic example. If this fails, we're in deep trouble.
9def basic():
10 return 1
11
12basic.events = [(0, 'call'),
13 (1, 'line'),
14 (1, 'return')]
15
Jeremy Hyltoned40ea12006-04-04 14:26:39 +000016# Many of the tests below are tricky because they involve pass statements.
17# If there is implicit control flow around a pass statement (in an except
18# clause or else caluse) under what conditions do you set a line number
19# following that clause?
20
21
22# The entire "while 0:" statement is optimized away. No code
23# exists for it, so the line numbers skip directly from "del x"
24# to "x = 1".
Michael W. Hudson53d58bb2002-08-30 13:09:51 +000025def arigo_example():
26 x = 1
27 del x
28 while 0:
29 pass
30 x = 1
31
32arigo_example.events = [(0, 'call'),
33 (1, 'line'),
34 (2, 'line'),
Michael W. Hudson53d58bb2002-08-30 13:09:51 +000035 (5, 'line'),
36 (5, 'return')]
37
38# check that lines consisting of just one instruction get traced:
39def one_instr_line():
40 x = 1
41 del x
42 x = 1
43
44one_instr_line.events = [(0, 'call'),
45 (1, 'line'),
46 (2, 'line'),
47 (3, 'line'),
48 (3, 'return')]
49
50def no_pop_tops(): # 0
51 x = 1 # 1
52 for a in range(2): # 2
53 if a: # 3
54 x = 1 # 4
55 else: # 5
56 x = 1 # 6
57
58no_pop_tops.events = [(0, 'call'),
59 (1, 'line'),
60 (2, 'line'),
61 (3, 'line'),
62 (6, 'line'),
63 (2, 'line'),
64 (3, 'line'),
65 (4, 'line'),
66 (2, 'line'),
Michael W. Hudson02ff6a92002-09-11 15:36:32 +000067 (2, 'return')]
Michael W. Hudson53d58bb2002-08-30 13:09:51 +000068
69def no_pop_blocks():
Jeremy Hyltoned40ea12006-04-04 14:26:39 +000070 y = 1
71 while not y:
Michael W. Hudson53d58bb2002-08-30 13:09:51 +000072 bla
73 x = 1
74
75no_pop_blocks.events = [(0, 'call'),
76 (1, 'line'),
Jeremy Hyltoned40ea12006-04-04 14:26:39 +000077 (2, 'line'),
78 (4, 'line'),
79 (4, 'return')]
Michael W. Hudson53d58bb2002-08-30 13:09:51 +000080
Michael W. Hudson519a3422002-09-11 14:47:51 +000081def called(): # line -3
82 x = 1
83
84def call(): # line 0
85 called()
86
87call.events = [(0, 'call'),
88 (1, 'line'),
89 (-3, 'call'),
90 (-2, 'line'),
91 (-2, 'return'),
92 (1, 'return')]
93
94def raises():
95 raise Exception
96
97def test_raise():
98 try:
99 raises()
100 except Exception, exc:
101 x = 1
102
103test_raise.events = [(0, 'call'),
104 (1, 'line'),
105 (2, 'line'),
106 (-3, 'call'),
107 (-2, 'line'),
108 (-2, 'exception'),
Barry Warsawe2eca0b2005-08-15 18:14:19 +0000109 (-2, 'return'),
Michael W. Hudson519a3422002-09-11 14:47:51 +0000110 (2, 'exception'),
111 (3, 'line'),
112 (4, 'line'),
113 (4, 'return')]
114
115def _settrace_and_return(tracefunc):
116 sys.settrace(tracefunc)
117 sys._getframe().f_back.f_trace = tracefunc
118def settrace_and_return(tracefunc):
119 _settrace_and_return(tracefunc)
Tim Peters3de75262002-11-09 05:26:15 +0000120
Michael W. Hudson519a3422002-09-11 14:47:51 +0000121settrace_and_return.events = [(1, 'return')]
122
123def _settrace_and_raise(tracefunc):
124 sys.settrace(tracefunc)
125 sys._getframe().f_back.f_trace = tracefunc
126 raise RuntimeError
127def settrace_and_raise(tracefunc):
128 try:
129 _settrace_and_raise(tracefunc)
130 except RuntimeError, exc:
131 pass
Tim Peters3de75262002-11-09 05:26:15 +0000132
Michael W. Hudson519a3422002-09-11 14:47:51 +0000133settrace_and_raise.events = [(2, 'exception'),
134 (3, 'line'),
135 (4, 'line'),
136 (4, 'return')]
137
Nicholas Bastinaea94592004-03-22 18:30:42 +0000138# implicit return example
Jeremy Hyltoned40ea12006-04-04 14:26:39 +0000139# This test is interesting because of the else: pass
140# part of the code. The code generate for the true
141# part of the if contains a jump past the else branch.
142# The compiler then generates an implicit "return None"
143# Internally, the compiler visits the pass statement
144# and stores its line number for use on the next instruction.
145# The next instruction is the implicit return None.
Nicholas Bastinaea94592004-03-22 18:30:42 +0000146def ireturn_example():
147 a = 5
148 b = 5
149 if a == b:
150 b = a+1
151 else:
152 pass
153
154ireturn_example.events = [(0, 'call'),
155 (1, 'line'),
156 (2, 'line'),
157 (3, 'line'),
158 (4, 'line'),
Jeremy Hyltoned40ea12006-04-04 14:26:39 +0000159 (6, 'line'),
160 (6, 'return')]
Nicholas Bastinaea94592004-03-22 18:30:42 +0000161
Nicholas Bastinfa7bec72004-03-22 19:21:47 +0000162# Tight loop with while(1) example (SF #765624)
163def tightloop_example():
164 items = range(0, 3)
165 try:
166 i = 0
167 while 1:
Nicholas Bastinee6c9b82004-03-22 19:23:46 +0000168 b = items[i]; i+=1
Nicholas Bastinfa7bec72004-03-22 19:21:47 +0000169 except IndexError:
170 pass
171
172tightloop_example.events = [(0, 'call'),
173 (1, 'line'),
174 (2, 'line'),
175 (3, 'line'),
176 (4, 'line'),
177 (5, 'line'),
178 (5, 'line'),
179 (5, 'line'),
Nicholas Bastinee6c9b82004-03-22 19:23:46 +0000180 (5, 'line'),
Nicholas Bastinfa7bec72004-03-22 19:21:47 +0000181 (5, 'exception'),
182 (6, 'line'),
183 (7, 'line'),
184 (7, 'return')]
185
Armin Rigo70693382004-03-22 19:30:39 +0000186def tighterloop_example():
187 items = range(1, 4)
188 try:
189 i = 0
190 while 1: i = items[i]
191 except IndexError:
192 pass
193
194tighterloop_example.events = [(0, 'call'),
195 (1, 'line'),
196 (2, 'line'),
197 (3, 'line'),
198 (4, 'line'),
199 (4, 'line'),
200 (4, 'line'),
201 (4, 'line'),
202 (4, 'exception'),
203 (5, 'line'),
204 (6, 'line'),
205 (6, 'return')]
206
Amaury Forgeot d'Arc0d75f092007-11-13 21:54:28 +0000207def generator_function():
208 try:
209 yield True
210 "continued"
211 finally:
212 "finally"
213def generator_example():
214 # any() will leave the generator before its end
215 x = any(generator_function())
216
217 # the following lines were not traced
218 for x in range(10):
219 y = x
220
221generator_example.events = ([(0, 'call'),
222 (2, 'line'),
223 (-6, 'call'),
224 (-5, 'line'),
225 (-4, 'line'),
226 (-4, 'return'),
227 (-4, 'call'),
228 (-4, 'exception'),
229 (-1, 'line'),
230 (-1, 'return')] +
231 [(5, 'line'), (6, 'line')] * 10 +
232 [(5, 'line'), (5, 'return')])
233
234
Michael W. Hudson53d58bb2002-08-30 13:09:51 +0000235class Tracer:
236 def __init__(self):
237 self.events = []
238 def trace(self, frame, event, arg):
239 self.events.append((frame.f_lineno, event))
240 return self.trace
Amaury Forgeot d'Arc0d75f092007-11-13 21:54:28 +0000241 def traceWithGenexp(self, frame, event, arg):
242 (o for o in [1])
243 self.events.append((frame.f_lineno, event))
244 return self.trace
Michael W. Hudson53d58bb2002-08-30 13:09:51 +0000245
246class TraceTestCase(unittest.TestCase):
Michael W. Hudson519a3422002-09-11 14:47:51 +0000247 def compare_events(self, line_offset, events, expected_events):
Tim Peters3de75262002-11-09 05:26:15 +0000248 events = [(l - line_offset, e) for (l, e) in events]
Michael W. Hudson519a3422002-09-11 14:47:51 +0000249 if events != expected_events:
250 self.fail(
251 "events did not match expectation:\n" +
Amaury Forgeot d'Arc0d75f092007-11-13 21:54:28 +0000252 "\n".join(difflib.ndiff([str(x) for x in expected_events],
253 [str(x) for x in events])))
Tim Peters3de75262002-11-09 05:26:15 +0000254
Amaury Forgeot d'Arc6fd03bb2008-02-04 21:45:05 +0000255 def run_and_compare(self, func, events):
Michael W. Hudson53d58bb2002-08-30 13:09:51 +0000256 tracer = Tracer()
257 sys.settrace(tracer.trace)
258 func()
259 sys.settrace(None)
Michael W. Hudson519a3422002-09-11 14:47:51 +0000260 self.compare_events(func.func_code.co_firstlineno,
Amaury Forgeot d'Arc6fd03bb2008-02-04 21:45:05 +0000261 tracer.events, events)
262
263 def run_test(self, func):
264 self.run_and_compare(func, func.events)
Michael W. Hudson519a3422002-09-11 14:47:51 +0000265
266 def run_test2(self, func):
267 tracer = Tracer()
268 func(tracer.trace)
269 sys.settrace(None)
270 self.compare_events(func.func_code.co_firstlineno,
271 tracer.events, func.events)
Tim Peters3de75262002-11-09 05:26:15 +0000272
Georg Brandl56112892008-01-20 13:59:46 +0000273 def set_and_retrieve_none(self):
274 sys.settrace(None)
275 assert sys.gettrace() is None
276
277 def set_and_retrieve_func(self):
278 def fn(*args):
279 pass
280
281 sys.settrace(fn)
282 try:
283 assert sys.gettrace() is fn
284 finally:
285 sys.settrace(None)
286
Nicholas Bastinaea94592004-03-22 18:30:42 +0000287 def test_01_basic(self):
Michael W. Hudson53d58bb2002-08-30 13:09:51 +0000288 self.run_test(basic)
Jeremy Hyltoned40ea12006-04-04 14:26:39 +0000289 def test_02_arigo(self):
290 self.run_test(arigo_example)
Nicholas Bastinaea94592004-03-22 18:30:42 +0000291 def test_03_one_instr(self):
Michael W. Hudson53d58bb2002-08-30 13:09:51 +0000292 self.run_test(one_instr_line)
Jeremy Hyltoned40ea12006-04-04 14:26:39 +0000293 def test_04_no_pop_blocks(self):
294 self.run_test(no_pop_blocks)
Neal Norwitz4ffedad2006-08-04 04:58:47 +0000295 def test_05_no_pop_tops(self):
296 self.run_test(no_pop_tops)
Nicholas Bastinaea94592004-03-22 18:30:42 +0000297 def test_06_call(self):
Michael W. Hudson519a3422002-09-11 14:47:51 +0000298 self.run_test(call)
Nicholas Bastinaea94592004-03-22 18:30:42 +0000299 def test_07_raise(self):
Michael W. Hudson519a3422002-09-11 14:47:51 +0000300 self.run_test(test_raise)
301
Nicholas Bastinaea94592004-03-22 18:30:42 +0000302 def test_08_settrace_and_return(self):
Michael W. Hudson519a3422002-09-11 14:47:51 +0000303 self.run_test2(settrace_and_return)
Nicholas Bastinaea94592004-03-22 18:30:42 +0000304 def test_09_settrace_and_raise(self):
Michael W. Hudson519a3422002-09-11 14:47:51 +0000305 self.run_test2(settrace_and_raise)
Jeremy Hyltoned40ea12006-04-04 14:26:39 +0000306 def test_10_ireturn(self):
307 self.run_test(ireturn_example)
Nicholas Bastinfa7bec72004-03-22 19:21:47 +0000308 def test_11_tightloop(self):
309 self.run_test(tightloop_example)
Armin Rigo70693382004-03-22 19:30:39 +0000310 def test_12_tighterloop(self):
311 self.run_test(tighterloop_example)
Michael W. Hudson53d58bb2002-08-30 13:09:51 +0000312
Amaury Forgeot d'Arc0d75f092007-11-13 21:54:28 +0000313 def test_13_genexp(self):
314 self.run_test(generator_example)
315 # issue1265: if the trace function contains a generator,
316 # and if the traced function contains another generator
317 # that is not completely exhausted, the trace stopped.
318 # Worse: the 'finally' clause was not invoked.
319 tracer = Tracer()
320 sys.settrace(tracer.traceWithGenexp)
321 generator_example()
322 sys.settrace(None)
323 self.compare_events(generator_example.__code__.co_firstlineno,
324 tracer.events, generator_example.events)
325
Amaury Forgeot d'Arc6fd03bb2008-02-04 21:45:05 +0000326 def test_14_onliner_if(self):
327 def onliners():
328 if True: False
329 else: True
330 return 0
331 self.run_and_compare(
332 onliners,
333 [(0, 'call'),
334 (1, 'line'),
335 (3, 'line'),
336 (3, 'return')])
337
338 def test_15_loops(self):
339 # issue1750076: "while" expression is skipped by debugger
340 def for_example():
341 for x in range(2):
342 pass
343 self.run_and_compare(
344 for_example,
345 [(0, 'call'),
346 (1, 'line'),
347 (2, 'line'),
348 (1, 'line'),
349 (2, 'line'),
350 (1, 'line'),
351 (1, 'return')])
352
353 def while_example():
354 # While expression should be traced on every loop
355 x = 2
356 while x > 0:
357 x -= 1
358 self.run_and_compare(
359 while_example,
360 [(0, 'call'),
361 (2, 'line'),
362 (3, 'line'),
363 (4, 'line'),
364 (3, 'line'),
365 (4, 'line'),
366 (3, 'line'),
367 (3, 'return')])
368
Michael W. Hudsonfb4d6ec2002-10-02 13:13:45 +0000369class RaisingTraceFuncTestCase(unittest.TestCase):
Michael W. Hudson006c7522002-11-08 13:08:46 +0000370 def trace(self, frame, event, arg):
371 """A trace function that raises an exception in response to a
372 specific trace event."""
373 if event == self.raiseOnEvent:
Michael W. Hudsonfb4d6ec2002-10-02 13:13:45 +0000374 raise ValueError # just something that isn't RuntimeError
Michael W. Hudson006c7522002-11-08 13:08:46 +0000375 else:
376 return self.trace
Tim Peters3de75262002-11-09 05:26:15 +0000377
Michael W. Hudson006c7522002-11-08 13:08:46 +0000378 def f(self):
379 """The function to trace; raises an exception if that's the case
380 we're testing, so that the 'exception' trace event fires."""
381 if self.raiseOnEvent == 'exception':
382 x = 0
383 y = 1/x
384 else:
Michael W. Hudsonfb4d6ec2002-10-02 13:13:45 +0000385 return 1
Tim Peters3de75262002-11-09 05:26:15 +0000386
Michael W. Hudson006c7522002-11-08 13:08:46 +0000387 def run_test_for_event(self, event):
388 """Tests that an exception raised in response to the given event is
389 handled OK."""
390 self.raiseOnEvent = event
Michael W. Hudsonfb4d6ec2002-10-02 13:13:45 +0000391 try:
392 for i in xrange(sys.getrecursionlimit() + 1):
Michael W. Hudson006c7522002-11-08 13:08:46 +0000393 sys.settrace(self.trace)
Michael W. Hudsonfb4d6ec2002-10-02 13:13:45 +0000394 try:
Michael W. Hudson006c7522002-11-08 13:08:46 +0000395 self.f()
Michael W. Hudsonfb4d6ec2002-10-02 13:13:45 +0000396 except ValueError:
397 pass
398 else:
399 self.fail("exception not thrown!")
400 except RuntimeError:
401 self.fail("recursion counter not reset")
Tim Peters3de75262002-11-09 05:26:15 +0000402
Michael W. Hudson006c7522002-11-08 13:08:46 +0000403 # Test the handling of exceptions raised by each kind of trace event.
404 def test_call(self):
405 self.run_test_for_event('call')
406 def test_line(self):
407 self.run_test_for_event('line')
408 def test_return(self):
409 self.run_test_for_event('return')
410 def test_exception(self):
411 self.run_test_for_event('exception')
Michael W. Hudsonfb4d6ec2002-10-02 13:13:45 +0000412
Michael W. Hudson58ee2af2003-04-29 16:18:47 +0000413 def test_trash_stack(self):
414 def f():
415 for i in range(5):
416 print i # line tracing will raise an exception at this line
417
418 def g(frame, why, extra):
419 if (why == 'line' and
420 frame.f_lineno == f.func_code.co_firstlineno + 2):
421 raise RuntimeError, "i am crashing"
422 return g
423
424 sys.settrace(g)
425 try:
426 f()
427 except RuntimeError:
428 # the test is really that this doesn't segfault:
429 import gc
430 gc.collect()
431 else:
432 self.fail("exception not propagated")
433
Michael W. Hudsoncfd38842002-12-17 16:15:34 +0000434
435# 'Jump' tests: assigning to frame.f_lineno within a trace function
436# moves the execution position - it's how debuggers implement a Jump
437# command (aka. "Set next statement").
438
439class JumpTracer:
440 """Defines a trace function that jumps from one place to another,
441 with the source and destination lines of the jump being defined by
442 the 'jump' property of the function under test."""
443
444 def __init__(self, function):
445 self.function = function
446 self.jumpFrom = function.jump[0]
447 self.jumpTo = function.jump[1]
448 self.done = False
449
450 def trace(self, frame, event, arg):
451 if not self.done and frame.f_code == self.function.func_code:
452 firstLine = frame.f_code.co_firstlineno
453 if frame.f_lineno == firstLine + self.jumpFrom:
454 # Cope with non-integer self.jumpTo (because of
455 # no_jump_to_non_integers below).
456 try:
457 frame.f_lineno = firstLine + self.jumpTo
458 except TypeError:
459 frame.f_lineno = self.jumpTo
460 self.done = True
461 return self.trace
462
463# The first set of 'jump' tests are for things that are allowed:
464
465def jump_simple_forwards(output):
466 output.append(1)
467 output.append(2)
468 output.append(3)
469
470jump_simple_forwards.jump = (1, 3)
471jump_simple_forwards.output = [3]
472
473def jump_simple_backwards(output):
474 output.append(1)
475 output.append(2)
476
477jump_simple_backwards.jump = (2, 1)
478jump_simple_backwards.output = [1, 1, 2]
479
480def jump_out_of_block_forwards(output):
481 for i in 1, 2:
482 output.append(2)
483 for j in [3]: # Also tests jumping over a block
484 output.append(4)
485 output.append(5)
486
487jump_out_of_block_forwards.jump = (3, 5)
488jump_out_of_block_forwards.output = [2, 5]
489
490def jump_out_of_block_backwards(output):
491 output.append(1)
492 for i in [1]:
493 output.append(3)
494 for j in [2]: # Also tests jumping over a block
495 output.append(5)
496 output.append(6)
497 output.append(7)
498
499jump_out_of_block_backwards.jump = (6, 1)
500jump_out_of_block_backwards.output = [1, 3, 5, 1, 3, 5, 6, 7]
501
502def jump_to_codeless_line(output):
503 output.append(1)
504 # Jumping to this line should skip to the next one.
505 output.append(3)
506
507jump_to_codeless_line.jump = (1, 2)
508jump_to_codeless_line.output = [3]
509
510def jump_to_same_line(output):
511 output.append(1)
512 output.append(2)
513 output.append(3)
514
515jump_to_same_line.jump = (2, 2)
516jump_to_same_line.output = [1, 2, 3]
517
518# Tests jumping within a finally block, and over one.
519def jump_in_nested_finally(output):
520 try:
521 output.append(2)
522 finally:
523 output.append(4)
524 try:
525 output.append(6)
526 finally:
527 output.append(8)
528 output.append(9)
529
530jump_in_nested_finally.jump = (4, 9)
531jump_in_nested_finally.output = [2, 9]
532
533# The second set of 'jump' tests are for things that are not allowed:
534
535def no_jump_too_far_forwards(output):
536 try:
537 output.append(2)
538 output.append(3)
539 except ValueError, e:
540 output.append('after' in str(e))
541
542no_jump_too_far_forwards.jump = (3, 6)
543no_jump_too_far_forwards.output = [2, True]
544
545def no_jump_too_far_backwards(output):
546 try:
547 output.append(2)
548 output.append(3)
549 except ValueError, e:
550 output.append('before' in str(e))
551
552no_jump_too_far_backwards.jump = (3, -1)
553no_jump_too_far_backwards.output = [2, True]
554
555# Test each kind of 'except' line.
556def no_jump_to_except_1(output):
557 try:
558 output.append(2)
559 except:
560 e = sys.exc_info()[1]
561 output.append('except' in str(e))
562
563no_jump_to_except_1.jump = (2, 3)
564no_jump_to_except_1.output = [True]
565
566def no_jump_to_except_2(output):
567 try:
568 output.append(2)
569 except ValueError:
570 e = sys.exc_info()[1]
571 output.append('except' in str(e))
572
573no_jump_to_except_2.jump = (2, 3)
574no_jump_to_except_2.output = [True]
575
576def no_jump_to_except_3(output):
577 try:
578 output.append(2)
579 except ValueError, e:
580 output.append('except' in str(e))
581
582no_jump_to_except_3.jump = (2, 3)
583no_jump_to_except_3.output = [True]
584
585def no_jump_to_except_4(output):
586 try:
587 output.append(2)
588 except (ValueError, RuntimeError), e:
589 output.append('except' in str(e))
590
591no_jump_to_except_4.jump = (2, 3)
592no_jump_to_except_4.output = [True]
593
594def no_jump_forwards_into_block(output):
595 try:
596 output.append(2)
597 for i in 1, 2:
598 output.append(4)
599 except ValueError, e:
600 output.append('into' in str(e))
601
602no_jump_forwards_into_block.jump = (2, 4)
603no_jump_forwards_into_block.output = [True]
604
605def no_jump_backwards_into_block(output):
606 try:
607 for i in 1, 2:
608 output.append(3)
609 output.append(4)
610 except ValueError, e:
611 output.append('into' in str(e))
612
613no_jump_backwards_into_block.jump = (4, 3)
614no_jump_backwards_into_block.output = [3, 3, True]
615
616def no_jump_into_finally_block(output):
617 try:
618 try:
619 output.append(3)
620 x = 1
621 finally:
622 output.append(6)
623 except ValueError, e:
624 output.append('finally' in str(e))
625
626no_jump_into_finally_block.jump = (4, 6)
627no_jump_into_finally_block.output = [3, 6, True] # The 'finally' still runs
628
629def no_jump_out_of_finally_block(output):
630 try:
631 try:
632 output.append(3)
633 finally:
634 output.append(5)
635 output.append(6)
636 except ValueError, e:
637 output.append('finally' in str(e))
638
639no_jump_out_of_finally_block.jump = (5, 1)
640no_jump_out_of_finally_block.output = [3, True]
641
642# This verifies the line-numbers-must-be-integers rule.
643def no_jump_to_non_integers(output):
644 try:
645 output.append(2)
646 except ValueError, e:
647 output.append('integer' in str(e))
648
649no_jump_to_non_integers.jump = (2, "Spam")
650no_jump_to_non_integers.output = [True]
651
652# This verifies that you can't set f_lineno via _getframe or similar
653# trickery.
654def no_jump_without_trace_function():
655 try:
656 previous_frame = sys._getframe().f_back
657 previous_frame.f_lineno = previous_frame.f_lineno
658 except ValueError, e:
659 # This is the exception we wanted; make sure the error message
660 # talks about trace functions.
661 if 'trace' not in str(e):
662 raise
663 else:
664 # Something's wrong - the expected exception wasn't raised.
665 raise RuntimeError, "Trace-function-less jump failed to fail"
666
667
668class JumpTestCase(unittest.TestCase):
669 def compare_jump_output(self, expected, received):
670 if received != expected:
671 self.fail( "Outputs don't match:\n" +
672 "Expected: " + repr(expected) + "\n" +
673 "Received: " + repr(received))
674
675 def run_test(self, func):
676 tracer = JumpTracer(func)
677 sys.settrace(tracer.trace)
678 output = []
679 func(output)
680 sys.settrace(None)
681 self.compare_jump_output(func.output, output)
682
683 def test_01_jump_simple_forwards(self):
684 self.run_test(jump_simple_forwards)
685 def test_02_jump_simple_backwards(self):
686 self.run_test(jump_simple_backwards)
687 def test_03_jump_out_of_block_forwards(self):
688 self.run_test(jump_out_of_block_forwards)
689 def test_04_jump_out_of_block_backwards(self):
690 self.run_test(jump_out_of_block_backwards)
691 def test_05_jump_to_codeless_line(self):
692 self.run_test(jump_to_codeless_line)
693 def test_06_jump_to_same_line(self):
694 self.run_test(jump_to_same_line)
695 def test_07_jump_in_nested_finally(self):
696 self.run_test(jump_in_nested_finally)
697 def test_08_no_jump_too_far_forwards(self):
698 self.run_test(no_jump_too_far_forwards)
699 def test_09_no_jump_too_far_backwards(self):
700 self.run_test(no_jump_too_far_backwards)
Jeremy Hyltoned40ea12006-04-04 14:26:39 +0000701 def test_10_no_jump_to_except_1(self):
702 self.run_test(no_jump_to_except_1)
703 def test_11_no_jump_to_except_2(self):
704 self.run_test(no_jump_to_except_2)
705 def test_12_no_jump_to_except_3(self):
706 self.run_test(no_jump_to_except_3)
707 def test_13_no_jump_to_except_4(self):
708 self.run_test(no_jump_to_except_4)
Michael W. Hudsoncfd38842002-12-17 16:15:34 +0000709 def test_14_no_jump_forwards_into_block(self):
710 self.run_test(no_jump_forwards_into_block)
711 def test_15_no_jump_backwards_into_block(self):
712 self.run_test(no_jump_backwards_into_block)
713 def test_16_no_jump_into_finally_block(self):
714 self.run_test(no_jump_into_finally_block)
715 def test_17_no_jump_out_of_finally_block(self):
716 self.run_test(no_jump_out_of_finally_block)
717 def test_18_no_jump_to_non_integers(self):
718 self.run_test(no_jump_to_non_integers)
719 def test_19_no_jump_without_trace_function(self):
720 no_jump_without_trace_function()
721
Michael W. Hudson53d58bb2002-08-30 13:09:51 +0000722def test_main():
Walter Dörwald21d3a322003-05-01 17:45:56 +0000723 test_support.run_unittest(
724 TraceTestCase,
725 RaisingTraceFuncTestCase,
726 JumpTestCase
727 )
Michael W. Hudson53d58bb2002-08-30 13:09:51 +0000728
729if __name__ == "__main__":
730 test_main()