From b71bd9b300b6dbab25adcc4a0d9db14763011e72 Mon Sep 17 00:00:00 2001 From: Ronny Pfannschmidt Date: Thu, 22 Nov 2018 20:43:58 +0100 Subject: [PATCH] fix #4386 - handle uninitialized exceptioninfo in repr/str --- changelog/4386.bugfix.rst | 1 + src/_pytest/_code/code.py | 15 +++++++++++---- testing/python/raises.py | 12 ++++++++++++ 3 files changed, 24 insertions(+), 4 deletions(-) create mode 100644 changelog/4386.bugfix.rst diff --git a/changelog/4386.bugfix.rst b/changelog/4386.bugfix.rst new file mode 100644 index 000000000..0367f3ddc --- /dev/null +++ b/changelog/4386.bugfix.rst @@ -0,0 +1 @@ +Handle uninitialized exceptioninfo in repr/str. diff --git a/src/_pytest/_code/code.py b/src/_pytest/_code/code.py index d06e24f00..26973c4e1 100644 --- a/src/_pytest/_code/code.py +++ b/src/_pytest/_code/code.py @@ -425,7 +425,10 @@ class ExceptionInfo(object): self.traceback = _pytest._code.Traceback(self.tb, excinfo=ref(self)) def __repr__(self): - return "" % (self.typename, len(self.traceback)) + try: + return "" % (self.typename, len(self.traceback)) + except AttributeError: + return "" def exconly(self, tryshort=False): """ return the exception as a string @@ -513,9 +516,13 @@ class ExceptionInfo(object): return fmt.repr_excinfo(self) def __str__(self): - entry = self.traceback[-1] - loc = ReprFileLocation(entry.path, entry.lineno + 1, self.exconly()) - return str(loc) + try: + entry = self.traceback[-1] + except AttributeError: + return repr(self) + else: + loc = ReprFileLocation(entry.path, entry.lineno + 1, self.exconly()) + return str(loc) def __unicode__(self): entry = self.traceback[-1] diff --git a/testing/python/raises.py b/testing/python/raises.py index a72aeef63..527d688a2 100644 --- a/testing/python/raises.py +++ b/testing/python/raises.py @@ -33,6 +33,18 @@ class TestRaises(object): except pytest.raises.Exception: pass + def test_raises_repr_inflight(self): + with pytest.raises(RuntimeError) as excinfo: + # this test prints the inflight uninitialized object + # using repr and str as well as pprint to demonstrate + # it works + print(str(excinfo)) + print(repr(excinfo)) + import pprint + + pprint.pprint(excinfo) + raise RuntimeError(1) + def test_raises_as_contextmanager(self, testdir): testdir.makepyfile( """