mirror of
https://github.com/python/cpython.git
synced 2025-08-04 00:48:58 +00:00
Make str/str8 comparisons return True/False for !=/==.
Code that has been returning str8 becomes much more apparent thanks to this (e.g., struct module returning str8 for all string-related formats or sqlite3 passing in str8 instances when converting objects that had a __conform__ method). One also has to watch out in C code when making a key from char * using PyString in the C code but a str instance in Python code as that will not longer compare equal. Once str8 gains a constructor like the current bytes type then test_modulefinder needs a cleanup as the fix is a little messy in that file. Thanks goes to Thomas Lee for writing the patch for the change giving an initial run-down of why most of the tests were failing.
This commit is contained in:
parent
6464d47195
commit
4043001f5d
11 changed files with 167 additions and 203 deletions
|
@ -39,163 +39,158 @@ def testformat(formatstr, args, output=None):
|
|||
if verbose:
|
||||
print('yes')
|
||||
|
||||
def testboth(formatstr, *args):
|
||||
testformat(str8(formatstr), *args)
|
||||
testformat(formatstr, *args)
|
||||
testformat("%.1d", (1,), "1")
|
||||
testformat("%.*d", (sys.maxint,1)) # expect overflow
|
||||
testformat("%.100d", (1,), '0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001')
|
||||
testformat("%#.117x", (1,), '0x000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001')
|
||||
testformat("%#.118x", (1,), '0x0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001')
|
||||
|
||||
|
||||
testboth("%.1d", (1,), "1")
|
||||
testboth("%.*d", (sys.maxint,1)) # expect overflow
|
||||
testboth("%.100d", (1,), '0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001')
|
||||
testboth("%#.117x", (1,), '0x000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001')
|
||||
testboth("%#.118x", (1,), '0x0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001')
|
||||
|
||||
testboth("%f", (1.0,), "1.000000")
|
||||
testformat("%f", (1.0,), "1.000000")
|
||||
# these are trying to test the limits of the internal magic-number-length
|
||||
# formatting buffer, if that number changes then these tests are less
|
||||
# effective
|
||||
testboth("%#.*g", (109, -1.e+49/3.))
|
||||
testboth("%#.*g", (110, -1.e+49/3.))
|
||||
testboth("%#.*g", (110, -1.e+100/3.))
|
||||
testformat("%#.*g", (109, -1.e+49/3.))
|
||||
testformat("%#.*g", (110, -1.e+49/3.))
|
||||
testformat("%#.*g", (110, -1.e+100/3.))
|
||||
|
||||
# test some ridiculously large precision, expect overflow
|
||||
testboth('%12.*f', (123456, 1.0))
|
||||
testformat('%12.*f', (123456, 1.0))
|
||||
|
||||
# check for internal overflow validation on length of precision
|
||||
overflowrequired = 1
|
||||
testboth("%#.*g", (110, -1.e+100/3.))
|
||||
testboth("%#.*G", (110, -1.e+100/3.))
|
||||
testboth("%#.*f", (110, -1.e+100/3.))
|
||||
testboth("%#.*F", (110, -1.e+100/3.))
|
||||
testformat("%#.*g", (110, -1.e+100/3.))
|
||||
testformat("%#.*G", (110, -1.e+100/3.))
|
||||
testformat("%#.*f", (110, -1.e+100/3.))
|
||||
testformat("%#.*F", (110, -1.e+100/3.))
|
||||
overflowrequired = 0
|
||||
|
||||
# Formatting of long integers. Overflow is not ok
|
||||
overflowok = 0
|
||||
testboth("%x", 10, "a")
|
||||
testboth("%x", 100000000000, "174876e800")
|
||||
testboth("%o", 10, "12")
|
||||
testboth("%o", 100000000000, "1351035564000")
|
||||
testboth("%d", 10, "10")
|
||||
testboth("%d", 100000000000, "100000000000")
|
||||
testformat("%x", 10, "a")
|
||||
testformat("%x", 100000000000, "174876e800")
|
||||
testformat("%o", 10, "12")
|
||||
testformat("%o", 100000000000, "1351035564000")
|
||||
testformat("%d", 10, "10")
|
||||
testformat("%d", 100000000000, "100000000000")
|
||||
|
||||
big = 123456789012345678901234567890
|
||||
testboth("%d", big, "123456789012345678901234567890")
|
||||
testboth("%d", -big, "-123456789012345678901234567890")
|
||||
testboth("%5d", -big, "-123456789012345678901234567890")
|
||||
testboth("%31d", -big, "-123456789012345678901234567890")
|
||||
testboth("%32d", -big, " -123456789012345678901234567890")
|
||||
testboth("%-32d", -big, "-123456789012345678901234567890 ")
|
||||
testboth("%032d", -big, "-0123456789012345678901234567890")
|
||||
testboth("%-032d", -big, "-123456789012345678901234567890 ")
|
||||
testboth("%034d", -big, "-000123456789012345678901234567890")
|
||||
testboth("%034d", big, "0000123456789012345678901234567890")
|
||||
testboth("%0+34d", big, "+000123456789012345678901234567890")
|
||||
testboth("%+34d", big, " +123456789012345678901234567890")
|
||||
testboth("%34d", big, " 123456789012345678901234567890")
|
||||
testboth("%.2d", big, "123456789012345678901234567890")
|
||||
testboth("%.30d", big, "123456789012345678901234567890")
|
||||
testboth("%.31d", big, "0123456789012345678901234567890")
|
||||
testboth("%32.31d", big, " 0123456789012345678901234567890")
|
||||
testformat("%d", big, "123456789012345678901234567890")
|
||||
testformat("%d", -big, "-123456789012345678901234567890")
|
||||
testformat("%5d", -big, "-123456789012345678901234567890")
|
||||
testformat("%31d", -big, "-123456789012345678901234567890")
|
||||
testformat("%32d", -big, " -123456789012345678901234567890")
|
||||
testformat("%-32d", -big, "-123456789012345678901234567890 ")
|
||||
testformat("%032d", -big, "-0123456789012345678901234567890")
|
||||
testformat("%-032d", -big, "-123456789012345678901234567890 ")
|
||||
testformat("%034d", -big, "-000123456789012345678901234567890")
|
||||
testformat("%034d", big, "0000123456789012345678901234567890")
|
||||
testformat("%0+34d", big, "+000123456789012345678901234567890")
|
||||
testformat("%+34d", big, " +123456789012345678901234567890")
|
||||
testformat("%34d", big, " 123456789012345678901234567890")
|
||||
testformat("%.2d", big, "123456789012345678901234567890")
|
||||
testformat("%.30d", big, "123456789012345678901234567890")
|
||||
testformat("%.31d", big, "0123456789012345678901234567890")
|
||||
testformat("%32.31d", big, " 0123456789012345678901234567890")
|
||||
|
||||
big = 0x1234567890abcdef12345 # 21 hex digits
|
||||
testboth("%x", big, "1234567890abcdef12345")
|
||||
testboth("%x", -big, "-1234567890abcdef12345")
|
||||
testboth("%5x", -big, "-1234567890abcdef12345")
|
||||
testboth("%22x", -big, "-1234567890abcdef12345")
|
||||
testboth("%23x", -big, " -1234567890abcdef12345")
|
||||
testboth("%-23x", -big, "-1234567890abcdef12345 ")
|
||||
testboth("%023x", -big, "-01234567890abcdef12345")
|
||||
testboth("%-023x", -big, "-1234567890abcdef12345 ")
|
||||
testboth("%025x", -big, "-0001234567890abcdef12345")
|
||||
testboth("%025x", big, "00001234567890abcdef12345")
|
||||
testboth("%0+25x", big, "+0001234567890abcdef12345")
|
||||
testboth("%+25x", big, " +1234567890abcdef12345")
|
||||
testboth("%25x", big, " 1234567890abcdef12345")
|
||||
testboth("%.2x", big, "1234567890abcdef12345")
|
||||
testboth("%.21x", big, "1234567890abcdef12345")
|
||||
testboth("%.22x", big, "01234567890abcdef12345")
|
||||
testboth("%23.22x", big, " 01234567890abcdef12345")
|
||||
testboth("%-23.22x", big, "01234567890abcdef12345 ")
|
||||
testboth("%X", big, "1234567890ABCDEF12345")
|
||||
testboth("%#X", big, "0X1234567890ABCDEF12345")
|
||||
testboth("%#x", big, "0x1234567890abcdef12345")
|
||||
testboth("%#x", -big, "-0x1234567890abcdef12345")
|
||||
testboth("%#.23x", -big, "-0x001234567890abcdef12345")
|
||||
testboth("%#+.23x", big, "+0x001234567890abcdef12345")
|
||||
testboth("%# .23x", big, " 0x001234567890abcdef12345")
|
||||
testboth("%#+.23X", big, "+0X001234567890ABCDEF12345")
|
||||
testboth("%#-+.23X", big, "+0X001234567890ABCDEF12345")
|
||||
testboth("%#-+26.23X", big, "+0X001234567890ABCDEF12345")
|
||||
testboth("%#-+27.23X", big, "+0X001234567890ABCDEF12345 ")
|
||||
testboth("%#+27.23X", big, " +0X001234567890ABCDEF12345")
|
||||
testformat("%x", big, "1234567890abcdef12345")
|
||||
testformat("%x", -big, "-1234567890abcdef12345")
|
||||
testformat("%5x", -big, "-1234567890abcdef12345")
|
||||
testformat("%22x", -big, "-1234567890abcdef12345")
|
||||
testformat("%23x", -big, " -1234567890abcdef12345")
|
||||
testformat("%-23x", -big, "-1234567890abcdef12345 ")
|
||||
testformat("%023x", -big, "-01234567890abcdef12345")
|
||||
testformat("%-023x", -big, "-1234567890abcdef12345 ")
|
||||
testformat("%025x", -big, "-0001234567890abcdef12345")
|
||||
testformat("%025x", big, "00001234567890abcdef12345")
|
||||
testformat("%0+25x", big, "+0001234567890abcdef12345")
|
||||
testformat("%+25x", big, " +1234567890abcdef12345")
|
||||
testformat("%25x", big, " 1234567890abcdef12345")
|
||||
testformat("%.2x", big, "1234567890abcdef12345")
|
||||
testformat("%.21x", big, "1234567890abcdef12345")
|
||||
testformat("%.22x", big, "01234567890abcdef12345")
|
||||
testformat("%23.22x", big, " 01234567890abcdef12345")
|
||||
testformat("%-23.22x", big, "01234567890abcdef12345 ")
|
||||
testformat("%X", big, "1234567890ABCDEF12345")
|
||||
testformat("%#X", big, "0X1234567890ABCDEF12345")
|
||||
testformat("%#x", big, "0x1234567890abcdef12345")
|
||||
testformat("%#x", -big, "-0x1234567890abcdef12345")
|
||||
testformat("%#.23x", -big, "-0x001234567890abcdef12345")
|
||||
testformat("%#+.23x", big, "+0x001234567890abcdef12345")
|
||||
testformat("%# .23x", big, " 0x001234567890abcdef12345")
|
||||
testformat("%#+.23X", big, "+0X001234567890ABCDEF12345")
|
||||
testformat("%#-+.23X", big, "+0X001234567890ABCDEF12345")
|
||||
testformat("%#-+26.23X", big, "+0X001234567890ABCDEF12345")
|
||||
testformat("%#-+27.23X", big, "+0X001234567890ABCDEF12345 ")
|
||||
testformat("%#+27.23X", big, " +0X001234567890ABCDEF12345")
|
||||
# next one gets two leading zeroes from precision, and another from the
|
||||
# 0 flag and the width
|
||||
testboth("%#+027.23X", big, "+0X0001234567890ABCDEF12345")
|
||||
testformat("%#+027.23X", big, "+0X0001234567890ABCDEF12345")
|
||||
# same, except no 0 flag
|
||||
testboth("%#+27.23X", big, " +0X001234567890ABCDEF12345")
|
||||
testformat("%#+27.23X", big, " +0X001234567890ABCDEF12345")
|
||||
|
||||
big = 0o12345670123456701234567012345670 # 32 octal digits
|
||||
testboth("%o", big, "12345670123456701234567012345670")
|
||||
testboth("%o", -big, "-12345670123456701234567012345670")
|
||||
testboth("%5o", -big, "-12345670123456701234567012345670")
|
||||
testboth("%33o", -big, "-12345670123456701234567012345670")
|
||||
testboth("%34o", -big, " -12345670123456701234567012345670")
|
||||
testboth("%-34o", -big, "-12345670123456701234567012345670 ")
|
||||
testboth("%034o", -big, "-012345670123456701234567012345670")
|
||||
testboth("%-034o", -big, "-12345670123456701234567012345670 ")
|
||||
testboth("%036o", -big, "-00012345670123456701234567012345670")
|
||||
testboth("%036o", big, "000012345670123456701234567012345670")
|
||||
testboth("%0+36o", big, "+00012345670123456701234567012345670")
|
||||
testboth("%+36o", big, " +12345670123456701234567012345670")
|
||||
testboth("%36o", big, " 12345670123456701234567012345670")
|
||||
testboth("%.2o", big, "12345670123456701234567012345670")
|
||||
testboth("%.32o", big, "12345670123456701234567012345670")
|
||||
testboth("%.33o", big, "012345670123456701234567012345670")
|
||||
testboth("%34.33o", big, " 012345670123456701234567012345670")
|
||||
testboth("%-34.33o", big, "012345670123456701234567012345670 ")
|
||||
testboth("%o", big, "12345670123456701234567012345670")
|
||||
testboth("%#o", big, "0o12345670123456701234567012345670")
|
||||
testboth("%#o", -big, "-0o12345670123456701234567012345670")
|
||||
testboth("%#.34o", -big, "-0o0012345670123456701234567012345670")
|
||||
testboth("%#+.34o", big, "+0o0012345670123456701234567012345670")
|
||||
testboth("%# .34o", big, " 0o0012345670123456701234567012345670")
|
||||
testboth("%#-+.34o", big, "+0o0012345670123456701234567012345670")
|
||||
testboth("%#-+39.34o", big, "+0o0012345670123456701234567012345670 ")
|
||||
testboth("%#+39.34o", big, " +0o0012345670123456701234567012345670")
|
||||
testformat("%o", big, "12345670123456701234567012345670")
|
||||
testformat("%o", -big, "-12345670123456701234567012345670")
|
||||
testformat("%5o", -big, "-12345670123456701234567012345670")
|
||||
testformat("%33o", -big, "-12345670123456701234567012345670")
|
||||
testformat("%34o", -big, " -12345670123456701234567012345670")
|
||||
testformat("%-34o", -big, "-12345670123456701234567012345670 ")
|
||||
testformat("%034o", -big, "-012345670123456701234567012345670")
|
||||
testformat("%-034o", -big, "-12345670123456701234567012345670 ")
|
||||
testformat("%036o", -big, "-00012345670123456701234567012345670")
|
||||
testformat("%036o", big, "000012345670123456701234567012345670")
|
||||
testformat("%0+36o", big, "+00012345670123456701234567012345670")
|
||||
testformat("%+36o", big, " +12345670123456701234567012345670")
|
||||
testformat("%36o", big, " 12345670123456701234567012345670")
|
||||
testformat("%.2o", big, "12345670123456701234567012345670")
|
||||
testformat("%.32o", big, "12345670123456701234567012345670")
|
||||
testformat("%.33o", big, "012345670123456701234567012345670")
|
||||
testformat("%34.33o", big, " 012345670123456701234567012345670")
|
||||
testformat("%-34.33o", big, "012345670123456701234567012345670 ")
|
||||
testformat("%o", big, "12345670123456701234567012345670")
|
||||
testformat("%#o", big, "0o12345670123456701234567012345670")
|
||||
testformat("%#o", -big, "-0o12345670123456701234567012345670")
|
||||
testformat("%#.34o", -big, "-0o0012345670123456701234567012345670")
|
||||
testformat("%#+.34o", big, "+0o0012345670123456701234567012345670")
|
||||
testformat("%# .34o", big, " 0o0012345670123456701234567012345670")
|
||||
testformat("%#-+.34o", big, "+0o0012345670123456701234567012345670")
|
||||
testformat("%#-+39.34o", big, "+0o0012345670123456701234567012345670 ")
|
||||
testformat("%#+39.34o", big, " +0o0012345670123456701234567012345670")
|
||||
# next one gets one leading zero from precision
|
||||
testboth("%.33o", big, "012345670123456701234567012345670")
|
||||
testformat("%.33o", big, "012345670123456701234567012345670")
|
||||
# one leading zero from precision
|
||||
testboth("%#.33o", big, "0o012345670123456701234567012345670")
|
||||
testformat("%#.33o", big, "0o012345670123456701234567012345670")
|
||||
# leading zero vanishes
|
||||
testboth("%#.32o", big, "0o12345670123456701234567012345670")
|
||||
testformat("%#.32o", big, "0o12345670123456701234567012345670")
|
||||
# one leading zero from precision, and another from '0' flag & width
|
||||
testboth("%034.33o", big, "0012345670123456701234567012345670")
|
||||
testformat("%034.33o", big, "0012345670123456701234567012345670")
|
||||
# max width includes base marker; padding zeroes come after marker
|
||||
testboth("%0#38.33o", big, "0o000012345670123456701234567012345670")
|
||||
testformat("%0#38.33o", big, "0o000012345670123456701234567012345670")
|
||||
# padding spaces come before marker
|
||||
testboth("%#36.33o", big, " 0o012345670123456701234567012345670")
|
||||
testformat("%#36.33o", big, " 0o012345670123456701234567012345670")
|
||||
|
||||
# Some small ints, in both Python int and long flavors).
|
||||
testboth("%d", 42, "42")
|
||||
testboth("%d", -42, "-42")
|
||||
testboth("%#x", 1, "0x1")
|
||||
testboth("%#X", 1, "0X1")
|
||||
testboth("%#o", 1, "0o1")
|
||||
testboth("%#o", 1, "0o1")
|
||||
testboth("%#o", 0, "0o0")
|
||||
testboth("%#o", 0, "0o0")
|
||||
testboth("%o", 0, "0")
|
||||
testboth("%d", 0, "0")
|
||||
testboth("%#x", 0, "0x0")
|
||||
testboth("%#X", 0, "0X0")
|
||||
testformat("%d", 42, "42")
|
||||
testformat("%d", -42, "-42")
|
||||
testformat("%#x", 1, "0x1")
|
||||
testformat("%#X", 1, "0X1")
|
||||
testformat("%#o", 1, "0o1")
|
||||
testformat("%#o", 1, "0o1")
|
||||
testformat("%#o", 0, "0o0")
|
||||
testformat("%#o", 0, "0o0")
|
||||
testformat("%o", 0, "0")
|
||||
testformat("%d", 0, "0")
|
||||
testformat("%#x", 0, "0x0")
|
||||
testformat("%#X", 0, "0X0")
|
||||
|
||||
testboth("%x", 0x42, "42")
|
||||
testboth("%x", -0x42, "-42")
|
||||
testformat("%x", 0x42, "42")
|
||||
testformat("%x", -0x42, "-42")
|
||||
|
||||
testboth("%o", 0o42, "42")
|
||||
testboth("%o", -0o42, "-42")
|
||||
testboth("%o", 0o42, "42")
|
||||
testboth("%o", -0o42, "-42")
|
||||
testformat("%o", 0o42, "42")
|
||||
testformat("%o", -0o42, "-42")
|
||||
testformat("%o", 0o42, "42")
|
||||
testformat("%o", -0o42, "-42")
|
||||
|
||||
# Test exception for unknown format characters
|
||||
if verbose:
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue