From: Georg Brandl Date: Sun, 24 Sep 2006 12:50:28 +0000 (+0000) Subject: Fix a bug in traceback.format_exception_only() that led to an error X-Git-Tag: v2.5.1c1~374 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=edd81b2402ae7e3b1c4aa24f28f46567674d3a75;p=python Fix a bug in traceback.format_exception_only() that led to an error being raised when print_exc() was called without an exception set. In version 2.4, this printed "None", restored that behavior. (backport from rev. 51995) --- diff --git a/Lib/test/test_traceback.py b/Lib/test/test_traceback.py index b3c5a50958..b42dbc4df4 100644 --- a/Lib/test/test_traceback.py +++ b/Lib/test/test_traceback.py @@ -149,6 +149,10 @@ def test(): str_value = '' % X.__name__ self.assertEqual(err[0], X.__name__ + ': ' + str_value + '\n') + def test_without_exception(self): + err = traceback.format_exception_only(None, None) + self.assertEqual(err, ['None\n']) + def test_main(): run_unittest(TracebackCases) diff --git a/Lib/traceback.py b/Lib/traceback.py index 75e1fcffa3..31b8255379 100644 --- a/Lib/traceback.py +++ b/Lib/traceback.py @@ -170,7 +170,7 @@ def format_exception_only(etype, value): # would throw another exception and mask the original problem. if (isinstance(etype, BaseException) or isinstance(etype, types.InstanceType) or - type(etype) is str): + etype is None or type(etype) is str): return [_format_final_exc_line(etype, value)] stype = etype.__name__ diff --git a/Misc/NEWS b/Misc/NEWS index e930453ade..685daf6823 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -28,6 +28,10 @@ Extension Modules Library ------- +- Fix a bug in traceback.format_exception_only() that led to an error + being raised when print_exc() was called without an exception set. + In version 2.4, this printed "None", restored that behavior. + - Make webbrowser.BackgroundBrowser usable in Windows (it wasn't because the close_fds arg to subprocess.Popen is not supported).