mirror of
https://github.com/python/cpython.git
synced 2025-08-04 08:59:19 +00:00
bpo-45249: Ensure the traceback module prints correctly syntax errors with ranges (GH-28575)
This commit is contained in:
parent
adc5d32f47
commit
20f439b6b9
2 changed files with 34 additions and 6 deletions
|
@ -43,6 +43,9 @@ class TracebackCases(unittest.TestCase):
|
|||
def syntax_error_with_caret_2(self):
|
||||
compile("1 +\n", "?", "exec")
|
||||
|
||||
def syntax_error_with_caret_range(self):
|
||||
compile("f(x, y for y in range(30), z)", "?", "exec")
|
||||
|
||||
def syntax_error_bad_indentation(self):
|
||||
compile("def spam():\n print(1)\n print(2)", "?", "exec")
|
||||
|
||||
|
@ -59,18 +62,28 @@ class TracebackCases(unittest.TestCase):
|
|||
self.assertTrue(err[1].strip() == "return x!")
|
||||
self.assertIn("^", err[2]) # third line has caret
|
||||
self.assertEqual(err[1].find("!"), err[2].find("^")) # in the right place
|
||||
self.assertEqual(err[2].count("^"), 1)
|
||||
|
||||
err = self.get_exception_format(self.syntax_error_with_caret_2,
|
||||
SyntaxError)
|
||||
self.assertIn("^", err[2]) # third line has caret
|
||||
self.assertEqual(err[2].count('\n'), 1) # and no additional newline
|
||||
self.assertEqual(err[1].find("+") + 1, err[2].find("^")) # in the right place
|
||||
self.assertEqual(err[2].count("^"), 1)
|
||||
|
||||
err = self.get_exception_format(self.syntax_error_with_caret_non_ascii,
|
||||
SyntaxError)
|
||||
self.assertIn("^", err[2]) # third line has caret
|
||||
self.assertEqual(err[2].count('\n'), 1) # and no additional newline
|
||||
self.assertEqual(err[1].find("+") + 1, err[2].find("^")) # in the right place
|
||||
self.assertEqual(err[2].count("^"), 1)
|
||||
|
||||
err = self.get_exception_format(self.syntax_error_with_caret_range,
|
||||
SyntaxError)
|
||||
self.assertIn("^", err[2]) # third line has caret
|
||||
self.assertEqual(err[2].count('\n'), 1) # and no additional newline
|
||||
self.assertEqual(err[1].find("y"), err[2].find("^")) # in the right place
|
||||
self.assertEqual(err[2].count("^"), len("y for y in range(30)"))
|
||||
|
||||
def test_nocaret(self):
|
||||
exc = SyntaxError("error", ("x.py", 23, None, "bad syntax"))
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue