From: Georg Brandl Date: Sun, 24 Sep 2006 12:50:24 +0000 (+0000) Subject: Fix a bug in traceback.format_exception_only() that led to an error X-Git-Tag: v2.6a1~2637 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=c7986cee76cf2ffd6f8351fa8a65ce658825f70a;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. --- 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 ae14e8ffd9..c1a3a6cc3c 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -56,6 +56,10 @@ Core and builtins 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).