Kaydet (Commit) db1bd5c2 authored tarafından Fred Drake's avatar Fred Drake

Revise tests to support str(<long int object>) not appending "L".

üst b06007a3
...@@ -209,7 +209,7 @@ if sys.spam != 1: raise TestFailed, 'setattr(sys, \'spam\', 1)' ...@@ -209,7 +209,7 @@ if sys.spam != 1: raise TestFailed, 'setattr(sys, \'spam\', 1)'
print 'str' print 'str'
if str('') <> '': raise TestFailed, 'str(\'\')' if str('') <> '': raise TestFailed, 'str(\'\')'
if str(0) <> '0': raise TestFailed, 'str(0)' if str(0) <> '0': raise TestFailed, 'str(0)'
if str(0L) <> '0L': raise TestFailed, 'str(0L)' if str(0L) <> '0': raise TestFailed, 'str(0L)'
if str(()) <> '()': raise TestFailed, 'str(())' if str(()) <> '()': raise TestFailed, 'str(())'
if str([]) <> '[]': raise TestFailed, 'str([])' if str([]) <> '[]': raise TestFailed, 'str([])'
if str({}) <> '{}': raise TestFailed, 'str({})' if str({}) <> '{}': raise TestFailed, 'str({})'
......
...@@ -159,7 +159,7 @@ def test_bitop_identities(maxdigits=MAXDIGITS): ...@@ -159,7 +159,7 @@ def test_bitop_identities(maxdigits=MAXDIGITS):
test_bitop_identities_2(x, y) test_bitop_identities_2(x, y)
test_bitop_identities_3(x, y, getran((lenx + leny)/2)) test_bitop_identities_3(x, y, getran((lenx + leny)/2))
# ------------------------------------------------------ hex oct str atol # ------------------------------------------------- hex oct repr str atol
def slow_format(x, base): def slow_format(x, base):
if (x, base) == (0, 8): if (x, base) == (0, 8):
...@@ -181,12 +181,18 @@ def slow_format(x, base): ...@@ -181,12 +181,18 @@ def slow_format(x, base):
def test_format_1(x): def test_format_1(x):
from string import atol from string import atol
for base, mapper in (8, oct), (10, str), (16, hex): for base, mapper in (8, oct), (10, repr), (16, hex):
got = mapper(x) got = mapper(x)
expected = slow_format(x, base) expected = slow_format(x, base)
check(got == expected, mapper.__name__, "returned", check(got == expected, mapper.__name__, "returned",
got, "but expected", expected, "for", x) got, "but expected", expected, "for", x)
check(atol(got, 0) == x, 'atol("%s", 0) !=' % got, x) check(atol(got, 0) == x, 'atol("%s", 0) !=' % got, x)
# str() has to be checked a little differently since there's no
# trailing "L"
got = str(x)
expected = slow_format(x, 10)[:-1]
check(got == expected, mapper.__name__, "returned",
got, "but expected", expected, "for", x)
def test_format(maxdigits=MAXDIGITS): def test_format(maxdigits=MAXDIGITS):
print "long str/hex/oct/atol" print "long str/hex/oct/atol"
......
...@@ -56,20 +56,20 @@ powtest(float) ...@@ -56,20 +56,20 @@ powtest(float)
# Other tests-- not very systematic # Other tests-- not very systematic
print 'The number in both columns should match.' print 'The number in both columns should match.'
print pow(3,3) % 8, pow(3,3,8) print `pow(3,3) % 8`, `pow(3,3,8)`
print pow(3,3) % -8, pow(3,3,-8) print `pow(3,3) % -8`, `pow(3,3,-8)`
print pow(3,2) % -2, pow(3,2,-2) print `pow(3,2) % -2`, `pow(3,2,-2)`
print pow(-3,3) % 8, pow(-3,3,8) print `pow(-3,3) % 8`, `pow(-3,3,8)`
print pow(-3,3) % -8, pow(-3,3,-8) print `pow(-3,3) % -8`, `pow(-3,3,-8)`
print pow(5,2) % -8, pow(5,2,-8) print `pow(5,2) % -8`, `pow(5,2,-8)`
print print
print pow(3L,3L) % 8, pow(3L,3L,8) print `pow(3L,3L) % 8`, `pow(3L,3L,8)`
print pow(3L,3L) % -8, pow(3L,3L,-8) print `pow(3L,3L) % -8`, `pow(3L,3L,-8)`
print pow(3L,2) % -2, pow(3L,2,-2) print `pow(3L,2) % -2`, `pow(3L,2,-2)`
print pow(-3L,3L) % 8, pow(-3L,3L,8) print `pow(-3L,3L) % 8`, `pow(-3L,3L,8)`
print pow(-3L,3L) % -8, pow(-3L,3L,-8) print `pow(-3L,3L) % -8`, `pow(-3L,3L,-8)`
print pow(5L,2) % -8, pow(5L,2,-8) print `pow(5L,2) % -8`, `pow(5L,2,-8)`
print print
print pow(3.0,3.0) % 8, pow(3.0,3.0,8) print pow(3.0,3.0) % 8, pow(3.0,3.0,8)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment