mirror of https://github.com/python/cpython
Merged revisions 80777 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r80777 | victor.stinner | 2010-05-05 14:40:49 +0200 (mer., 05 mai 2010) | 3 lines Issue #8313: traceback.format_exception_only() encodes unicode message to ASCII with backslashreplace error handler if str(value) failed ........
This commit is contained in:
parent
2dd131d535
commit
7c8eaad1bf
|
@ -168,6 +168,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):
|
||||
|
||||
|
|
|
@ -212,8 +212,14 @@ def _format_final_exc_line(etype, value):
|
|||
def _some_str(value):
|
||||
try:
|
||||
return str(value)
|
||||
except:
|
||||
return '<unprintable %s object>' % type(value).__name__
|
||||
except Exception:
|
||||
pass
|
||||
try:
|
||||
value = unicode(value)
|
||||
return value.encode("ascii", "backslashreplace")
|
||||
except Exception:
|
||||
pass
|
||||
return '<unprintable %s object>' % type(value).__name__
|
||||
|
||||
|
||||
def print_exc(limit=None, file=None):
|
||||
|
|
|
@ -33,6 +33,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
|
||||
|
|
Loading…
Reference in New Issue