gh-102008: simplify test_except_star by using sys.exception() instead of sys.exc_info() (#102009)

This commit is contained in:
Irit Katriel 2023-02-21 15:11:31 +00:00 committed by GitHub
parent 7346a381be
commit c2b85a95a5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -208,44 +208,38 @@ class ExceptStarTest(unittest.TestCase):
class TestExceptStarSplitSemantics(ExceptStarTest):
def doSplitTestNamed(self, exc, T, match_template, rest_template):
initial_exc_info = sys.exc_info()
exc_info = match = rest = None
initial_sys_exception = sys.exception()
sys_exception = match = rest = None
try:
try:
raise exc
except* T as e:
exc_info = sys.exc_info()
sys_exception = sys.exception()
match = e
except BaseException as e:
rest = e
if match_template:
self.assertEqual(exc_info[1], match)
else:
self.assertIsNone(exc_info)
self.assertEqual(sys_exception, match)
self.assertExceptionIsLike(match, match_template)
self.assertExceptionIsLike(rest, rest_template)
self.assertEqual(sys.exc_info(), initial_exc_info)
self.assertEqual(sys.exception(), initial_sys_exception)
def doSplitTestUnnamed(self, exc, T, match_template, rest_template):
initial_exc_info = sys.exc_info()
exc_info = match = rest = None
initial_sys_exception = sys.exception()
sys_exception = match = rest = None
try:
try:
raise exc
except* T:
exc_info = sys.exc_info()
match = sys.exc_info()[1]
sys_exception = match = sys.exception()
else:
if rest_template:
self.fail("Exception not raised")
except BaseException as e:
rest = e
self.assertExceptionIsLike(match, match_template)
if match_template:
self.assertEqual(exc_info[0], type(match_template))
self.assertExceptionIsLike(rest, rest_template)
self.assertEqual(sys.exc_info(), initial_exc_info)
self.assertEqual(sys.exception(), initial_sys_exception)
def doSplitTestInExceptHandler(self, exc, T, match_template, rest_template):
try:
@ -409,11 +403,11 @@ class TestExceptStarSplitSemantics(ExceptStarTest):
try:
raise ExceptionGroup("mmu", [OSError("os"), BlockingIOError("io")])
except* BlockingIOError:
e = sys.exc_info()[1]
e = sys.exception()
self.assertExceptionIsLike(e,
ExceptionGroup("mmu", [BlockingIOError("io")]))
except* OSError:
e = sys.exc_info()[1]
e = sys.exception()
self.assertExceptionIsLike(e,
ExceptionGroup("mmu", [OSError("os")]))
else:
@ -434,7 +428,7 @@ class TestExceptStarSplitSemantics(ExceptStarTest):
try:
raise ExceptionGroup("fstu", [BlockingIOError("io")])
except* OSError:
e = sys.exc_info()[1]
e = sys.exception()
self.assertExceptionIsLike(e,
ExceptionGroup("fstu", [BlockingIOError("io")]))
except* BlockingIOError:
@ -452,7 +446,7 @@ class TestExceptStarSplitSemantics(ExceptStarTest):
pass
else:
self.fail("Exception not raised")
e = sys.exc_info()[1]
e = sys.exception()
self.assertExceptionIsLike(e,
ExceptionGroup("n", [BlockingIOError("io")]))
else:
@ -766,7 +760,7 @@ class TestExceptStarRaiseFrom(ExceptStarTest):
try:
raise orig
except* OSError:
e = sys.exc_info()[1]
e = sys.exception()
raise TypeError(3) from e
except ExceptionGroup as e:
exc = e
@ -821,7 +815,7 @@ class TestExceptStarRaiseFrom(ExceptStarTest):
try:
raise orig
except* (TypeError, ValueError) as e:
e = sys.exc_info()[1]
e = sys.exception()
raise SyntaxError(3) from e
except ExceptionGroup as e:
exc = e
@ -882,10 +876,10 @@ class TestExceptStarRaiseFrom(ExceptStarTest):
try:
raise orig
except* TypeError:
e = sys.exc_info()[1]
e = sys.exception()
raise SyntaxError(3) from e
except* ValueError:
e = sys.exc_info()[1]
e = sys.exception()
raise SyntaxError(4) from e
except ExceptionGroup as e:
exc = e
@ -982,7 +976,7 @@ class TestExceptStarExceptionGroupSubclass(ExceptStarTest):
class TestExceptStarCleanup(ExceptStarTest):
def test_exc_info_restored(self):
def test_sys_exception_restored(self):
try:
try:
raise ValueError(42)
@ -997,7 +991,7 @@ class TestExceptStarCleanup(ExceptStarTest):
self.assertExceptionIsLike(exc, ZeroDivisionError('division by zero'))
self.assertExceptionIsLike(exc.__context__, ValueError(42))
self.assertEqual(sys.exc_info(), (None, None, None))
self.assertEqual(sys.exception(), None)
class TestExceptStar_WeirdLeafExceptions(ExceptStarTest):