mirror of
https://github.com/python/cpython.git
synced 2025-10-24 02:13:49 +00:00
Fix PyString_Format() so that '%c' % u'a' returns u'a'
instead of raising a TypeError. (From SF patch #710127) Add tests to verify this is fixed. Add various tests for '%c' % int.
This commit is contained in:
parent
2a04623ddd
commit
43440a621e
5 changed files with 18 additions and 0 deletions
|
@ -358,6 +358,8 @@ def test_formatting(self):
|
|||
self.assertEqual(u"%r, %r" % (u"abc", "abc"), u"u'abc', 'abc'")
|
||||
self.assertEqual(u"%(x)s, %(y)s" % {'x':u"abc", 'y':"def"}, u'abc, def')
|
||||
self.assertEqual(u"%(x)s, %(\xfc)s" % {'x':u"abc", u'\xfc':"def"}, u'abc, def')
|
||||
self.assertEqual(u'%c' % 0x1234, u'\u1234')
|
||||
self.assertRaises(ValueError, u'%c'.__mod__, sys.maxunicode+1)
|
||||
|
||||
# formatting jobs delegated from the string implementation:
|
||||
self.assertEqual('...%(foo)s...' % {'foo':u"abc"}, u'...abc...')
|
||||
|
@ -375,6 +377,7 @@ def test_formatting(self):
|
|||
self.assertEqual('%*.*s' % (5,3,u'abc',), u' abc')
|
||||
self.assertEqual('%i %*.*s' % (10, 5,3,u'abc',), u'10 abc')
|
||||
self.assertEqual('%i%s %*.*s' % (10, 3, 5, 3, u'abc',), u'103 abc')
|
||||
self.assertEqual('%c' % u'a', u'a')
|
||||
|
||||
self.assertRaises(ValueError, u"%c".__mod__, (sys.maxunicode+1,))
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue