]> granicus.if.org Git - python/commitdiff
Merged revisions 73232 via svnmerge from
authorGeorg Brandl <georg@python.org>
Thu, 4 Jun 2009 19:41:00 +0000 (19:41 +0000)
committerGeorg Brandl <georg@python.org>
Thu, 4 Jun 2009 19:41:00 +0000 (19:41 +0000)
svn+ssh://pythondev@svn.python.org/python/trunk

........
  r73232 | georg.brandl | 2009-06-04 20:59:58 +0200 (Do, 04 Jun 2009) | 1 line

  Add test for #3684.
........

Lib/test/test_traceback.py

index 64dc748a85082d4b44f7b390340060d63d38f864..903323840e69aeaf10ee8295ed1a2af5e7f91946 100644 (file)
@@ -26,6 +26,9 @@ class SyntaxTracebackCases(unittest.TestCase):
     def syntax_error_with_caret(self):
         compile("def fact(x):\n\treturn x!\n", "?", "exec")
 
+    def syntax_error_with_caret_2(self):
+        compile("1 +\n", "?", "exec")
+
     def syntax_error_without_caret(self):
         # XXX why doesn't compile raise the same traceback?
         import test.badsyntax_nocaret
@@ -41,6 +44,12 @@ class SyntaxTracebackCases(unittest.TestCase):
         self.assert_("^" in err[2]) # third line has caret
         self.assertEqual(err[1].find("!"), err[2].find("^")) # in the right place
 
+        err = self.get_exception_format(self.syntax_error_with_caret_2,
+                                        SyntaxError)
+        self.assert_("^" in err[2]) # third line has caret
+        self.assert_(err[2].count('\n') == 1) # and no additional newline
+        self.assert_(err[1].find("+") == err[2].find("^")) # in the right place
+
     def test_nocaret(self):
         if is_jython:
             # jython adds a caret in this case (why shouldn't it?)