summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy/testing/assertions.py
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2021-06-02 23:07:28 -0400
committerMike Bayer <mike_mp@zzzcomputing.com>2021-06-02 23:07:28 -0400
commitdcdc9442ed94f0857a62de40e17e588250f0576e (patch)
treec05d872d6d16f066bd04ba27aeeec6b9d1887d16 /lib/sqlalchemy/testing/assertions.py
parentcf8c76b9fcfcd1e79da4b089e7a86d6300d737e1 (diff)
downloadsqlalchemy-dcdc9442ed94f0857a62de40e17e588250f0576e.tar.gz
delete exception traceback in _expect_raises
a new segfault is observed in python 3.10.0b2 in conjunction with asyncio and possibly greenlet. Ensuring the traceback object is deleted from scope here, which is a good idea anyway, apparently seems to resolve the issue. Change-Id: Ia83bafb088ef19853044f1d436db259cbfd1e5f4 References: https://github.com/python-greenlet/greenlet/issues/242
Diffstat (limited to 'lib/sqlalchemy/testing/assertions.py')
-rw-r--r--lib/sqlalchemy/testing/assertions.py7
1 files changed, 7 insertions, 0 deletions
diff --git a/lib/sqlalchemy/testing/assertions.py b/lib/sqlalchemy/testing/assertions.py
index 9ff2f76eb..b618021a6 100644
--- a/lib/sqlalchemy/testing/assertions.py
+++ b/lib/sqlalchemy/testing/assertions.py
@@ -372,6 +372,13 @@ def _expect_raises(except_cls, msg=None, check_context=False):
_assert_proper_exception_context(err)
print(util.text_type(err).encode("utf-8"))
+ # it's generally a good idea to not carry traceback objects outside
+ # of the except: block, but in this case especially we seem to have
+ # hit some bug in either python 3.10.0b2 or greenlet or both which
+ # this seems to fix:
+ # https://github.com/python-greenlet/greenlet/issues/242
+ del ec
+
# assert outside the block so it works for AssertionError too !
assert success, "Callable did not raise an exception"