Issue #8313: traceback.format_exception_only() encodes unicode message to

ASCII with backslashreplace error handler if str(value) failed
This commit is contained in:
Victor Stinner 2010-05-05 12:40:49 +00:00
parent f3c157f639
commit 926fd4ee32
3 changed files with 20 additions and 2 deletions

View File

@ -159,6 +159,15 @@ def test():
err = traceback.format_exception_only(None, None)
self.assertEqual(err, ['None\n'])
def test_unicode(self):
err = AssertionError('\xff')
lines = traceback.format_exception_only(type(err), err)
self.assertEqual(lines, ['AssertionError: \xff\n'])
err = AssertionError(u'\xe9')
lines = traceback.format_exception_only(type(err), err)
self.assertEqual(lines, ['AssertionError: \\xe9\n'])
class TracebackFormatTests(unittest.TestCase):

View File

@ -211,7 +211,13 @@ def _format_final_exc_line(etype, value):
def _some_str(value):
try:
return str(value)
except:
except Exception:
pass
try:
value = unicode(value)
return value.encode("ascii", "backslashreplace")
except Exception:
pass
return '<unprintable %s object>' % type(value).__name__

View File

@ -39,6 +39,9 @@ Core and Builtins
Library
-------
- Issue #8313: traceback.format_exception_only() encodes unicode message to
ASCII with backslashreplace error handler if str(value) failed
- Issue #8567: Fix precedence of signals in Decimal module: when a
Decimal operation raises multiple signals and more than one of those
signals is trapped, the specification determines the order in which