blob: abc80418a4d9fd733fb10f1114ac91664f7325d0 [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)
52
Neal Norwitz271a8682006-08-15 06:29:03 +000053 def test_subclasses(self):
54 r = range(10)
55 self.assertEqual(r[TrapInt(5):TrapInt(10)], r[5:10])
56 self.assertEqual(r[TrapLong(5):TrapLong(10)], r[5:10])
57 self.assertEqual(slice(TrapInt()).indices(0), (0,0,1))
58 self.assertEqual(slice(TrapLong(0)).indices(0), (0,0,1))
Tim Petersc02c1c82006-08-15 00:25:04 +000059
Neal Norwitz8a87f5d2006-08-12 17:03:09 +000060 def test_error(self):
61 self.o.ind = 'dumb'
62 self.n.ind = 'bad'
Benjamin Peterson5c8da862009-06-30 22:57:08 +000063 self.assertRaises(TypeError, operator.index, self.o)
64 self.assertRaises(TypeError, operator.index, self.n)
65 self.assertRaises(TypeError, slice(self.o).indices, 0)
66 self.assertRaises(TypeError, slice(self.n).indices, 0)
Neal Norwitz8a87f5d2006-08-12 17:03:09 +000067
68
69class SeqTestCase(unittest.TestCase):
70 # This test case isn't run directly. It just defines common tests
71 # to the different sequence types below
72 def setUp(self):
73 self.o = oldstyle()
74 self.n = newstyle()
Armin Rigo5eca19b2006-03-30 11:28:43 +000075 self.o2 = oldstyle()
76 self.n2 = newstyle()
Anthony Baxter4ef3a232006-03-30 12:59:11 +000077
Neal Norwitz8a87f5d2006-08-12 17:03:09 +000078 def test_index(self):
Armin Rigo5eca19b2006-03-30 11:28:43 +000079 self.o.ind = -2
80 self.n.ind = 2
Neal Norwitz8a87f5d2006-08-12 17:03:09 +000081 self.assertEqual(self.seq[self.n], self.seq[2])
82 self.assertEqual(self.seq[self.o], self.seq[-2])
Armin Rigo5eca19b2006-03-30 11:28:43 +000083
84 def test_slice(self):
85 self.o.ind = 1
86 self.o2.ind = 3
87 self.n.ind = 2
88 self.n2.ind = 4
Neal Norwitz8a87f5d2006-08-12 17:03:09 +000089 self.assertEqual(self.seq[self.o:self.o2], self.seq[1:3])
90 self.assertEqual(self.seq[self.n:self.n2], self.seq[2:4])
Armin Rigo5eca19b2006-03-30 11:28:43 +000091
Mark Dickinsone3656132010-01-09 18:50:50 +000092 def test_slice_bug7532(self):
93 seqlen = len(self.seq)
94 self.o.ind = int(seqlen * 1.5)
95 self.n.ind = seqlen + 2
96 self.assertEqual(self.seq[self.o:], self.seq[0:0])
97 self.assertEqual(self.seq[:self.o], self.seq)
98 self.assertEqual(self.seq[self.n:], self.seq[0:0])
99 self.assertEqual(self.seq[:self.n], self.seq)
100 if isinstance(self.seq, ClassicSeq):
101 return
102 # These tests fail for ClassicSeq (see bug #7532)
103 self.o2.ind = -seqlen - 2
104 self.n2.ind = -int(seqlen * 1.5)
105 self.assertEqual(self.seq[self.o2:], self.seq)
106 self.assertEqual(self.seq[:self.o2], self.seq[0:0])
107 self.assertEqual(self.seq[self.n2:], self.seq)
108 self.assertEqual(self.seq[:self.n2], self.seq[0:0])
109
Armin Rigo314861c2006-03-30 14:04:02 +0000110 def test_repeat(self):
111 self.o.ind = 3
112 self.n.ind = 2
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000113 self.assertEqual(self.seq * self.o, self.seq * 3)
114 self.assertEqual(self.seq * self.n, self.seq * 2)
115 self.assertEqual(self.o * self.seq, self.seq * 3)
116 self.assertEqual(self.n * self.seq, self.seq * 2)
Armin Rigo5eca19b2006-03-30 11:28:43 +0000117
Armin Rigo314861c2006-03-30 14:04:02 +0000118 def test_wrappers(self):
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000119 self.o.ind = 4
120 self.n.ind = 5
121 self.assertEqual(self.seq.__getitem__(self.o), self.seq[4])
122 self.assertEqual(self.seq.__mul__(self.o), self.seq * 4)
123 self.assertEqual(self.seq.__rmul__(self.o), self.seq * 4)
124 self.assertEqual(self.seq.__getitem__(self.n), self.seq[5])
125 self.assertEqual(self.seq.__mul__(self.n), self.seq * 5)
126 self.assertEqual(self.seq.__rmul__(self.n), self.seq * 5)
Armin Rigo314861c2006-03-30 14:04:02 +0000127
Neal Norwitz271a8682006-08-15 06:29:03 +0000128 def test_subclasses(self):
129 self.assertEqual(self.seq[TrapInt()], self.seq[0])
130 self.assertEqual(self.seq[TrapLong()], self.seq[0])
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000131
132 def test_error(self):
133 self.o.ind = 'dumb'
134 self.n.ind = 'bad'
135 indexobj = lambda x, obj: obj.seq[x]
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000136 self.assertRaises(TypeError, indexobj, self.o, self)
137 self.assertRaises(TypeError, indexobj, self.n, self)
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000138 sliceobj = lambda x, obj: obj.seq[x:]
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000139 self.assertRaises(TypeError, sliceobj, self.o, self)
140 self.assertRaises(TypeError, sliceobj, self.n, self)
Anthony Baxter4ef3a232006-03-30 12:59:11 +0000141
142
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000143class ListTestCase(SeqTestCase):
Armin Rigo314861c2006-03-30 14:04:02 +0000144 seq = [0,10,20,30,40,50]
145
146 def test_setdelitem(self):
Armin Rigo5eca19b2006-03-30 11:28:43 +0000147 self.o.ind = -2
148 self.n.ind = 2
Armin Rigo314861c2006-03-30 14:04:02 +0000149 lst = list('ab!cdefghi!j')
150 del lst[self.o]
151 del lst[self.n]
152 lst[self.o] = 'X'
153 lst[self.n] = 'Y'
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000154 self.assertEqual(lst, list('abYdefghXj'))
Anthony Baxter4ef3a232006-03-30 12:59:11 +0000155
Armin Rigo314861c2006-03-30 14:04:02 +0000156 lst = [5, 6, 7, 8, 9, 10, 11]
157 lst.__setitem__(self.n, "here")
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000158 self.assertEqual(lst, [5, 6, "here", 8, 9, 10, 11])
Armin Rigo314861c2006-03-30 14:04:02 +0000159 lst.__delitem__(self.n)
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000160 self.assertEqual(lst, [5, 6, 8, 9, 10, 11])
Armin Rigo5eca19b2006-03-30 11:28:43 +0000161
Armin Rigo314861c2006-03-30 14:04:02 +0000162 def test_inplace_repeat(self):
163 self.o.ind = 2
164 self.n.ind = 3
165 lst = [6, 4]
166 lst *= self.o
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000167 self.assertEqual(lst, [6, 4, 6, 4])
Armin Rigo314861c2006-03-30 14:04:02 +0000168 lst *= self.n
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000169 self.assertEqual(lst, [6, 4, 6, 4] * 3)
Armin Rigo314861c2006-03-30 14:04:02 +0000170
171 lst = [5, 6, 7, 8, 9, 11]
172 l2 = lst.__imul__(self.n)
Florent Xiclunabc27c6a2010-03-19 18:34:55 +0000173 self.assertIs(l2, lst)
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000174 self.assertEqual(lst, [5, 6, 7, 8, 9, 11] * 3)
Armin Rigo314861c2006-03-30 14:04:02 +0000175
176
Mark Dickinsone3656132010-01-09 18:50:50 +0000177class _BaseSeq:
178
179 def __init__(self, iterable):
180 self._list = list(iterable)
181
182 def __repr__(self):
183 return repr(self._list)
184
185 def __eq__(self, other):
186 return self._list == other
187
188 def __len__(self):
189 return len(self._list)
190
191 def __mul__(self, n):
192 return self.__class__(self._list*n)
193 __rmul__ = __mul__
194
195 def __getitem__(self, index):
196 return self._list[index]
197
198
199class _GetSliceMixin:
200
201 def __getslice__(self, i, j):
202 return self._list.__getslice__(i, j)
203
204
205class ClassicSeq(_BaseSeq): pass
206class NewSeq(_BaseSeq, object): pass
207class ClassicSeqDeprecated(_GetSliceMixin, ClassicSeq): pass
208class NewSeqDeprecated(_GetSliceMixin, NewSeq): pass
209
210
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000211class TupleTestCase(SeqTestCase):
Armin Rigo314861c2006-03-30 14:04:02 +0000212 seq = (0,10,20,30,40,50)
213
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000214class StringTestCase(SeqTestCase):
Armin Rigo314861c2006-03-30 14:04:02 +0000215 seq = "this is a test"
216
Florent Xiclunabc27c6a2010-03-19 18:34:55 +0000217class ByteArrayTestCase(SeqTestCase):
218 seq = bytearray("this is a test")
219
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000220class UnicodeTestCase(SeqTestCase):
Armin Rigo314861c2006-03-30 14:04:02 +0000221 seq = u"this is a test"
222
Mark Dickinsone3656132010-01-09 18:50:50 +0000223class ClassicSeqTestCase(SeqTestCase):
224 seq = ClassicSeq((0,10,20,30,40,50))
225
226class NewSeqTestCase(SeqTestCase):
227 seq = NewSeq((0,10,20,30,40,50))
228
229class ClassicSeqDeprecatedTestCase(SeqTestCase):
230 seq = ClassicSeqDeprecated((0,10,20,30,40,50))
231
232class NewSeqDeprecatedTestCase(SeqTestCase):
233 seq = NewSeqDeprecated((0,10,20,30,40,50))
234
Armin Rigo314861c2006-03-30 14:04:02 +0000235
236class XRangeTestCase(unittest.TestCase):
237
238 def test_xrange(self):
239 n = newstyle()
240 n.ind = 5
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000241 self.assertEqual(xrange(1, 20)[n], 6)
242 self.assertEqual(xrange(1, 20).__getitem__(n), 6)
243
244class OverflowTestCase(unittest.TestCase):
245
246 def setUp(self):
247 self.pos = 2**100
248 self.neg = -self.pos
249
250 def test_large_longs(self):
251 self.assertEqual(self.pos.__index__(), self.pos)
252 self.assertEqual(self.neg.__index__(), self.neg)
253
Neal Norwitz1872b1c2006-08-12 18:44:06 +0000254 def _getitem_helper(self, base):
255 class GetItem(base):
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000256 def __len__(self):
Mark Dickinsone3656132010-01-09 18:50:50 +0000257 return maxint # cannot return long here
258 def __getitem__(self, key):
259 return key
260 x = GetItem()
261 self.assertEqual(x[self.pos], self.pos)
262 self.assertEqual(x[self.neg], self.neg)
263 self.assertEqual(x[self.neg:self.pos].indices(maxsize),
264 (0, maxsize, 1))
265 self.assertEqual(x[self.neg:self.pos:1].indices(maxsize),
266 (0, maxsize, 1))
267
268 def _getslice_helper_deprecated(self, base):
269 class GetItem(base):
270 def __len__(self):
Florent Xiclunabc27c6a2010-03-19 18:34:55 +0000271 return maxint # cannot return long here
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000272 def __getitem__(self, key):
273 return key
274 def __getslice__(self, i, j):
275 return i, j
276 x = GetItem()
277 self.assertEqual(x[self.pos], self.pos)
278 self.assertEqual(x[self.neg], self.neg)
Kristján Valur Jónsson170eee92007-05-03 20:09:56 +0000279 self.assertEqual(x[self.neg:self.pos], (maxint+minsize, maxsize))
Mark Dickinsone3656132010-01-09 18:50:50 +0000280 self.assertEqual(x[self.neg:self.pos:1].indices(maxsize),
281 (0, maxsize, 1))
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000282
Neal Norwitz1872b1c2006-08-12 18:44:06 +0000283 def test_getitem(self):
284 self._getitem_helper(object)
Florent Xicluna6de9e932010-03-07 12:18:33 +0000285 with test_support.check_py3k_warnings():
Mark Dickinsone3656132010-01-09 18:50:50 +0000286 self._getslice_helper_deprecated(object)
Neal Norwitz1872b1c2006-08-12 18:44:06 +0000287
288 def test_getitem_classic(self):
289 class Empty: pass
Mark Dickinsone3656132010-01-09 18:50:50 +0000290 # XXX This test fails (see bug #7532)
291 #self._getitem_helper(Empty)
Florent Xicluna6de9e932010-03-07 12:18:33 +0000292 with test_support.check_py3k_warnings():
Mark Dickinsone3656132010-01-09 18:50:50 +0000293 self._getslice_helper_deprecated(Empty)
Neal Norwitz1872b1c2006-08-12 18:44:06 +0000294
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000295 def test_sequence_repeat(self):
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000296 self.assertRaises(OverflowError, lambda: "a" * self.pos)
297 self.assertRaises(OverflowError, lambda: "a" * self.neg)
Armin Rigo5eca19b2006-03-30 11:28:43 +0000298
299
300def test_main():
301 test_support.run_unittest(
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000302 BaseTestCase,
Armin Rigo5eca19b2006-03-30 11:28:43 +0000303 ListTestCase,
304 TupleTestCase,
Florent Xiclunabc27c6a2010-03-19 18:34:55 +0000305 ByteArrayTestCase,
Armin Rigo5eca19b2006-03-30 11:28:43 +0000306 StringTestCase,
Armin Rigo314861c2006-03-30 14:04:02 +0000307 UnicodeTestCase,
Mark Dickinsone3656132010-01-09 18:50:50 +0000308 ClassicSeqTestCase,
309 NewSeqTestCase,
Armin Rigo314861c2006-03-30 14:04:02 +0000310 XRangeTestCase,
Neal Norwitz8a87f5d2006-08-12 17:03:09 +0000311 OverflowTestCase,
Armin Rigo5eca19b2006-03-30 11:28:43 +0000312 )
Florent Xicluna6de9e932010-03-07 12:18:33 +0000313 with test_support.check_py3k_warnings():
Mark Dickinsone3656132010-01-09 18:50:50 +0000314 test_support.run_unittest(
315 ClassicSeqDeprecatedTestCase,
316 NewSeqDeprecatedTestCase,
317 )
318
Armin Rigo5eca19b2006-03-30 11:28:43 +0000319
320if __name__ == "__main__":
321 test_main()