bpo-32416: Add two new tests in test_sys_settrace. (GH-5072) (#5073)

Move other test to more proper place.
(cherry picked from commit e8ed96550c)
This commit is contained in:
Miss Islington (bot) 2018-01-01 10:51:30 -08:00 committed by Serhiy Storchaka
parent fe90efdc07
commit 439ce8a939

View file

@ -743,6 +743,14 @@ class JumpTestCase(unittest.TestCase):
output.append(6) output.append(6)
output.append(7) output.append(7)
@jump_test(2, 4, [1, 4, 5, -4])
def test_jump_across_with(output):
output.append(1)
with tracecontext(output, 2):
output.append(3)
with tracecontext(output, 4):
output.append(5)
@jump_test(8, 11, [1, 3, 5, 11, 12]) @jump_test(8, 11, [1, 3, 5, 11, 12])
def test_jump_out_of_complex_nested_blocks(output): def test_jump_out_of_complex_nested_blocks(output):
output.append(1) output.append(1)
@ -794,6 +802,17 @@ class JumpTestCase(unittest.TestCase):
break break
output.append(13) output.append(13)
@jump_test(1, 7, [7, 8])
def test_jump_over_for_block_before_else(output):
output.append(1)
if not output: # always false
for i in [3]:
output.append(4)
else:
output.append(6)
output.append(7)
output.append(8)
# The second set of 'jump' tests are for things that are not allowed: # The second set of 'jump' tests are for things that are not allowed:
@jump_test(2, 3, [1], (ValueError, 'after')) @jump_test(2, 3, [1], (ValueError, 'after'))
@ -951,21 +970,24 @@ class JumpTestCase(unittest.TestCase):
finally: finally:
output.append(5) output.append(5)
@jump_test(2, 4, [1, 4, 5, -4]) @jump_test(3, 5, [1, 2, -2], (ValueError, 'into'))
def test_jump_across_with(output): def test_no_jump_between_with_blocks(output):
output.append(1) output.append(1)
with tracecontext(output, 2): with tracecontext(output, 2):
output.append(3) output.append(3)
with tracecontext(output, 4): with tracecontext(output, 4):
output.append(5) output.append(5)
@jump_test(3, 5, [1, 2, -2], (ValueError, 'into')) @jump_test(7, 4, [1, 6], (ValueError, 'into'))
def test_jump_across_with_2(output): def test_no_jump_into_for_block_before_else(output):
output.append(1) output.append(1)
with tracecontext(output, 2): if not output: # always false
output.append(3) for i in [3]:
with tracecontext(output, 4): output.append(4)
output.append(5) else:
output.append(6)
output.append(7)
output.append(8)
def test_no_jump_to_non_integers(self): def test_no_jump_to_non_integers(self):
self.run_test(no_jump_to_non_integers, 2, "Spam", [True]) self.run_test(no_jump_to_non_integers, 2, "Spam", [True])