mirror of
https://github.com/python/cpython.git
synced 2025-08-31 14:07:50 +00:00
gh-113358: Fix rendering tracebacks with exceptions with a broken __getattr__ (GH-113359)
Co-authored-by: Irit Katriel <1055913+iritkatriel@users.noreply.github.com>
This commit is contained in:
parent
17b73ab99e
commit
04fabe22dd
3 changed files with 20 additions and 1 deletions
|
@ -2209,6 +2209,20 @@ class BaseExceptionReportingTests:
|
|||
err_msg = "b'please do not show me as numbers'"
|
||||
self.assertEqual(self.get_report(e), vanilla + err_msg + '\n')
|
||||
|
||||
# an exception with a broken __getattr__ raising a non expected error
|
||||
class BrokenException(Exception):
|
||||
broken = False
|
||||
def __getattr__(self, name):
|
||||
if self.broken:
|
||||
raise ValueError(f'no {name}')
|
||||
|
||||
e = BrokenException(123)
|
||||
vanilla = self.get_report(e)
|
||||
e.broken = True
|
||||
self.assertEqual(
|
||||
self.get_report(e),
|
||||
vanilla + "Ignored error getting __notes__: ValueError('no __notes__')\n")
|
||||
|
||||
def test_exception_with_multiple_notes(self):
|
||||
for e in [ValueError(42), SyntaxError('bad syntax')]:
|
||||
with self.subTest(e=e):
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue