blob: a54594a450c01fefbdba4a05628207b9e447fd72 [file] [log] [blame]
Roger E. Masse8db1b071996-12-09 20:09:16 +00001#! /usr/bin/env python
2"""Test the arraymodule.
Roger E. Massefab8ab81996-12-20 22:36:52 +00003 Roger E. Masse
Roger E. Masse8db1b071996-12-09 20:09:16 +00004"""
Roger E. Massefab8ab81996-12-20 22:36:52 +00005
Walter Dörwald7fd94242003-05-18 00:47:47 +00006import unittest
7from test import test_support
Raymond Hettingercb87bc82004-05-31 00:35:52 +00008from weakref import proxy
Christian Heimesc5f05e42008-02-23 17:40:11 +00009import array, cStringIO
Raymond Hettingerb0900e62004-12-16 16:23:40 +000010from cPickle import loads, dumps
11
12class ArraySubclass(array.array):
13 pass
Guido van Rossumc9f8f141997-04-09 20:51:54 +000014
Georg Brandlb84c1372007-01-21 10:28:43 +000015class ArraySubclassWithKwargs(array.array):
16 def __init__(self, typecode, newarg=None):
17 array.array.__init__(typecode)
18
Walter Dörwald7fd94242003-05-18 00:47:47 +000019tests = [] # list to accumulate all tests
20typecodes = "cubBhHiIlLfd"
Martin v. Löwis99866332002-03-01 10:27:01 +000021
Walter Dörwald7fd94242003-05-18 00:47:47 +000022class BadConstructorTest(unittest.TestCase):
Martin v. Löwis99866332002-03-01 10:27:01 +000023
Walter Dörwald7fd94242003-05-18 00:47:47 +000024 def test_constructor(self):
25 self.assertRaises(TypeError, array.array)
26 self.assertRaises(TypeError, array.array, spam=42)
27 self.assertRaises(TypeError, array.array, 'xx')
28 self.assertRaises(ValueError, array.array, 'x')
Martin v. Löwis99866332002-03-01 10:27:01 +000029
Walter Dörwald7fd94242003-05-18 00:47:47 +000030tests.append(BadConstructorTest)
Martin v. Löwis99866332002-03-01 10:27:01 +000031
Walter Dörwald7fd94242003-05-18 00:47:47 +000032class BaseTest(unittest.TestCase):
33 # Required class attributes (provided by subclasses
34 # typecode: the typecode to test
35 # example: an initializer usable in the constructor for this type
36 # smallerexample: the same length as example, but smaller
37 # biggerexample: the same length as example, but bigger
38 # outside: An entry that is not in example
39 # minitemsize: the minimum guaranteed itemsize
Martin v. Löwis99866332002-03-01 10:27:01 +000040
Walter Dörwald7fd94242003-05-18 00:47:47 +000041 def assertEntryEqual(self, entry1, entry2):
42 self.assertEqual(entry1, entry2)
Martin v. Löwis99866332002-03-01 10:27:01 +000043
Walter Dörwald7fd94242003-05-18 00:47:47 +000044 def badtypecode(self):
45 # Return a typecode that is different from our own
46 return typecodes[(typecodes.index(self.typecode)+1) % len(typecodes)]
Martin v. Löwis99866332002-03-01 10:27:01 +000047
Walter Dörwald7fd94242003-05-18 00:47:47 +000048 def test_constructor(self):
49 a = array.array(self.typecode)
50 self.assertEqual(a.typecode, self.typecode)
51 self.assert_(a.itemsize>=self.minitemsize)
52 self.assertRaises(TypeError, array.array, self.typecode, None)
Martin v. Löwis99866332002-03-01 10:27:01 +000053
Walter Dörwald7fd94242003-05-18 00:47:47 +000054 def test_len(self):
55 a = array.array(self.typecode)
56 a.append(self.example[0])
57 self.assertEqual(len(a), 1)
Martin v. Löwis99866332002-03-01 10:27:01 +000058
Walter Dörwald7fd94242003-05-18 00:47:47 +000059 a = array.array(self.typecode, self.example)
60 self.assertEqual(len(a), len(self.example))
Martin v. Löwis99866332002-03-01 10:27:01 +000061
Walter Dörwald7fd94242003-05-18 00:47:47 +000062 def test_buffer_info(self):
63 a = array.array(self.typecode, self.example)
64 self.assertRaises(TypeError, a.buffer_info, 42)
65 bi = a.buffer_info()
66 self.assert_(isinstance(bi, tuple))
67 self.assertEqual(len(bi), 2)
Tim Peters9bdc85f2006-04-10 21:38:11 +000068 self.assert_(isinstance(bi[0], (int, long)))
Walter Dörwald7fd94242003-05-18 00:47:47 +000069 self.assert_(isinstance(bi[1], int))
70 self.assertEqual(bi[1], len(a))
Martin v. Löwis99866332002-03-01 10:27:01 +000071
Walter Dörwald7fd94242003-05-18 00:47:47 +000072 def test_byteswap(self):
73 a = array.array(self.typecode, self.example)
74 self.assertRaises(TypeError, a.byteswap, 42)
75 if a.itemsize in (1, 2, 4, 8):
76 b = array.array(self.typecode, self.example)
77 b.byteswap()
78 if a.itemsize==1:
79 self.assertEqual(a, b)
80 else:
81 self.assertNotEqual(a, b)
82 b.byteswap()
83 self.assertEqual(a, b)
Martin v. Löwis99866332002-03-01 10:27:01 +000084
Raymond Hettinger3aa82c02004-03-13 18:18:51 +000085 def test_copy(self):
86 import copy
87 a = array.array(self.typecode, self.example)
88 b = copy.copy(a)
89 self.assertNotEqual(id(a), id(b))
90 self.assertEqual(a, b)
91
Thomas Wouters9e398ca2006-08-24 18:40:20 +000092 def test_deepcopy(self):
93 import copy
94 a = array.array(self.typecode, self.example)
95 b = copy.deepcopy(a)
96 self.assertNotEqual(id(a), id(b))
97 self.assertEqual(a, b)
98
Raymond Hettingerb0900e62004-12-16 16:23:40 +000099 def test_pickle(self):
100 for protocol in (0, 1, 2):
101 a = array.array(self.typecode, self.example)
102 b = loads(dumps(a, protocol))
103 self.assertNotEqual(id(a), id(b))
104 self.assertEqual(a, b)
105
106 a = ArraySubclass(self.typecode, self.example)
107 a.x = 10
108 b = loads(dumps(a, protocol))
109 self.assertNotEqual(id(a), id(b))
110 self.assertEqual(a, b)
111 self.assertEqual(a.x, b.x)
112 self.assertEqual(type(a), type(b))
113
Raymond Hettingere6e660b2007-04-02 17:29:30 +0000114 def test_pickle_for_empty_array(self):
115 for protocol in (0, 1, 2):
116 a = array.array(self.typecode)
117 b = loads(dumps(a, protocol))
118 self.assertNotEqual(id(a), id(b))
119 self.assertEqual(a, b)
120
121 a = ArraySubclass(self.typecode)
122 a.x = 10
123 b = loads(dumps(a, protocol))
124 self.assertNotEqual(id(a), id(b))
125 self.assertEqual(a, b)
126 self.assertEqual(a.x, b.x)
127 self.assertEqual(type(a), type(b))
128
Walter Dörwald7fd94242003-05-18 00:47:47 +0000129 def test_insert(self):
130 a = array.array(self.typecode, self.example)
131 a.insert(0, self.example[0])
132 self.assertEqual(len(a), 1+len(self.example))
133 self.assertEqual(a[0], a[1])
134 self.assertRaises(TypeError, a.insert)
135 self.assertRaises(TypeError, a.insert, None)
Walter Dörwaldba39d9c2003-05-18 01:56:25 +0000136 self.assertRaises(TypeError, a.insert, 0, None)
Martin v. Löwis99866332002-03-01 10:27:01 +0000137
Walter Dörwald9e46abe2003-05-18 03:15:10 +0000138 a = array.array(self.typecode, self.example)
139 a.insert(-1, self.example[0])
140 self.assertEqual(
141 a,
142 array.array(
143 self.typecode,
144 self.example[:-1] + self.example[:1] + self.example[-1:]
145 )
146 )
147
148 a = array.array(self.typecode, self.example)
149 a.insert(-1000, self.example[0])
150 self.assertEqual(
151 a,
152 array.array(self.typecode, self.example[:1] + self.example)
153 )
154
155 a = array.array(self.typecode, self.example)
156 a.insert(1000, self.example[0])
157 self.assertEqual(
158 a,
159 array.array(self.typecode, self.example + self.example[:1])
160 )
161
Walter Dörwald7fd94242003-05-18 00:47:47 +0000162 def test_tofromfile(self):
163 a = array.array(self.typecode, 2*self.example)
164 self.assertRaises(TypeError, a.tofile)
165 self.assertRaises(TypeError, a.tofile, cStringIO.StringIO())
166 f = open(test_support.TESTFN, 'wb')
167 try:
168 a.tofile(f)
169 f.close()
170 b = array.array(self.typecode)
171 f = open(test_support.TESTFN, 'rb')
172 self.assertRaises(TypeError, b.fromfile)
173 self.assertRaises(
174 TypeError,
175 b.fromfile,
176 cStringIO.StringIO(), len(self.example)
177 )
178 b.fromfile(f, len(self.example))
179 self.assertEqual(b, array.array(self.typecode, self.example))
180 self.assertNotEqual(a, b)
181 b.fromfile(f, len(self.example))
182 self.assertEqual(a, b)
183 self.assertRaises(EOFError, b.fromfile, f, 1)
184 f.close()
185 finally:
186 if not f.closed:
187 f.close()
188 test_support.unlink(test_support.TESTFN)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000189
Walter Dörwald7fd94242003-05-18 00:47:47 +0000190 def test_tofromlist(self):
191 a = array.array(self.typecode, 2*self.example)
192 b = array.array(self.typecode)
193 self.assertRaises(TypeError, a.tolist, 42)
194 self.assertRaises(TypeError, b.fromlist)
195 self.assertRaises(TypeError, b.fromlist, 42)
196 self.assertRaises(TypeError, b.fromlist, [None])
197 b.fromlist(a.tolist())
198 self.assertEqual(a, b)
Fred Drake78334472000-06-28 17:50:51 +0000199
Walter Dörwald7fd94242003-05-18 00:47:47 +0000200 def test_tofromstring(self):
201 a = array.array(self.typecode, 2*self.example)
202 b = array.array(self.typecode)
203 self.assertRaises(TypeError, a.tostring, 42)
204 self.assertRaises(TypeError, b.fromstring)
205 self.assertRaises(TypeError, b.fromstring, 42)
206 b.fromstring(a.tostring())
207 self.assertEqual(a, b)
208 if a.itemsize>1:
209 self.assertRaises(ValueError, b.fromstring, "x")
Fred Drake78334472000-06-28 17:50:51 +0000210
Walter Dörwald7fd94242003-05-18 00:47:47 +0000211 def test_repr(self):
212 a = array.array(self.typecode, 2*self.example)
213 self.assertEqual(a, eval(repr(a), {"array": array.array}))
Fred Drake78334472000-06-28 17:50:51 +0000214
Walter Dörwald7fd94242003-05-18 00:47:47 +0000215 a = array.array(self.typecode)
216 self.assertEqual(repr(a), "array('%s')" % self.typecode)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000217
Walter Dörwald7fd94242003-05-18 00:47:47 +0000218 def test_str(self):
219 a = array.array(self.typecode, 2*self.example)
220 str(a)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000221
Walter Dörwald7fd94242003-05-18 00:47:47 +0000222 def test_cmp(self):
223 a = array.array(self.typecode, self.example)
224 self.assert_((a == 42) is False)
225 self.assert_((a != 42) is True)
Tim Peterscc78e472000-11-14 21:36:07 +0000226
Walter Dörwald7fd94242003-05-18 00:47:47 +0000227 self.assert_((a == a) is True)
228 self.assert_((a != a) is False)
229 self.assert_((a < a) is False)
230 self.assert_((a <= a) is True)
231 self.assert_((a > a) is False)
232 self.assert_((a >= a) is True)
Tim Peterscc78e472000-11-14 21:36:07 +0000233
Neal Norwitzc72f5012006-03-17 08:55:46 +0000234 al = array.array(self.typecode, self.smallerexample)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000235 ab = array.array(self.typecode, self.biggerexample)
Guido van Rossum7f1d3aa1998-07-16 15:31:43 +0000236
Walter Dörwald7fd94242003-05-18 00:47:47 +0000237 self.assert_((a == 2*a) is False)
238 self.assert_((a != 2*a) is True)
239 self.assert_((a < 2*a) is True)
240 self.assert_((a <= 2*a) is True)
241 self.assert_((a > 2*a) is False)
242 self.assert_((a >= 2*a) is False)
Martin v. Löwis99866332002-03-01 10:27:01 +0000243
Neal Norwitzc72f5012006-03-17 08:55:46 +0000244 self.assert_((a == al) is False)
245 self.assert_((a != al) is True)
246 self.assert_((a < al) is False)
247 self.assert_((a <= al) is False)
248 self.assert_((a > al) is True)
249 self.assert_((a >= al) is True)
Martin v. Löwis99866332002-03-01 10:27:01 +0000250
Walter Dörwald7fd94242003-05-18 00:47:47 +0000251 self.assert_((a == ab) is False)
252 self.assert_((a != ab) is True)
253 self.assert_((a < ab) is True)
254 self.assert_((a <= ab) is True)
255 self.assert_((a > ab) is False)
256 self.assert_((a >= ab) is False)
Martin v. Löwis99866332002-03-01 10:27:01 +0000257
Walter Dörwald7fd94242003-05-18 00:47:47 +0000258 def test_add(self):
259 a = array.array(self.typecode, self.example) \
260 + array.array(self.typecode, self.example[::-1])
261 self.assertEqual(
262 a,
263 array.array(self.typecode, self.example + self.example[::-1])
264 )
Martin v. Löwis99866332002-03-01 10:27:01 +0000265
Walter Dörwald7fd94242003-05-18 00:47:47 +0000266 b = array.array(self.badtypecode())
267 self.assertRaises(TypeError, a.__add__, b)
268
269 self.assertRaises(TypeError, a.__add__, "bad")
270
271 def test_iadd(self):
272 a = array.array(self.typecode, self.example[::-1])
273 b = a
274 a += array.array(self.typecode, 2*self.example)
275 self.assert_(a is b)
276 self.assertEqual(
277 a,
278 array.array(self.typecode, self.example[::-1]+2*self.example)
279 )
280
281 b = array.array(self.badtypecode())
282 self.assertRaises(TypeError, a.__add__, b)
283
284 self.assertRaises(TypeError, a.__iadd__, "bad")
285
286 def test_mul(self):
287 a = 5*array.array(self.typecode, self.example)
288 self.assertEqual(
289 a,
290 array.array(self.typecode, 5*self.example)
291 )
292
293 a = array.array(self.typecode, self.example)*5
294 self.assertEqual(
295 a,
296 array.array(self.typecode, self.example*5)
297 )
298
299 a = 0*array.array(self.typecode, self.example)
300 self.assertEqual(
301 a,
302 array.array(self.typecode)
303 )
304
305 a = (-1)*array.array(self.typecode, self.example)
306 self.assertEqual(
307 a,
308 array.array(self.typecode)
309 )
310
311 self.assertRaises(TypeError, a.__mul__, "bad")
312
313 def test_imul(self):
314 a = array.array(self.typecode, self.example)
315 b = a
316
317 a *= 5
318 self.assert_(a is b)
319 self.assertEqual(
320 a,
321 array.array(self.typecode, 5*self.example)
322 )
323
324 a *= 0
325 self.assert_(a is b)
326 self.assertEqual(a, array.array(self.typecode))
327
328 a *= 1000
329 self.assert_(a is b)
330 self.assertEqual(a, array.array(self.typecode))
331
332 a *= -1
333 self.assert_(a is b)
334 self.assertEqual(a, array.array(self.typecode))
335
336 a = array.array(self.typecode, self.example)
337 a *= -1
338 self.assertEqual(a, array.array(self.typecode))
339
340 self.assertRaises(TypeError, a.__imul__, "bad")
341
342 def test_getitem(self):
343 a = array.array(self.typecode, self.example)
344 self.assertEntryEqual(a[0], self.example[0])
345 self.assertEntryEqual(a[0L], self.example[0])
346 self.assertEntryEqual(a[-1], self.example[-1])
347 self.assertEntryEqual(a[-1L], self.example[-1])
348 self.assertEntryEqual(a[len(self.example)-1], self.example[-1])
349 self.assertEntryEqual(a[-len(self.example)], self.example[0])
350 self.assertRaises(TypeError, a.__getitem__)
351 self.assertRaises(IndexError, a.__getitem__, len(self.example))
352 self.assertRaises(IndexError, a.__getitem__, -len(self.example)-1)
353
354 def test_setitem(self):
355 a = array.array(self.typecode, self.example)
356 a[0] = a[-1]
357 self.assertEntryEqual(a[0], a[-1])
358
359 a = array.array(self.typecode, self.example)
360 a[0L] = a[-1]
361 self.assertEntryEqual(a[0], a[-1])
362
363 a = array.array(self.typecode, self.example)
364 a[-1] = a[0]
365 self.assertEntryEqual(a[0], a[-1])
366
367 a = array.array(self.typecode, self.example)
368 a[-1L] = a[0]
369 self.assertEntryEqual(a[0], a[-1])
370
371 a = array.array(self.typecode, self.example)
372 a[len(self.example)-1] = a[0]
373 self.assertEntryEqual(a[0], a[-1])
374
375 a = array.array(self.typecode, self.example)
376 a[-len(self.example)] = a[-1]
377 self.assertEntryEqual(a[0], a[-1])
378
379 self.assertRaises(TypeError, a.__setitem__)
380 self.assertRaises(TypeError, a.__setitem__, None)
381 self.assertRaises(TypeError, a.__setitem__, 0, None)
382 self.assertRaises(
383 IndexError,
384 a.__setitem__,
385 len(self.example), self.example[0]
386 )
387 self.assertRaises(
388 IndexError,
389 a.__setitem__,
390 -len(self.example)-1, self.example[0]
391 )
392
393 def test_delitem(self):
394 a = array.array(self.typecode, self.example)
395 del a[0]
396 self.assertEqual(
397 a,
398 array.array(self.typecode, self.example[1:])
399 )
400
401 a = array.array(self.typecode, self.example)
402 del a[-1]
403 self.assertEqual(
404 a,
405 array.array(self.typecode, self.example[:-1])
406 )
407
408 a = array.array(self.typecode, self.example)
409 del a[len(self.example)-1]
410 self.assertEqual(
411 a,
412 array.array(self.typecode, self.example[:-1])
413 )
414
415 a = array.array(self.typecode, self.example)
416 del a[-len(self.example)]
417 self.assertEqual(
418 a,
419 array.array(self.typecode, self.example[1:])
420 )
421
422 self.assertRaises(TypeError, a.__delitem__)
423 self.assertRaises(TypeError, a.__delitem__, None)
424 self.assertRaises(IndexError, a.__delitem__, len(self.example))
425 self.assertRaises(IndexError, a.__delitem__, -len(self.example)-1)
426
427 def test_getslice(self):
428 a = array.array(self.typecode, self.example)
429 self.assertEqual(a[:], a)
430
431 self.assertEqual(
432 a[1:],
433 array.array(self.typecode, self.example[1:])
434 )
435
436 self.assertEqual(
437 a[:1],
438 array.array(self.typecode, self.example[:1])
439 )
440
441 self.assertEqual(
442 a[:-1],
443 array.array(self.typecode, self.example[:-1])
444 )
445
446 self.assertEqual(
447 a[-1:],
448 array.array(self.typecode, self.example[-1:])
449 )
450
451 self.assertEqual(
452 a[-1:-1],
453 array.array(self.typecode)
454 )
455
456 self.assertEqual(
Walter Dörwald1083c242005-01-21 21:16:51 +0000457 a[2:1],
458 array.array(self.typecode)
459 )
460
461 self.assertEqual(
Walter Dörwald7fd94242003-05-18 00:47:47 +0000462 a[1000:],
463 array.array(self.typecode)
464 )
465 self.assertEqual(a[-1000:], a)
466 self.assertEqual(a[:1000], a)
467 self.assertEqual(
468 a[:-1000],
469 array.array(self.typecode)
470 )
471 self.assertEqual(a[-1000:1000], a)
472 self.assertEqual(
473 a[2000:1000],
474 array.array(self.typecode)
475 )
476
Thomas Wouters3ccec682007-08-28 15:28:19 +0000477 def test_extended_getslice(self):
478 # Test extended slicing by comparing with list slicing
479 # (Assumes list conversion works correctly, too)
480 a = array.array(self.typecode, self.example)
481 indices = (0, None, 1, 3, 19, 100, -1, -2, -31, -100)
482 for start in indices:
483 for stop in indices:
484 # Everything except the initial 0 (invalid step)
485 for step in indices[1:]:
486 self.assertEqual(list(a[start:stop:step]),
487 list(a)[start:stop:step])
488
Walter Dörwald7fd94242003-05-18 00:47:47 +0000489 def test_setslice(self):
490 a = array.array(self.typecode, self.example)
491 a[:1] = a
492 self.assertEqual(
493 a,
494 array.array(self.typecode, self.example + self.example[1:])
495 )
496
497 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000498 a[:-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000499 self.assertEqual(
500 a,
501 array.array(self.typecode, self.example + self.example[-1:])
502 )
503
504 a = array.array(self.typecode, self.example)
505 a[-1:] = a
506 self.assertEqual(
507 a,
508 array.array(self.typecode, self.example[:-1] + self.example)
509 )
510
511 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000512 a[1:] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000513 self.assertEqual(
514 a,
515 array.array(self.typecode, self.example[:1] + self.example)
516 )
517
518 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000519 a[1:-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000520 self.assertEqual(
521 a,
522 array.array(
523 self.typecode,
524 self.example[:1] + self.example + self.example[-1:]
525 )
526 )
527
528 a = array.array(self.typecode, self.example)
529 a[1000:] = a
530 self.assertEqual(
531 a,
532 array.array(self.typecode, 2*self.example)
533 )
534
535 a = array.array(self.typecode, self.example)
536 a[-1000:] = a
537 self.assertEqual(
538 a,
539 array.array(self.typecode, self.example)
540 )
541
542 a = array.array(self.typecode, self.example)
543 a[:1000] = a
544 self.assertEqual(
545 a,
546 array.array(self.typecode, self.example)
547 )
548
549 a = array.array(self.typecode, self.example)
550 a[:-1000] = a
551 self.assertEqual(
552 a,
553 array.array(self.typecode, 2*self.example)
554 )
555
556 a = array.array(self.typecode, self.example)
557 a[1:0] = a
558 self.assertEqual(
559 a,
560 array.array(self.typecode, self.example[:1] + self.example + self.example[1:])
561 )
562
563 a = array.array(self.typecode, self.example)
564 a[2000:1000] = a
565 self.assertEqual(
566 a,
567 array.array(self.typecode, 2*self.example)
568 )
569
570 a = array.array(self.typecode, self.example)
571 self.assertRaises(TypeError, a.__setslice__, 0, 0, None)
Thomas Wouters3ccec682007-08-28 15:28:19 +0000572 self.assertRaises(TypeError, a.__setitem__, slice(0, 0), None)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000573 self.assertRaises(TypeError, a.__setitem__, slice(0, 1), None)
574
575 b = array.array(self.badtypecode())
576 self.assertRaises(TypeError, a.__setslice__, 0, 0, b)
Thomas Wouters3ccec682007-08-28 15:28:19 +0000577 self.assertRaises(TypeError, a.__setitem__, slice(0, 0), b)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000578 self.assertRaises(TypeError, a.__setitem__, slice(0, 1), b)
579
Thomas Wouters3ccec682007-08-28 15:28:19 +0000580 def test_extended_set_del_slice(self):
581 indices = (0, None, 1, 3, 19, 100, -1, -2, -31, -100)
582 for start in indices:
583 for stop in indices:
584 # Everything except the initial 0 (invalid step)
585 for step in indices[1:]:
586 a = array.array(self.typecode, self.example)
587 L = list(a)
588 # Make sure we have a slice of exactly the right length,
589 # but with (hopefully) different data.
590 data = L[start:stop:step]
591 data.reverse()
592 L[start:stop:step] = data
593 a[start:stop:step] = array.array(self.typecode, data)
594 self.assertEquals(a, array.array(self.typecode, L))
595
596 del L[start:stop:step]
597 del a[start:stop:step]
598 self.assertEquals(a, array.array(self.typecode, L))
599
Walter Dörwald7fd94242003-05-18 00:47:47 +0000600 def test_index(self):
601 example = 2*self.example
602 a = array.array(self.typecode, example)
603 self.assertRaises(TypeError, a.index)
604 for x in example:
605 self.assertEqual(a.index(x), example.index(x))
606 self.assertRaises(ValueError, a.index, None)
607 self.assertRaises(ValueError, a.index, self.outside)
608
609 def test_count(self):
610 example = 2*self.example
611 a = array.array(self.typecode, example)
612 self.assertRaises(TypeError, a.count)
613 for x in example:
614 self.assertEqual(a.count(x), example.count(x))
615 self.assertEqual(a.count(self.outside), 0)
616 self.assertEqual(a.count(None), 0)
617
618 def test_remove(self):
619 for x in self.example:
620 example = 2*self.example
621 a = array.array(self.typecode, example)
622 pos = example.index(x)
623 example2 = example[:pos] + example[pos+1:]
624 a.remove(x)
625 self.assertEqual(a, array.array(self.typecode, example2))
626
627 a = array.array(self.typecode, self.example)
628 self.assertRaises(ValueError, a.remove, self.outside)
629
630 self.assertRaises(ValueError, a.remove, None)
631
632 def test_pop(self):
633 a = array.array(self.typecode)
634 self.assertRaises(IndexError, a.pop)
635
636 a = array.array(self.typecode, 2*self.example)
637 self.assertRaises(TypeError, a.pop, 42, 42)
638 self.assertRaises(TypeError, a.pop, None)
639 self.assertRaises(IndexError, a.pop, len(a))
640 self.assertRaises(IndexError, a.pop, -len(a)-1)
641
642 self.assertEntryEqual(a.pop(0), self.example[0])
643 self.assertEqual(
644 a,
645 array.array(self.typecode, self.example[1:]+self.example)
646 )
647 self.assertEntryEqual(a.pop(1), self.example[2])
648 self.assertEqual(
649 a,
650 array.array(self.typecode, self.example[1:2]+self.example[3:]+self.example)
651 )
652 self.assertEntryEqual(a.pop(0), self.example[1])
653 self.assertEntryEqual(a.pop(), self.example[-1])
654 self.assertEqual(
655 a,
656 array.array(self.typecode, self.example[3:]+self.example[:-1])
657 )
658
659 def test_reverse(self):
660 a = array.array(self.typecode, self.example)
661 self.assertRaises(TypeError, a.reverse, 42)
Fred Drake004d5e62000-10-23 17:22:08 +0000662 a.reverse()
Walter Dörwald7fd94242003-05-18 00:47:47 +0000663 self.assertEqual(
664 a,
665 array.array(self.typecode, self.example[::-1])
666 )
667
668 def test_extend(self):
669 a = array.array(self.typecode, self.example)
670 self.assertRaises(TypeError, a.extend)
671 a.extend(array.array(self.typecode, self.example[::-1]))
672 self.assertEqual(
673 a,
674 array.array(self.typecode, self.example+self.example[::-1])
675 )
676
677 b = array.array(self.badtypecode())
678 self.assertRaises(TypeError, a.extend, b)
679
Raymond Hettinger49f9bd12004-03-14 05:43:59 +0000680 a = array.array(self.typecode, self.example)
681 a.extend(self.example[::-1])
682 self.assertEqual(
683 a,
684 array.array(self.typecode, self.example+self.example[::-1])
685 )
686
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +0000687 def test_constructor_with_iterable_argument(self):
688 a = array.array(self.typecode, iter(self.example))
689 b = array.array(self.typecode, self.example)
690 self.assertEqual(a, b)
691
692 # non-iterable argument
693 self.assertRaises(TypeError, array.array, self.typecode, 10)
694
695 # pass through errors raised in __iter__
696 class A:
697 def __iter__(self):
698 raise UnicodeError
699 self.assertRaises(UnicodeError, array.array, self.typecode, A())
700
701 # pass through errors raised in next()
702 def B():
703 raise UnicodeError
704 yield None
705 self.assertRaises(UnicodeError, array.array, self.typecode, B())
706
Walter Dörwald7fd94242003-05-18 00:47:47 +0000707 def test_coveritertraverse(self):
708 try:
709 import gc
710 except ImportError:
711 return
712 a = array.array(self.typecode)
713 l = [iter(a)]
714 l.append(l)
715 gc.collect()
716
717 def test_buffer(self):
718 a = array.array(self.typecode, self.example)
719 b = buffer(a)
720 self.assertEqual(b[0], a.tostring()[0])
721
Raymond Hettingercb87bc82004-05-31 00:35:52 +0000722 def test_weakref(self):
723 s = array.array(self.typecode, self.example)
724 p = proxy(s)
725 self.assertEqual(p.tostring(), s.tostring())
726 s = None
727 self.assertRaises(ReferenceError, len, p)
728
Skip Montanarod5cf0b82003-08-03 23:02:10 +0000729 def test_bug_782369(self):
730 import sys
Skip Montanaroed9bf122003-08-03 23:30:40 +0000731 if hasattr(sys, "getrefcount"):
732 for i in range(10):
733 b = array.array('B', range(64))
734 rc = sys.getrefcount(10)
735 for i in range(10):
736 b = array.array('B', range(64))
737 self.assertEqual(rc, sys.getrefcount(10))
Skip Montanarod5cf0b82003-08-03 23:02:10 +0000738
Georg Brandlb84c1372007-01-21 10:28:43 +0000739 def test_subclass_with_kwargs(self):
740 # SF bug #1486663 -- this used to erroneously raise a TypeError
741 ArraySubclassWithKwargs('b', newarg=1)
Raymond Hettingercb87bc82004-05-31 00:35:52 +0000742
743
Walter Dörwald7fd94242003-05-18 00:47:47 +0000744class StringTest(BaseTest):
745
746 def test_setitem(self):
747 super(StringTest, self).test_setitem()
748 a = array.array(self.typecode, self.example)
749 self.assertRaises(TypeError, a.__setitem__, 0, self.example[:2])
750
751class CharacterTest(StringTest):
752 typecode = 'c'
753 example = '\x01azAZ\x00\xfe'
754 smallerexample = '\x01azAY\x00\xfe'
755 biggerexample = '\x01azAZ\x00\xff'
756 outside = '\x33'
757 minitemsize = 1
758
759 def test_subbclassing(self):
760 class EditableString(array.array):
761 def __new__(cls, s, *args, **kwargs):
762 return array.array.__new__(cls, 'c', s)
763
764 def __init__(self, s, color='blue'):
Walter Dörwald7fd94242003-05-18 00:47:47 +0000765 self.color = color
766
767 def strip(self):
768 self[:] = array.array('c', self.tostring().strip())
769
770 def __repr__(self):
771 return 'EditableString(%r)' % self.tostring()
772
773 s = EditableString("\ttest\r\n")
774 s.strip()
775 self.assertEqual(s.tostring(), "test")
776
777 self.assertEqual(s.color, "blue")
778 s.color = "red"
779 self.assertEqual(s.color, "red")
780 self.assertEqual(s.__dict__.keys(), ["color"])
781
782 def test_nounicode(self):
783 a = array.array(self.typecode, self.example)
784 self.assertRaises(ValueError, a.fromunicode, unicode(''))
785 self.assertRaises(ValueError, a.tounicode)
786
787tests.append(CharacterTest)
788
789if test_support.have_unicode:
790 class UnicodeTest(StringTest):
791 typecode = 'u'
792 example = unicode(r'\x01\u263a\x00\ufeff', 'unicode-escape')
793 smallerexample = unicode(r'\x01\u263a\x00\ufefe', 'unicode-escape')
794 biggerexample = unicode(r'\x01\u263a\x01\ufeff', 'unicode-escape')
795 outside = unicode('\x33')
796 minitemsize = 2
797
798 def test_unicode(self):
799 self.assertRaises(TypeError, array.array, 'b', unicode('foo', 'ascii'))
800
801 a = array.array('u', unicode(r'\xa0\xc2\u1234', 'unicode-escape'))
802 a.fromunicode(unicode(' ', 'ascii'))
803 a.fromunicode(unicode('', 'ascii'))
804 a.fromunicode(unicode('', 'ascii'))
805 a.fromunicode(unicode(r'\x11abc\xff\u1234', 'unicode-escape'))
806 s = a.tounicode()
807 self.assertEqual(
808 s,
809 unicode(r'\xa0\xc2\u1234 \x11abc\xff\u1234', 'unicode-escape')
810 )
811
812 s = unicode(r'\x00="\'a\\b\x80\xff\u0000\u0001\u1234', 'unicode-escape')
813 a = array.array('u', s)
814 self.assertEqual(
815 repr(a),
816 r"""array('u', u'\x00="\'a\\b\x80\xff\x00\x01\u1234')"""
817 )
818
819 self.assertRaises(TypeError, a.fromunicode)
820
821 tests.append(UnicodeTest)
822
823class NumberTest(BaseTest):
824
825 def test_extslice(self):
826 a = array.array(self.typecode, range(5))
827 self.assertEqual(a[::], a)
828 self.assertEqual(a[::2], array.array(self.typecode, [0,2,4]))
829 self.assertEqual(a[1::2], array.array(self.typecode, [1,3]))
830 self.assertEqual(a[::-1], array.array(self.typecode, [4,3,2,1,0]))
831 self.assertEqual(a[::-2], array.array(self.typecode, [4,2,0]))
832 self.assertEqual(a[3::-2], array.array(self.typecode, [3,1]))
833 self.assertEqual(a[-100:100:], a)
834 self.assertEqual(a[100:-100:-1], a[::-1])
835 self.assertEqual(a[-100L:100L:2L], array.array(self.typecode, [0,2,4]))
836 self.assertEqual(a[1000:2000:2], array.array(self.typecode, []))
837 self.assertEqual(a[-1000:-2000:-2], array.array(self.typecode, []))
838
839 def test_delslice(self):
840 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000841 del a[::2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000842 self.assertEqual(a, array.array(self.typecode, [1,3]))
843 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000844 del a[1::2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000845 self.assertEqual(a, array.array(self.typecode, [0,2,4]))
846 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000847 del a[1::-2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000848 self.assertEqual(a, array.array(self.typecode, [0,2,3,4]))
849 a = array.array(self.typecode, range(10))
Michael W. Hudson56796f62002-07-29 14:35:04 +0000850 del a[::1000]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000851 self.assertEqual(a, array.array(self.typecode, [1,2,3,4,5,6,7,8,9]))
852
853 def test_assignment(self):
854 a = array.array(self.typecode, range(10))
855 a[::2] = array.array(self.typecode, [42]*5)
856 self.assertEqual(a, array.array(self.typecode, [42, 1, 42, 3, 42, 5, 42, 7, 42, 9]))
857 a = array.array(self.typecode, range(10))
858 a[::-4] = array.array(self.typecode, [10]*3)
859 self.assertEqual(a, array.array(self.typecode, [0, 10, 2, 3, 4, 10, 6, 7, 8 ,10]))
860 a = array.array(self.typecode, range(4))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000861 a[::-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000862 self.assertEqual(a, array.array(self.typecode, [3, 2, 1, 0]))
863 a = array.array(self.typecode, range(10))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000864 b = a[:]
865 c = a[:]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000866 ins = array.array(self.typecode, range(2))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000867 a[2:3] = ins
868 b[slice(2,3)] = ins
869 c[2:3:] = ins
Fred Drake004d5e62000-10-23 17:22:08 +0000870
Walter Dörwald7fd94242003-05-18 00:47:47 +0000871 def test_iterationcontains(self):
872 a = array.array(self.typecode, range(10))
873 self.assertEqual(list(a), range(10))
874 b = array.array(self.typecode, [20])
875 self.assertEqual(a[-1] in a, True)
876 self.assertEqual(b[0] not in a, True)
877
878 def check_overflow(self, lower, upper):
879 # method to be used by subclasses
880
881 # should not overflow assigning lower limit
882 a = array.array(self.typecode, [lower])
883 a[0] = lower
884 # should overflow assigning less than lower limit
885 self.assertRaises(OverflowError, array.array, self.typecode, [lower-1])
886 self.assertRaises(OverflowError, a.__setitem__, 0, lower-1)
887 # should not overflow assigning upper limit
888 a = array.array(self.typecode, [upper])
889 a[0] = upper
890 # should overflow assigning more than upper limit
891 self.assertRaises(OverflowError, array.array, self.typecode, [upper+1])
892 self.assertRaises(OverflowError, a.__setitem__, 0, upper+1)
893
894 def test_subclassing(self):
895 typecode = self.typecode
896 class ExaggeratingArray(array.array):
897 __slots__ = ['offset']
898
899 def __new__(cls, typecode, data, offset):
900 return array.array.__new__(cls, typecode, data)
901
902 def __init__(self, typecode, data, offset):
903 self.offset = offset
904
905 def __getitem__(self, i):
906 return array.array.__getitem__(self, i) + self.offset
907
908 a = ExaggeratingArray(self.typecode, [3, 6, 7, 11], 4)
909 self.assertEntryEqual(a[0], 7)
910
911 self.assertRaises(AttributeError, setattr, a, "color", "blue")
912
913class SignedNumberTest(NumberTest):
914 example = [-1, 0, 1, 42, 0x7f]
915 smallerexample = [-1, 0, 1, 42, 0x7e]
916 biggerexample = [-1, 0, 1, 43, 0x7f]
917 outside = 23
918
919 def test_overflow(self):
920 a = array.array(self.typecode)
921 lower = -1 * long(pow(2, a.itemsize * 8 - 1))
922 upper = long(pow(2, a.itemsize * 8 - 1)) - 1L
923 self.check_overflow(lower, upper)
924
925class UnsignedNumberTest(NumberTest):
926 example = [0, 1, 17, 23, 42, 0xff]
927 smallerexample = [0, 1, 17, 23, 42, 0xfe]
928 biggerexample = [0, 1, 17, 23, 43, 0xff]
929 outside = 0xaa
930
931 def test_overflow(self):
932 a = array.array(self.typecode)
933 lower = 0
934 upper = long(pow(2, a.itemsize * 8)) - 1L
935 self.check_overflow(lower, upper)
Fred Drake004d5e62000-10-23 17:22:08 +0000936
937
Walter Dörwald7fd94242003-05-18 00:47:47 +0000938class ByteTest(SignedNumberTest):
939 typecode = 'b'
940 minitemsize = 1
941tests.append(ByteTest)
Fred Drake004d5e62000-10-23 17:22:08 +0000942
Walter Dörwald7fd94242003-05-18 00:47:47 +0000943class UnsignedByteTest(UnsignedNumberTest):
944 typecode = 'B'
945 minitemsize = 1
946tests.append(UnsignedByteTest)
947
948class ShortTest(SignedNumberTest):
949 typecode = 'h'
950 minitemsize = 2
951tests.append(ShortTest)
952
953class UnsignedShortTest(UnsignedNumberTest):
954 typecode = 'H'
955 minitemsize = 2
956tests.append(UnsignedShortTest)
957
958class IntTest(SignedNumberTest):
959 typecode = 'i'
960 minitemsize = 2
961tests.append(IntTest)
962
963class UnsignedIntTest(UnsignedNumberTest):
964 typecode = 'I'
965 minitemsize = 2
966tests.append(UnsignedIntTest)
967
968class LongTest(SignedNumberTest):
969 typecode = 'l'
970 minitemsize = 4
971tests.append(LongTest)
972
973class UnsignedLongTest(UnsignedNumberTest):
974 typecode = 'L'
975 minitemsize = 4
976tests.append(UnsignedLongTest)
977
978class FPTest(NumberTest):
979 example = [-42.0, 0, 42, 1e5, -1e10]
980 smallerexample = [-42.0, 0, 42, 1e5, -2e10]
981 biggerexample = [-42.0, 0, 42, 1e5, 1e10]
982 outside = 23
983
984 def assertEntryEqual(self, entry1, entry2):
985 self.assertAlmostEqual(entry1, entry2)
986
Walter Dörwaldcf99b0a2003-05-22 13:15:31 +0000987 def test_byteswap(self):
988 a = array.array(self.typecode, self.example)
989 self.assertRaises(TypeError, a.byteswap, 42)
990 if a.itemsize in (1, 2, 4, 8):
991 b = array.array(self.typecode, self.example)
992 b.byteswap()
993 if a.itemsize==1:
994 self.assertEqual(a, b)
995 else:
996 # On alphas treating the byte swapped bit patters as
997 # floats/doubles results in floating point exceptions
998 # => compare the 8bit string values instead
999 self.assertNotEqual(a.tostring(), b.tostring())
1000 b.byteswap()
1001 self.assertEqual(a, b)
1002
Neal Norwitz35c6cd02003-05-22 13:29:15 +00001003class FloatTest(FPTest):
1004 typecode = 'f'
1005 minitemsize = 4
Walter Dörwald7fd94242003-05-18 00:47:47 +00001006tests.append(FloatTest)
1007
1008class DoubleTest(FPTest):
1009 typecode = 'd'
1010 minitemsize = 8
1011tests.append(DoubleTest)
1012
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +00001013def test_main(verbose=None):
1014 import sys
1015
Walter Dörwald7fd94242003-05-18 00:47:47 +00001016 test_support.run_unittest(*tests)
1017
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +00001018 # verify reference counting
1019 if verbose and hasattr(sys, "gettotalrefcount"):
1020 import gc
1021 counts = [None] * 5
1022 for i in xrange(len(counts)):
1023 test_support.run_unittest(*tests)
1024 gc.collect()
1025 counts[i] = sys.gettotalrefcount()
1026 print counts
1027
1028if __name__ == "__main__":
1029 test_main(verbose=True)