test_userlist.py 3.78 KB
Newer Older
1 2 3
# Check every path through every method of UserList

from UserList import UserList
4
from test.test_support import TestFailed
Tim Peters's avatar
Tim Peters committed
5

6
# Use check instead of assert so -O doesn't render the
Tim Peters's avatar
Tim Peters committed
7
# test useless.
8
# XXX: could use the verify function in test_support instead
Tim Peters's avatar
Tim Peters committed
9 10 11
def check(predicate, msg):
    if not predicate:
        raise TestFailed(msg + " failed")
12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28

l0 = []
l1 = [0]
l2 = [0, 1]

# Test constructors

u = UserList()
u0 = UserList(l0)
u1 = UserList(l1)
u2 = UserList(l2)

uu = UserList(u)
uu0 = UserList(u0)
uu1 = UserList(u1)
uu2 = UserList(u2)

29 30 31 32 33 34 35 36 37 38 39
v = UserList(tuple(u))
class OtherList:
    def __init__(self, initlist):
        self.__data = initlist
    def __len__(self):
        return len(self.__data)
    def __getitem__(self, i):
        return self.__data[i]
v0 = UserList(OtherList(u0))
vv = UserList("this is also a sequence")

40 41
# Test __repr__

Tim Peters's avatar
Tim Peters committed
42 43 44
check(str(u0) == str(l0), "str(u0) == str(l0)")
check(repr(u1) == repr(l1), "repr(u1) == repr(l1)")
check(`u2` == `l2`, "`u2` == `l2`")
45 46 47 48 49 50 51 52 53 54 55 56

# Test __cmp__ and __len__

def mycmp(a, b):
    r = cmp(a, b)
    if r < 0: return -1
    if r > 0: return 1
    return r

all = [l0, l1, l2, u, u0, u1, u2, uu, uu0, uu1, uu2]
for a in all:
    for b in all:
Tim Peters's avatar
Tim Peters committed
57 58
        check(mycmp(a, b) == mycmp(len(a), len(b)),
              "mycmp(a, b) == mycmp(len(a), len(b))")
59 60 61 62

# Test __getitem__

for i in range(len(u2)):
Tim Peters's avatar
Tim Peters committed
63
    check(u2[i] == i, "u2[i] == i")
64 65 66 67 68 69 70 71 72 73

# Test __setitem__

uu2[0] = 0
uu2[1] = 100
try:
    uu2[2] = 200
except IndexError:
    pass
else:
Tim Peters's avatar
Tim Peters committed
74
    raise TestFailed("uu2[2] shouldn't be assignable")
75 76 77 78 79 80 81 82 83 84

# Test __delitem__

del uu2[1]
del uu2[0]
try:
    del uu2[0]
except IndexError:
    pass
else:
Tim Peters's avatar
Tim Peters committed
85
    raise TestFailed("uu2[0] shouldn't be deletable")
86 87 88 89

# Test __getslice__

for i in range(-3, 4):
Tim Peters's avatar
Tim Peters committed
90 91
    check(u2[:i] == l2[:i], "u2[:i] == l2[:i]")
    check(u2[i:] == l2[i:], "u2[i:] == l2[i:]")
92
    for j in range(-3, 4):
Tim Peters's avatar
Tim Peters committed
93
        check(u2[i:j] == l2[i:j], "u2[i:j] == l2[i:j]")
94 95 96 97 98

# Test __setslice__

for i in range(-3, 4):
    u2[:i] = l2[:i]
Tim Peters's avatar
Tim Peters committed
99
    check(u2 == l2, "u2 == l2")
100
    u2[i:] = l2[i:]
Tim Peters's avatar
Tim Peters committed
101
    check(u2 == l2, "u2 == l2")
102 103
    for j in range(-3, 4):
        u2[i:j] = l2[i:j]
Tim Peters's avatar
Tim Peters committed
104
        check(u2 == l2, "u2 == l2")
105 106 107

uu2 = u2[:]
uu2[:0] = [-2, -1]
Tim Peters's avatar
Tim Peters committed
108
check(uu2 == [-2, -1, 0, 1], "uu2 == [-2, -1, 0, 1]")
109
uu2[0:] = []
Tim Peters's avatar
Tim Peters committed
110 111 112 113 114 115 116
check(uu2 == [], "uu2 == []")

# Test __contains__
for i in u2:
    check(i in u2, "i in u2")
for i in min(u2)-1, max(u2)+1:
    check(i not in u2, "i not in u2")
117 118 119 120 121 122

# Test __delslice__

uu2 = u2[:]
del uu2[1:2]
del uu2[0:1]
Tim Peters's avatar
Tim Peters committed
123
check(uu2 == [], "uu2 == []")
124 125 126 127

uu2 = u2[:]
del uu2[1:]
del uu2[:1]
Tim Peters's avatar
Tim Peters committed
128
check(uu2 == [], "uu2 == []")
129 130 131

# Test __add__, __radd__, __mul__ and __rmul__

Tim Peters's avatar
Tim Peters committed
132 133 134 135 136 137
check(u1 + [] == [] + u1 == u1, "u1 + [] == [] + u1 == u1")
check(u1 + [1] == u2, "u1 + [1] == u2")
check([-1] + u1 == [-1, 0], "[-1] + u1 == [-1, 0]")
check(u2 == u2*1 == 1*u2, "u2 == u2*1 == 1*u2")
check(u2+u2 == u2*2 == 2*u2, "u2+u2 == u2*2 == 2*u2")
check(u2+u2+u2 == u2*3 == 3*u2, "u2+u2+u2 == u2*3 == 3*u2")
138 139 140 141 142

# Test append

u = u1[:]
u.append(1)
Tim Peters's avatar
Tim Peters committed
143
check(u == u2, "u == u2")
144 145 146 147 148

# Test insert

u = u2[:]
u.insert(0, -1)
Tim Peters's avatar
Tim Peters committed
149
check(u == [-1, 0, 1], "u == [-1, 0, 1]")
150 151 152 153 154

# Test pop

u = [-1] + u2
u.pop()
Tim Peters's avatar
Tim Peters committed
155
check(u == [-1, 0], "u == [-1, 0]")
156
u.pop(0)
Tim Peters's avatar
Tim Peters committed
157
check(u == [0], "u == [0]")
158 159 160 161 162

# Test remove

u = u2[:]
u.remove(1)
Tim Peters's avatar
Tim Peters committed
163
check(u == u1, "u == u1")
164 165 166

# Test count
u = u2*3
Tim Peters's avatar
Tim Peters committed
167 168 169
check(u.count(0) == 3, "u.count(0) == 3")
check(u.count(1) == 3, "u.count(1) == 3")
check(u.count(2) == 0, "u.count(2) == 0")
170 171 172 173


# Test index

Tim Peters's avatar
Tim Peters committed
174 175
check(u2.index(0) == 0, "u2.index(0) == 0")
check(u2.index(1) == 1, "u2.index(1) == 1")
176 177 178 179 180
try:
    u2.index(2)
except ValueError:
    pass
else:
Tim Peters's avatar
Tim Peters committed
181
    raise TestFailed("expected ValueError")
182 183 184 185 186

# Test reverse

u = u2[:]
u.reverse()
Tim Peters's avatar
Tim Peters committed
187
check(u == [1, 0], "u == [1, 0]")
188
u.reverse()
Tim Peters's avatar
Tim Peters committed
189
check(u == u2, "u == u2")
190 191 192 193 194

# Test sort

u = UserList([1, 0])
u.sort()
Tim Peters's avatar
Tim Peters committed
195
check(u == u2, "u == u2")
196 197 198 199 200

# Test extend

u = u1[:]
u.extend(u2)
Tim Peters's avatar
Tim Peters committed
201
check(u == u1 + u2, "u == u1 + u2")