blob: a92b4428a32ab801d782821d3e9de79e06088da9 [file] [log] [blame]
Armin Rigo5eca19b2006-03-30 11:28:43 +00001import unittest
2from test import test_support
3import operator
Neal Norwitz8a87f5d2006-08-12 17:03:09 +00004from sys import maxint
Kristján Valur Jónsson170eee92007-05-03 20:09:56 +00005maxsize = test_support.MAX_Py_ssize_t
6minsize = -maxsize-1
Armin Rigo5eca19b2006-03-30 11:28:43 +00007
8class oldstyle:
9 def __index__(self):
10 return self.ind
11
12class newstyle(object):
13 def __index__(self):
14 return self.ind
15
Neal Norwitz8a87f5d2006-08-12 17:03:09 +000016class TrapInt(int):
17 def __index__(self):
18 return self
19
20class TrapLong(long):
21 def __index__(self):
22 return self
23
Armin Rigo314861c2006-03-30 14:04:02 +000024class BaseTestCase(unittest.TestCase):
Armin Rigo5eca19b2006-03-30 11:28:43 +000025 def setUp(self):
Armin Rigo5eca19b2006-03-30 11:28:43 +000026 self.o = oldstyle()
27 self.n = newstyle()
Neal Norwitz8a87f5d2006-08-12 17:03:09 +000028
29 def test_basic(self):
30 self.o.ind = -2
31 self.n.ind = 2
32 self.assertEqual(operator.index(self.o), -2)
33 self.assertEqual(operator.index(self.n), 2)
Tim Petersc02c1c82006-08-15 00:25:04 +000034
Neal Norwitz8a87f5d2006-08-12 17:03:09 +000035 def test_slice(self):
36 self.o.ind = 1
37 self.n.ind = 2
38 slc = slice(self.o, self.o, self.o)
39 check_slc = slice(1, 1, 1)
40 self.assertEqual(slc.indices(self.o), check_slc.indices(1))
41 slc = slice(self.n, self.n, self.n)
42 check_slc = slice(2, 2, 2)
43 self.assertEqual(slc.indices(self.n), check_slc.indices(2))
44
45 def test_wrappers(self):
46 self.o.ind = 4
47 self.n.ind = 5
48 self.assertEqual(6 .__index__(), 6)
49 self.assertEqual(-7L.__index__(), -7)
50 self.assertEqual(self.o.__index__(), 4)
51 self.assertEqual(self.n.__index__(), 5)
Antoine Pitrou6032c252010-03-30 18:49:45 +000052 self.assertEqual(True.__index__(), 1)
53 self.assertEqual(False.__index__(), 0)
Neal Norwitz8a87f5d2006-08-12 17:03:09 +000054
Neal Norwitz271a8682006-08-15 06:29:03 +000055 def test_subclasses(self):
56 r = range(10)
57 self.assertEqual(r[TrapInt(5):TrapInt(10)], r[5:10])
58 self.assertEqual(r[TrapLong(5):TrapLong(10)], r[5:10])
59 self.assertEqual(slice(TrapInt()).indices(0), (0,0,1))
60 self.assertEqual(slice(TrapLong(0)).indices(0), (0,0,1))
Tim Petersc02c1c82006-08-15 00:25:04 +000061
Neal Norwitz8a87f5d2006-08-12 17:03:09 +000062 def test_error(self):
63 self.o.ind = 'dumb'
64 self.n.ind = 'bad'
Benjamin Peterson5c8da862009-06-30 22:57:08 +000065 self.assertRaises(TypeError, operator.index, self.o)
66 self.assertRaises(TypeError, operator.index, self.n)
67 self.assertRaises(TypeError, slice(self.o).indices, 0)
68 self.assertRaises(TypeError, slice(self.n).indices, 0)
Neal Norwitz8a87f5d2006-08-12 17:03:09 +000069
70
71class SeqTestCase(unittest.TestCase):
72 # This test case isn't run directly. It just defines common tests
73 # to the different sequence types below
74 def setUp(self):
75 self.o = oldstyle()
76 self.n = newstyle()
Armin Rigo5eca19b2006-03-30 11:28:43 +000077 self.o2 = oldstyle()
78 self.n2 = newstyle()
Anthony Baxter4ef3a232006-03-30 12:59:11 +000079
Neal Norwitz8a87f5d2006-08-12 17:03:09 +000080 def test_index(self):
Armin Rigo5eca19b2006-03-30 11:28:43 +000081 self.o.ind = -2
82 self.n.ind = 2
Neal Norwitz8a87f5d2006-08-12 17:03:09 +000083 self.assertEqual(self.seq[self.n], self.seq[2])
84 self.assertEqual(self.seq[self.o], self.seq[-2])
Armin Rigo5eca19b2006-03-30 11:28:43 +000085
86 def test_slice(self):
87 self.o.ind = 1
88 self.o2.ind = 3
89 self.n.ind = 2
90 self.n2.ind = 4
Neal Norwitz8a87f5d2006-08-12 17:03:09 +000091 self.assertEqual(self.seq[self.o:self.o2], self.seq[1:3])
92 self.assertEqual(self.seq[self.n:self.n2], self.seq[2:4])
Armin Rigo5eca19b2006-03-30 11:28:43 +000093
Mark Dickinsone3656132010-01-09 18:50:50 +000094 def test_slice_bug7532(self):
95 seqlen = len(self.seq)
96 self.o.ind = int(seqlen * 1.5)
97 self.n.ind = seqlen + 2
98 self.assertEqual(self.seq[self.o:], self.seq[0:0])
99 self.assertEqual(self.seq[:self.o], self.seq)
100 self.assertEqual(self.seq[self.n:], self.seq[0:0])
101 self.assertEqual(self.seq[:self.n], self.seq)
102 if isinstance(self.seq, ClassicSeq):
103 return
104 # These tests fail for ClassicSeq (see bug #7532)
105 self.o2.ind = -seqlen - 2
106 self.n2.ind = -int(seqlen * 1.5)
107 self.assertEqual(self.seq[self.o2:], self.seq)
108 self.assertEqual(self.seq[:self.o2], self.seq[0:0])
109 self.assertEqual(self.seq[self.n2:], self.seq)
110 self.assertEqual(self.seq[:self.n2], self.seq[0:0])
111
Armin Rigo314861c2006-03-30 14:04:02 +0000112 def test_repeat(self):
113 self.o.ind = 3
114 self.n.ind = 2
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000115 self.assertEqual(self.seq * self.o, self.seq * 3)
116 self.assertEqual(self.seq * self.n, self.seq * 2)
117 self.assertEqual(self.o * self.seq, self.seq * 3)
118 self.assertEqual(self.n * self.seq, self.seq * 2)
Armin Rigo5eca19b2006-03-30 11:28:43 +0000119
Armin Rigo314861c2006-03-30 14:04:02 +0000120 def test_wrappers(self):
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000121 self.o.ind = 4
122 self.n.ind = 5
123 self.assertEqual(self.seq.__getitem__(self.o), self.seq[4])
124 self.assertEqual(self.seq.__mul__(self.o), self.seq * 4)
125 self.assertEqual(self.seq.__rmul__(self.o), self.seq * 4)
126 self.assertEqual(self.seq.__getitem__(self.n), self.seq[5])
127 self.assertEqual(self.seq.__mul__(self.n), self.seq * 5)
128 self.assertEqual(self.seq.__rmul__(self.n), self.seq * 5)
Armin Rigo314861c2006-03-30 14:04:02 +0000129
Neal Norwitz271a8682006-08-15 06:29:03 +0000130 def test_subclasses(self):
131 self.assertEqual(self.seq[TrapInt()], self.seq[0])
132 self.assertEqual(self.seq[TrapLong()], self.seq[0])
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000133
134 def test_error(self):
135 self.o.ind = 'dumb'
136 self.n.ind = 'bad'
137 indexobj = lambda x, obj: obj.seq[x]
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000138 self.assertRaises(TypeError, indexobj, self.o, self)
139 self.assertRaises(TypeError, indexobj, self.n, self)
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000140 sliceobj = lambda x, obj: obj.seq[x:]
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000141 self.assertRaises(TypeError, sliceobj, self.o, self)
142 self.assertRaises(TypeError, sliceobj, self.n, self)
Anthony Baxter4ef3a232006-03-30 12:59:11 +0000143
144
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000145class ListTestCase(SeqTestCase):
Armin Rigo314861c2006-03-30 14:04:02 +0000146 seq = [0,10,20,30,40,50]
147
148 def test_setdelitem(self):
Armin Rigo5eca19b2006-03-30 11:28:43 +0000149 self.o.ind = -2
150 self.n.ind = 2
Armin Rigo314861c2006-03-30 14:04:02 +0000151 lst = list('ab!cdefghi!j')
152 del lst[self.o]
153 del lst[self.n]
154 lst[self.o] = 'X'
155 lst[self.n] = 'Y'
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000156 self.assertEqual(lst, list('abYdefghXj'))
Anthony Baxter4ef3a232006-03-30 12:59:11 +0000157
Armin Rigo314861c2006-03-30 14:04:02 +0000158 lst = [5, 6, 7, 8, 9, 10, 11]
159 lst.__setitem__(self.n, "here")
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000160 self.assertEqual(lst, [5, 6, "here", 8, 9, 10, 11])
Armin Rigo314861c2006-03-30 14:04:02 +0000161 lst.__delitem__(self.n)
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000162 self.assertEqual(lst, [5, 6, 8, 9, 10, 11])
Armin Rigo5eca19b2006-03-30 11:28:43 +0000163
Armin Rigo314861c2006-03-30 14:04:02 +0000164 def test_inplace_repeat(self):
165 self.o.ind = 2
166 self.n.ind = 3
167 lst = [6, 4]
168 lst *= self.o
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000169 self.assertEqual(lst, [6, 4, 6, 4])
Armin Rigo314861c2006-03-30 14:04:02 +0000170 lst *= self.n
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000171 self.assertEqual(lst, [6, 4, 6, 4] * 3)
Armin Rigo314861c2006-03-30 14:04:02 +0000172
173 lst = [5, 6, 7, 8, 9, 11]
174 l2 = lst.__imul__(self.n)
Florent Xiclunabc27c6a2010-03-19 18:34:55 +0000175 self.assertIs(l2, lst)
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000176 self.assertEqual(lst, [5, 6, 7, 8, 9, 11] * 3)
Armin Rigo314861c2006-03-30 14:04:02 +0000177
178
Mark Dickinsone3656132010-01-09 18:50:50 +0000179class _BaseSeq:
180
181 def __init__(self, iterable):
182 self._list = list(iterable)
183
184 def __repr__(self):
185 return repr(self._list)
186
187 def __eq__(self, other):
188 return self._list == other
189
190 def __len__(self):
191 return len(self._list)
192
193 def __mul__(self, n):
194 return self.__class__(self._list*n)
195 __rmul__ = __mul__
196
197 def __getitem__(self, index):
198 return self._list[index]
199
200
201class _GetSliceMixin:
202
203 def __getslice__(self, i, j):
204 return self._list.__getslice__(i, j)
205
206
207class ClassicSeq(_BaseSeq): pass
208class NewSeq(_BaseSeq, object): pass
209class ClassicSeqDeprecated(_GetSliceMixin, ClassicSeq): pass
210class NewSeqDeprecated(_GetSliceMixin, NewSeq): pass
211
212
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000213class TupleTestCase(SeqTestCase):
Armin Rigo314861c2006-03-30 14:04:02 +0000214 seq = (0,10,20,30,40,50)
215
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000216class StringTestCase(SeqTestCase):
Armin Rigo314861c2006-03-30 14:04:02 +0000217 seq = "this is a test"
218
Florent Xiclunabc27c6a2010-03-19 18:34:55 +0000219class ByteArrayTestCase(SeqTestCase):
220 seq = bytearray("this is a test")
221
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000222class UnicodeTestCase(SeqTestCase):
Armin Rigo314861c2006-03-30 14:04:02 +0000223 seq = u"this is a test"
224
Mark Dickinsone3656132010-01-09 18:50:50 +0000225class ClassicSeqTestCase(SeqTestCase):
226 seq = ClassicSeq((0,10,20,30,40,50))
227
228class NewSeqTestCase(SeqTestCase):
229 seq = NewSeq((0,10,20,30,40,50))
230
231class ClassicSeqDeprecatedTestCase(SeqTestCase):
232 seq = ClassicSeqDeprecated((0,10,20,30,40,50))
233
234class NewSeqDeprecatedTestCase(SeqTestCase):
235 seq = NewSeqDeprecated((0,10,20,30,40,50))
236
Armin Rigo314861c2006-03-30 14:04:02 +0000237
238class XRangeTestCase(unittest.TestCase):
239
240 def test_xrange(self):
241 n = newstyle()
242 n.ind = 5
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000243 self.assertEqual(xrange(1, 20)[n], 6)
244 self.assertEqual(xrange(1, 20).__getitem__(n), 6)
245
246class OverflowTestCase(unittest.TestCase):
247
248 def setUp(self):
249 self.pos = 2**100
250 self.neg = -self.pos
251
252 def test_large_longs(self):
253 self.assertEqual(self.pos.__index__(), self.pos)
254 self.assertEqual(self.neg.__index__(), self.neg)
255
Neal Norwitz1872b1c2006-08-12 18:44:06 +0000256 def _getitem_helper(self, base):
257 class GetItem(base):
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000258 def __len__(self):
Mark Dickinsone3656132010-01-09 18:50:50 +0000259 return maxint # cannot return long here
260 def __getitem__(self, key):
261 return key
262 x = GetItem()
263 self.assertEqual(x[self.pos], self.pos)
264 self.assertEqual(x[self.neg], self.neg)
265 self.assertEqual(x[self.neg:self.pos].indices(maxsize),
266 (0, maxsize, 1))
267 self.assertEqual(x[self.neg:self.pos:1].indices(maxsize),
268 (0, maxsize, 1))
269
270 def _getslice_helper_deprecated(self, base):
271 class GetItem(base):
272 def __len__(self):
Florent Xiclunabc27c6a2010-03-19 18:34:55 +0000273 return maxint # cannot return long here
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000274 def __getitem__(self, key):
275 return key
276 def __getslice__(self, i, j):
277 return i, j
278 x = GetItem()
279 self.assertEqual(x[self.pos], self.pos)
280 self.assertEqual(x[self.neg], self.neg)
Kristján Valur Jónsson170eee92007-05-03 20:09:56 +0000281 self.assertEqual(x[self.neg:self.pos], (maxint+minsize, maxsize))
Mark Dickinsone3656132010-01-09 18:50:50 +0000282 self.assertEqual(x[self.neg:self.pos:1].indices(maxsize),
283 (0, maxsize, 1))
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000284
Neal Norwitz1872b1c2006-08-12 18:44:06 +0000285 def test_getitem(self):
286 self._getitem_helper(object)
Florent Xicluna6de9e932010-03-07 12:18:33 +0000287 with test_support.check_py3k_warnings():
Mark Dickinsone3656132010-01-09 18:50:50 +0000288 self._getslice_helper_deprecated(object)
Neal Norwitz1872b1c2006-08-12 18:44:06 +0000289
290 def test_getitem_classic(self):
291 class Empty: pass
Mark Dickinsone3656132010-01-09 18:50:50 +0000292 # XXX This test fails (see bug #7532)
293 #self._getitem_helper(Empty)
Florent Xicluna6de9e932010-03-07 12:18:33 +0000294 with test_support.check_py3k_warnings():
Mark Dickinsone3656132010-01-09 18:50:50 +0000295 self._getslice_helper_deprecated(Empty)
Neal Norwitz1872b1c2006-08-12 18:44:06 +0000296
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000297 def test_sequence_repeat(self):
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000298 self.assertRaises(OverflowError, lambda: "a" * self.pos)
299 self.assertRaises(OverflowError, lambda: "a" * self.neg)
Armin Rigo5eca19b2006-03-30 11:28:43 +0000300
301
302def test_main():
303 test_support.run_unittest(
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000304 BaseTestCase,
Armin Rigo5eca19b2006-03-30 11:28:43 +0000305 ListTestCase,
306 TupleTestCase,
Florent Xiclunabc27c6a2010-03-19 18:34:55 +0000307 ByteArrayTestCase,
Armin Rigo5eca19b2006-03-30 11:28:43 +0000308 StringTestCase,
Armin Rigo314861c2006-03-30 14:04:02 +0000309 UnicodeTestCase,
Mark Dickinsone3656132010-01-09 18:50:50 +0000310 ClassicSeqTestCase,
311 NewSeqTestCase,
Armin Rigo314861c2006-03-30 14:04:02 +0000312 XRangeTestCase,
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000313 OverflowTestCase,
Armin Rigo5eca19b2006-03-30 11:28:43 +0000314 )
Florent Xicluna6de9e932010-03-07 12:18:33 +0000315 with test_support.check_py3k_warnings():
Mark Dickinsone3656132010-01-09 18:50:50 +0000316 test_support.run_unittest(
317 ClassicSeqDeprecatedTestCase,
318 NewSeqDeprecatedTestCase,
319 )
320
Armin Rigo5eca19b2006-03-30 11:28:43 +0000321
322if __name__ == "__main__":
323 test_main()