blob: e655d1f6cbbaa88d437f97ccaa9ec82256b06d5d [file] [log] [blame]
Guido van Rossum447b4a01999-03-26 16:20:45 +00001# Check every path through every method of UserList
2
3from UserList import UserList
Tim Petersf5fa0fc2000-09-19 20:31:24 +00004from test_support import TestFailed
5
Fredrik Lundhf7850422001-01-17 21:51:36 +00006# Use check instead of assert so -O doesn't render the
Tim Petersf5fa0fc2000-09-19 20:31:24 +00007# test useless.
Fredrik Lundhf7850422001-01-17 21:51:36 +00008# XXX: could use the verify function in test_support instead
Tim Petersf5fa0fc2000-09-19 20:31:24 +00009def check(predicate, msg):
10 if not predicate:
11 raise TestFailed(msg + " failed")
Guido van Rossum447b4a01999-03-26 16:20:45 +000012
13l0 = []
14l1 = [0]
15l2 = [0, 1]
16
17# Test constructors
18
19u = UserList()
20u0 = UserList(l0)
21u1 = UserList(l1)
22u2 = UserList(l2)
23
24uu = UserList(u)
25uu0 = UserList(u0)
26uu1 = UserList(u1)
27uu2 = UserList(u2)
28
Jeremy Hylton6a973c72000-03-31 00:17:46 +000029v = UserList(tuple(u))
30class OtherList:
31 def __init__(self, initlist):
32 self.__data = initlist
33 def __len__(self):
34 return len(self.__data)
35 def __getitem__(self, i):
36 return self.__data[i]
37v0 = UserList(OtherList(u0))
38vv = UserList("this is also a sequence")
39
Guido van Rossum447b4a01999-03-26 16:20:45 +000040# Test __repr__
41
Tim Petersf5fa0fc2000-09-19 20:31:24 +000042check(str(u0) == str(l0), "str(u0) == str(l0)")
43check(repr(u1) == repr(l1), "repr(u1) == repr(l1)")
44check(`u2` == `l2`, "`u2` == `l2`")
Guido van Rossum447b4a01999-03-26 16:20:45 +000045
46# Test __cmp__ and __len__
47
48def mycmp(a, b):
49 r = cmp(a, b)
50 if r < 0: return -1
51 if r > 0: return 1
52 return r
53
54all = [l0, l1, l2, u, u0, u1, u2, uu, uu0, uu1, uu2]
55for a in all:
56 for b in all:
Tim Petersf5fa0fc2000-09-19 20:31:24 +000057 check(mycmp(a, b) == mycmp(len(a), len(b)),
58 "mycmp(a, b) == mycmp(len(a), len(b))")
Guido van Rossum447b4a01999-03-26 16:20:45 +000059
60# Test __getitem__
61
62for i in range(len(u2)):
Tim Petersf5fa0fc2000-09-19 20:31:24 +000063 check(u2[i] == i, "u2[i] == i")
Guido van Rossum447b4a01999-03-26 16:20:45 +000064
65# Test __setitem__
66
67uu2[0] = 0
68uu2[1] = 100
69try:
70 uu2[2] = 200
71except IndexError:
72 pass
73else:
Tim Petersf5fa0fc2000-09-19 20:31:24 +000074 raise TestFailed("uu2[2] shouldn't be assignable")
Guido van Rossum447b4a01999-03-26 16:20:45 +000075
76# Test __delitem__
77
78del uu2[1]
79del uu2[0]
80try:
81 del uu2[0]
82except IndexError:
83 pass
84else:
Tim Petersf5fa0fc2000-09-19 20:31:24 +000085 raise TestFailed("uu2[0] shouldn't be deletable")
Guido van Rossum447b4a01999-03-26 16:20:45 +000086
87# Test __getslice__
88
89for i in range(-3, 4):
Tim Petersf5fa0fc2000-09-19 20:31:24 +000090 check(u2[:i] == l2[:i], "u2[:i] == l2[:i]")
91 check(u2[i:] == l2[i:], "u2[i:] == l2[i:]")
Guido van Rossum447b4a01999-03-26 16:20:45 +000092 for j in range(-3, 4):
Tim Petersf5fa0fc2000-09-19 20:31:24 +000093 check(u2[i:j] == l2[i:j], "u2[i:j] == l2[i:j]")
Guido van Rossum447b4a01999-03-26 16:20:45 +000094
95# Test __setslice__
96
97for i in range(-3, 4):
98 u2[:i] = l2[:i]
Tim Petersf5fa0fc2000-09-19 20:31:24 +000099 check(u2 == l2, "u2 == l2")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000100 u2[i:] = l2[i:]
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000101 check(u2 == l2, "u2 == l2")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000102 for j in range(-3, 4):
103 u2[i:j] = l2[i:j]
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000104 check(u2 == l2, "u2 == l2")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000105
106uu2 = u2[:]
107uu2[:0] = [-2, -1]
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000108check(uu2 == [-2, -1, 0, 1], "uu2 == [-2, -1, 0, 1]")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000109uu2[0:] = []
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000110check(uu2 == [], "uu2 == []")
111
112# Test __contains__
113for i in u2:
114 check(i in u2, "i in u2")
115for i in min(u2)-1, max(u2)+1:
116 check(i not in u2, "i not in u2")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000117
118# Test __delslice__
119
120uu2 = u2[:]
121del uu2[1:2]
122del uu2[0:1]
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000123check(uu2 == [], "uu2 == []")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000124
125uu2 = u2[:]
126del uu2[1:]
127del uu2[:1]
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000128check(uu2 == [], "uu2 == []")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000129
130# Test __add__, __radd__, __mul__ and __rmul__
131
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000132check(u1 + [] == [] + u1 == u1, "u1 + [] == [] + u1 == u1")
133check(u1 + [1] == u2, "u1 + [1] == u2")
134check([-1] + u1 == [-1, 0], "[-1] + u1 == [-1, 0]")
135check(u2 == u2*1 == 1*u2, "u2 == u2*1 == 1*u2")
136check(u2+u2 == u2*2 == 2*u2, "u2+u2 == u2*2 == 2*u2")
137check(u2+u2+u2 == u2*3 == 3*u2, "u2+u2+u2 == u2*3 == 3*u2")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000138
139# Test append
140
141u = u1[:]
142u.append(1)
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000143check(u == u2, "u == u2")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000144
145# Test insert
146
147u = u2[:]
148u.insert(0, -1)
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000149check(u == [-1, 0, 1], "u == [-1, 0, 1]")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000150
151# Test pop
152
153u = [-1] + u2
154u.pop()
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000155check(u == [-1, 0], "u == [-1, 0]")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000156u.pop(0)
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000157check(u == [0], "u == [0]")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000158
159# Test remove
160
161u = u2[:]
162u.remove(1)
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000163check(u == u1, "u == u1")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000164
165# Test count
166u = u2*3
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000167check(u.count(0) == 3, "u.count(0) == 3")
168check(u.count(1) == 3, "u.count(1) == 3")
169check(u.count(2) == 0, "u.count(2) == 0")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000170
171
172# Test index
173
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000174check(u2.index(0) == 0, "u2.index(0) == 0")
175check(u2.index(1) == 1, "u2.index(1) == 1")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000176try:
177 u2.index(2)
178except ValueError:
179 pass
180else:
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000181 raise TestFailed("expected ValueError")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000182
183# Test reverse
184
185u = u2[:]
186u.reverse()
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000187check(u == [1, 0], "u == [1, 0]")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000188u.reverse()
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000189check(u == u2, "u == u2")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000190
191# Test sort
192
193u = UserList([1, 0])
194u.sort()
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000195check(u == u2, "u == u2")
Guido van Rossum447b4a01999-03-26 16:20:45 +0000196
197# Test extend
198
199u = u1[:]
200u.extend(u2)
Tim Petersf5fa0fc2000-09-19 20:31:24 +0000201check(u == u1 + u2, "u == u1 + u2")