diff options
author | Pablo Galindo Salgado <Pablogsal@gmail.com> | 2021-10-16 18:27:43 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-10-16 10:27:43 -0700 |
commit | fe0d9e22a52a10c4cbe52254b51f2d4e74d83568 (patch) | |
tree | 164d8d69ef92ef996cf43c4f4ae8ffeafc3980f7 /Lib/test | |
parent | 5afa0a411243210a30526c7459a0ccff5cb88494 (diff) | |
download | cpython-fe0d9e22a52a10c4cbe52254b51f2d4e74d83568.tar.gz cpython-fe0d9e22a52a10c4cbe52254b51f2d4e74d83568.zip |
bpo-45249: Fix caret location when end_offset is set to 0 (GH-28855)
Diffstat (limited to 'Lib/test')
-rw-r--r-- | Lib/test/test_traceback.py | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/Lib/test/test_traceback.py b/Lib/test/test_traceback.py index 83d36e12c02..1c7db9d3d47 100644 --- a/Lib/test/test_traceback.py +++ b/Lib/test/test_traceback.py @@ -55,6 +55,9 @@ class TracebackCases(unittest.TestCase): def syntax_error_bad_indentation2(self): compile(" print(2)", "?", "exec") + def tokenizer_error_with_caret_range(self): + compile("blech ( ", "?", "exec") + def test_caret(self): err = self.get_exception_format(self.syntax_error_with_caret, SyntaxError) @@ -85,6 +88,13 @@ class TracebackCases(unittest.TestCase): 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)")) + err = self.get_exception_format(self.tokenizer_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("("), err[2].find("^")) # in the right place + self.assertEqual(err[2].count("^"), 1) + def test_nocaret(self): exc = SyntaxError("error", ("x.py", 23, None, "bad syntax")) err = traceback.format_exception_only(SyntaxError, exc) |