changeset: 80017:22c8e6d71529 parent: 80012:1ecef550d744 parent: 80016:79ea0c84152a user: Mark Dickinson date: Sun Oct 28 10:23:08 2012 +0000 files: Lib/test/test_unicode.py Misc/NEWS Objects/unicodeobject.c description: Issue #14700: merge tests from 3.3. diff -r 1ecef550d744 -r 22c8e6d71529 Lib/test/test_unicode.py --- a/Lib/test/test_unicode.py Sun Oct 28 10:51:52 2012 +0100 +++ b/Lib/test/test_unicode.py Sun Oct 28 10:23:08 2012 +0000 @@ -981,6 +981,21 @@ self.assertRaises(ValueError, '{}'.format_map, 'a') self.assertRaises(ValueError, '{a} {}'.format_map, {"a" : 2, "b" : 1}) + def test_format_huge_precision(self): + format_string = ".{}f".format(sys.maxsize + 1) + with self.assertRaises(ValueError): + result = format(2.34, format_string) + + def test_format_huge_width(self): + format_string = "{}f".format(sys.maxsize + 1) + with self.assertRaises(ValueError): + result = format(2.34, format_string) + + def test_format_huge_item_number(self): + format_string = "{{{}:.6f}}".format(sys.maxsize + 1) + with self.assertRaises(ValueError): + result = format_string.format(2.34) + def test_format_auto_numbering(self): class C: def __init__(self, x=100): @@ -1069,6 +1084,18 @@ self.assertEqual('%.1s' % "a\xe9\u20ac", 'a') self.assertEqual('%.2s' % "a\xe9\u20ac", 'a\xe9') + @support.cpython_only + def test_formatting_huge_precision(self): + from _testcapi import INT_MAX + format_string = "%.{}f".format(INT_MAX + 1) + with self.assertRaises(ValueError): + result = format_string % 2.34 + + def test_formatting_huge_width(self): + format_string = "%{}f".format(sys.maxsize + 1) + with self.assertRaises(ValueError): + result = format_string % 2.34 + def test_startswith_endswith_errors(self): for meth in ('foo'.startswith, 'foo'.endswith): with self.assertRaises(TypeError) as cm:

AltStyle によって変換されたページ (->オリジナル) /