diff options
| author | Michael W. Hudson <mwh@python.net> | 2003-04-29 17:07:36 (GMT) | 
|---|---|---|
| committer | Michael W. Hudson <mwh@python.net> | 2003-04-29 17:07:36 (GMT) | 
| commit | 26848a34d100f5ff9c3f2710d321d68f73204005 (patch) | |
| tree | e7c2a4244b20e061ed6f871c14c5fafa8648693b /Lib/test | |
| parent | 58ee2af48ecc353bd56fab588c85248a2f1bc373 (diff) | |
| download | cpython-26848a34d100f5ff9c3f2710d321d68f73204005.zip cpython-26848a34d100f5ff9c3f2710d321d68f73204005.tar.gz cpython-26848a34d100f5ff9c3f2710d321d68f73204005.tar.bz2  | |
Use Tim's suggestion to fix
[ 708901 ] Lineno calculation sometimes broken
A one line patch to compile.c and a rather-more-than-one-line patch
to test_dis.  Hey ho.
Possibly a backport candidate -- tho' lnotab is less used in 2.2...
Diffstat (limited to 'Lib/test')
| -rw-r--r-- | Lib/test/test_dis.py | 65 | 
1 files changed, 51 insertions, 14 deletions
diff --git a/Lib/test/test_dis.py b/Lib/test/test_dis.py index ab93d4a..d88ea45 100644 --- a/Lib/test/test_dis.py +++ b/Lib/test/test_dis.py @@ -14,17 +14,61 @@ def _f(a):      return 1  dis_f = """\ - 13           0 LOAD_FAST                0 (a) + %-4d         0 LOAD_FAST                0 (a)                3 PRINT_ITEM                4 PRINT_NEWLINE - 14           5 LOAD_CONST               1 (1) + %-4d         5 LOAD_CONST               1 (1)                8 RETURN_VALUE                9 LOAD_CONST               0 (None)               12 RETURN_VALUE -""" +"""%(_f.func_code.co_firstlineno + 1, +     _f.func_code.co_firstlineno + 2) + + +def bug708901(): +    for res in range(1, +                     10): +        pass + +dis_bug708901 = """\ + %-4d         0 SETUP_LOOP              23 (to 26) +              3 LOAD_GLOBAL              0 (range) +              6 LOAD_CONST               1 (1) + + %-4d         9 LOAD_CONST               2 (10) +             12 CALL_FUNCTION            2 +             15 GET_ITER +        >>   16 FOR_ITER                 6 (to 25) +             19 STORE_FAST               0 (res) + + %-4d        22 JUMP_ABSOLUTE           16 +        >>   25 POP_BLOCK +        >>   26 LOAD_CONST               0 (None) +             29 RETURN_VALUE +"""%(bug708901.func_code.co_firstlineno + 1, +     bug708901.func_code.co_firstlineno + 2, +     bug708901.func_code.co_firstlineno + 3)  class DisTests(unittest.TestCase): +    def do_disassembly_test(self, func, expected): +        s = StringIO.StringIO() +        save_stdout = sys.stdout +        sys.stdout = s +        dis.dis(func) +        sys.stdout = save_stdout +        got = s.getvalue() +        # Trim trailing blanks (if any). +        lines = got.split('\n') +        lines = [line.rstrip() for line in lines] +        expected = expected.split("\n") +        import difflib +        if expected != lines: +            self.fail( +                "events did not match expectation:\n" + +                "\n".join(difflib.ndiff(expected, +                                        lines))) +      def test_opmap(self):          self.assertEqual(dis.opmap["STOP_CODE"], 0)          self.assertEqual(dis.opmap["LOAD_CONST"] in dis.hasconst, True) @@ -38,17 +82,10 @@ class DisTests(unittest.TestCase):          self.assertEqual(dis.opmap["STORE_NAME"], dis.HAVE_ARGUMENT)      def test_dis(self): -        s = StringIO.StringIO() -        save_stdout = sys.stdout -        sys.stdout = s -        dis.dis(_f) -        sys.stdout = save_stdout -        got = s.getvalue() -        # Trim trailing blanks (if any). -        lines = got.split('\n') -        lines = [line.rstrip() for line in lines] -        got = '\n'.join(lines) -        self.assertEqual(dis_f, got) +        self.do_disassembly_test(_f, dis_f) + +    def test_bug_708901(self): +        self.do_disassembly_test(bug708901, dis_bug708901)  def test_main():      run_unittest(DisTests)  | 
