blob: 02215e5ab96e95e8b621ece2a2b04377f5f0b776 [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
Walter Dörwald7fd94242003-05-18 00:47:47 +00009import array, cStringIO, math
Guido van Rossumbf12cdb2006-08-17 20:24:18 +000010from pickle import loads, dumps
Raymond Hettingerb0900e62004-12-16 16:23:40 +000011
12class ArraySubclass(array.array):
13 pass
Guido van Rossumc9f8f141997-04-09 20:51:54 +000014
Thomas Woutersb2137042007-02-01 18:02:27 +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)
Guido van Rossume2a383d2007-01-15 16:59:06 +000068 self.assert_(isinstance(bi[0], (int, int)))
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 Wouters89f507f2006-12-13 04:49:30 +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
Walter Dörwald7fd94242003-05-18 00:47:47 +0000114 def test_insert(self):
115 a = array.array(self.typecode, self.example)
116 a.insert(0, self.example[0])
117 self.assertEqual(len(a), 1+len(self.example))
118 self.assertEqual(a[0], a[1])
119 self.assertRaises(TypeError, a.insert)
120 self.assertRaises(TypeError, a.insert, None)
Walter Dörwaldba39d9c2003-05-18 01:56:25 +0000121 self.assertRaises(TypeError, a.insert, 0, None)
Martin v. Löwis99866332002-03-01 10:27:01 +0000122
Walter Dörwald9e46abe2003-05-18 03:15:10 +0000123 a = array.array(self.typecode, self.example)
124 a.insert(-1, self.example[0])
125 self.assertEqual(
126 a,
127 array.array(
128 self.typecode,
129 self.example[:-1] + self.example[:1] + self.example[-1:]
130 )
131 )
132
133 a = array.array(self.typecode, self.example)
134 a.insert(-1000, self.example[0])
135 self.assertEqual(
136 a,
137 array.array(self.typecode, self.example[:1] + self.example)
138 )
139
140 a = array.array(self.typecode, self.example)
141 a.insert(1000, self.example[0])
142 self.assertEqual(
143 a,
144 array.array(self.typecode, self.example + self.example[:1])
145 )
146
Walter Dörwald7fd94242003-05-18 00:47:47 +0000147 def test_tofromfile(self):
148 a = array.array(self.typecode, 2*self.example)
149 self.assertRaises(TypeError, a.tofile)
150 self.assertRaises(TypeError, a.tofile, cStringIO.StringIO())
151 f = open(test_support.TESTFN, 'wb')
152 try:
153 a.tofile(f)
154 f.close()
155 b = array.array(self.typecode)
156 f = open(test_support.TESTFN, 'rb')
157 self.assertRaises(TypeError, b.fromfile)
158 self.assertRaises(
159 TypeError,
160 b.fromfile,
161 cStringIO.StringIO(), len(self.example)
162 )
163 b.fromfile(f, len(self.example))
164 self.assertEqual(b, array.array(self.typecode, self.example))
165 self.assertNotEqual(a, b)
166 b.fromfile(f, len(self.example))
167 self.assertEqual(a, b)
168 self.assertRaises(EOFError, b.fromfile, f, 1)
169 f.close()
170 finally:
171 if not f.closed:
172 f.close()
173 test_support.unlink(test_support.TESTFN)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000174
Walter Dörwald7fd94242003-05-18 00:47:47 +0000175 def test_tofromlist(self):
176 a = array.array(self.typecode, 2*self.example)
177 b = array.array(self.typecode)
178 self.assertRaises(TypeError, a.tolist, 42)
179 self.assertRaises(TypeError, b.fromlist)
180 self.assertRaises(TypeError, b.fromlist, 42)
181 self.assertRaises(TypeError, b.fromlist, [None])
182 b.fromlist(a.tolist())
183 self.assertEqual(a, b)
Fred Drake78334472000-06-28 17:50:51 +0000184
Walter Dörwald7fd94242003-05-18 00:47:47 +0000185 def test_tofromstring(self):
186 a = array.array(self.typecode, 2*self.example)
187 b = array.array(self.typecode)
188 self.assertRaises(TypeError, a.tostring, 42)
189 self.assertRaises(TypeError, b.fromstring)
190 self.assertRaises(TypeError, b.fromstring, 42)
191 b.fromstring(a.tostring())
192 self.assertEqual(a, b)
193 if a.itemsize>1:
194 self.assertRaises(ValueError, b.fromstring, "x")
Fred Drake78334472000-06-28 17:50:51 +0000195
Walter Dörwald7fd94242003-05-18 00:47:47 +0000196 def test_repr(self):
197 a = array.array(self.typecode, 2*self.example)
198 self.assertEqual(a, eval(repr(a), {"array": array.array}))
Fred Drake78334472000-06-28 17:50:51 +0000199
Walter Dörwald7fd94242003-05-18 00:47:47 +0000200 a = array.array(self.typecode)
201 self.assertEqual(repr(a), "array('%s')" % self.typecode)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000202
Walter Dörwald7fd94242003-05-18 00:47:47 +0000203 def test_str(self):
204 a = array.array(self.typecode, 2*self.example)
205 str(a)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000206
Walter Dörwald7fd94242003-05-18 00:47:47 +0000207 def test_cmp(self):
208 a = array.array(self.typecode, self.example)
209 self.assert_((a == 42) is False)
210 self.assert_((a != 42) is True)
Tim Peterscc78e472000-11-14 21:36:07 +0000211
Walter Dörwald7fd94242003-05-18 00:47:47 +0000212 self.assert_((a == a) is True)
213 self.assert_((a != a) is False)
214 self.assert_((a < a) is False)
215 self.assert_((a <= a) is True)
216 self.assert_((a > a) is False)
217 self.assert_((a >= a) is True)
Tim Peterscc78e472000-11-14 21:36:07 +0000218
Neal Norwitzbd2835c2006-03-17 08:54:15 +0000219 al = array.array(self.typecode, self.smallerexample)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000220 ab = array.array(self.typecode, self.biggerexample)
Guido van Rossum7f1d3aa1998-07-16 15:31:43 +0000221
Walter Dörwald7fd94242003-05-18 00:47:47 +0000222 self.assert_((a == 2*a) is False)
223 self.assert_((a != 2*a) is True)
224 self.assert_((a < 2*a) is True)
225 self.assert_((a <= 2*a) is True)
226 self.assert_((a > 2*a) is False)
227 self.assert_((a >= 2*a) is False)
Martin v. Löwis99866332002-03-01 10:27:01 +0000228
Neal Norwitzbd2835c2006-03-17 08:54:15 +0000229 self.assert_((a == al) is False)
230 self.assert_((a != al) is True)
231 self.assert_((a < al) is False)
232 self.assert_((a <= al) is False)
233 self.assert_((a > al) is True)
234 self.assert_((a >= al) is True)
Martin v. Löwis99866332002-03-01 10:27:01 +0000235
Walter Dörwald7fd94242003-05-18 00:47:47 +0000236 self.assert_((a == ab) is False)
237 self.assert_((a != ab) is True)
238 self.assert_((a < ab) is True)
239 self.assert_((a <= ab) is True)
240 self.assert_((a > ab) is False)
241 self.assert_((a >= ab) is False)
Martin v. Löwis99866332002-03-01 10:27:01 +0000242
Walter Dörwald7fd94242003-05-18 00:47:47 +0000243 def test_add(self):
244 a = array.array(self.typecode, self.example) \
245 + array.array(self.typecode, self.example[::-1])
246 self.assertEqual(
247 a,
248 array.array(self.typecode, self.example + self.example[::-1])
249 )
Martin v. Löwis99866332002-03-01 10:27:01 +0000250
Walter Dörwald7fd94242003-05-18 00:47:47 +0000251 b = array.array(self.badtypecode())
252 self.assertRaises(TypeError, a.__add__, b)
253
254 self.assertRaises(TypeError, a.__add__, "bad")
255
256 def test_iadd(self):
257 a = array.array(self.typecode, self.example[::-1])
258 b = a
259 a += array.array(self.typecode, 2*self.example)
260 self.assert_(a is b)
261 self.assertEqual(
262 a,
263 array.array(self.typecode, self.example[::-1]+2*self.example)
264 )
265
266 b = array.array(self.badtypecode())
267 self.assertRaises(TypeError, a.__add__, b)
268
269 self.assertRaises(TypeError, a.__iadd__, "bad")
270
271 def test_mul(self):
272 a = 5*array.array(self.typecode, self.example)
273 self.assertEqual(
274 a,
275 array.array(self.typecode, 5*self.example)
276 )
277
278 a = array.array(self.typecode, self.example)*5
279 self.assertEqual(
280 a,
281 array.array(self.typecode, self.example*5)
282 )
283
284 a = 0*array.array(self.typecode, self.example)
285 self.assertEqual(
286 a,
287 array.array(self.typecode)
288 )
289
290 a = (-1)*array.array(self.typecode, self.example)
291 self.assertEqual(
292 a,
293 array.array(self.typecode)
294 )
295
296 self.assertRaises(TypeError, a.__mul__, "bad")
297
298 def test_imul(self):
299 a = array.array(self.typecode, self.example)
300 b = a
301
302 a *= 5
303 self.assert_(a is b)
304 self.assertEqual(
305 a,
306 array.array(self.typecode, 5*self.example)
307 )
308
309 a *= 0
310 self.assert_(a is b)
311 self.assertEqual(a, array.array(self.typecode))
312
313 a *= 1000
314 self.assert_(a is b)
315 self.assertEqual(a, array.array(self.typecode))
316
317 a *= -1
318 self.assert_(a is b)
319 self.assertEqual(a, array.array(self.typecode))
320
321 a = array.array(self.typecode, self.example)
322 a *= -1
323 self.assertEqual(a, array.array(self.typecode))
324
325 self.assertRaises(TypeError, a.__imul__, "bad")
326
327 def test_getitem(self):
328 a = array.array(self.typecode, self.example)
329 self.assertEntryEqual(a[0], self.example[0])
Guido van Rossume2a383d2007-01-15 16:59:06 +0000330 self.assertEntryEqual(a[0], self.example[0])
Walter Dörwald7fd94242003-05-18 00:47:47 +0000331 self.assertEntryEqual(a[-1], self.example[-1])
Guido van Rossume2a383d2007-01-15 16:59:06 +0000332 self.assertEntryEqual(a[-1], self.example[-1])
Walter Dörwald7fd94242003-05-18 00:47:47 +0000333 self.assertEntryEqual(a[len(self.example)-1], self.example[-1])
334 self.assertEntryEqual(a[-len(self.example)], self.example[0])
335 self.assertRaises(TypeError, a.__getitem__)
336 self.assertRaises(IndexError, a.__getitem__, len(self.example))
337 self.assertRaises(IndexError, a.__getitem__, -len(self.example)-1)
338
339 def test_setitem(self):
340 a = array.array(self.typecode, self.example)
341 a[0] = a[-1]
342 self.assertEntryEqual(a[0], a[-1])
343
344 a = array.array(self.typecode, self.example)
Guido van Rossume2a383d2007-01-15 16:59:06 +0000345 a[0] = a[-1]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000346 self.assertEntryEqual(a[0], a[-1])
347
348 a = array.array(self.typecode, self.example)
349 a[-1] = a[0]
350 self.assertEntryEqual(a[0], a[-1])
351
352 a = array.array(self.typecode, self.example)
Guido van Rossume2a383d2007-01-15 16:59:06 +0000353 a[-1] = a[0]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000354 self.assertEntryEqual(a[0], a[-1])
355
356 a = array.array(self.typecode, self.example)
357 a[len(self.example)-1] = a[0]
358 self.assertEntryEqual(a[0], a[-1])
359
360 a = array.array(self.typecode, self.example)
361 a[-len(self.example)] = a[-1]
362 self.assertEntryEqual(a[0], a[-1])
363
364 self.assertRaises(TypeError, a.__setitem__)
365 self.assertRaises(TypeError, a.__setitem__, None)
366 self.assertRaises(TypeError, a.__setitem__, 0, None)
367 self.assertRaises(
368 IndexError,
369 a.__setitem__,
370 len(self.example), self.example[0]
371 )
372 self.assertRaises(
373 IndexError,
374 a.__setitem__,
375 -len(self.example)-1, self.example[0]
376 )
377
378 def test_delitem(self):
379 a = array.array(self.typecode, self.example)
380 del a[0]
381 self.assertEqual(
382 a,
383 array.array(self.typecode, self.example[1:])
384 )
385
386 a = array.array(self.typecode, self.example)
387 del a[-1]
388 self.assertEqual(
389 a,
390 array.array(self.typecode, self.example[:-1])
391 )
392
393 a = array.array(self.typecode, self.example)
394 del a[len(self.example)-1]
395 self.assertEqual(
396 a,
397 array.array(self.typecode, self.example[:-1])
398 )
399
400 a = array.array(self.typecode, self.example)
401 del a[-len(self.example)]
402 self.assertEqual(
403 a,
404 array.array(self.typecode, self.example[1:])
405 )
406
407 self.assertRaises(TypeError, a.__delitem__)
408 self.assertRaises(TypeError, a.__delitem__, None)
409 self.assertRaises(IndexError, a.__delitem__, len(self.example))
410 self.assertRaises(IndexError, a.__delitem__, -len(self.example)-1)
411
412 def test_getslice(self):
413 a = array.array(self.typecode, self.example)
414 self.assertEqual(a[:], a)
415
416 self.assertEqual(
417 a[1:],
418 array.array(self.typecode, self.example[1:])
419 )
420
421 self.assertEqual(
422 a[:1],
423 array.array(self.typecode, self.example[:1])
424 )
425
426 self.assertEqual(
427 a[:-1],
428 array.array(self.typecode, self.example[:-1])
429 )
430
431 self.assertEqual(
432 a[-1:],
433 array.array(self.typecode, self.example[-1:])
434 )
435
436 self.assertEqual(
437 a[-1:-1],
438 array.array(self.typecode)
439 )
440
441 self.assertEqual(
Walter Dörwald1083c242005-01-21 21:16:51 +0000442 a[2:1],
443 array.array(self.typecode)
444 )
445
446 self.assertEqual(
Walter Dörwald7fd94242003-05-18 00:47:47 +0000447 a[1000:],
448 array.array(self.typecode)
449 )
450 self.assertEqual(a[-1000:], a)
451 self.assertEqual(a[:1000], a)
452 self.assertEqual(
453 a[:-1000],
454 array.array(self.typecode)
455 )
456 self.assertEqual(a[-1000:1000], a)
457 self.assertEqual(
458 a[2000:1000],
459 array.array(self.typecode)
460 )
461
462 def test_setslice(self):
463 a = array.array(self.typecode, self.example)
464 a[:1] = a
465 self.assertEqual(
466 a,
467 array.array(self.typecode, self.example + self.example[1:])
468 )
469
470 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000471 a[:-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000472 self.assertEqual(
473 a,
474 array.array(self.typecode, self.example + self.example[-1:])
475 )
476
477 a = array.array(self.typecode, self.example)
478 a[-1:] = a
479 self.assertEqual(
480 a,
481 array.array(self.typecode, self.example[:-1] + self.example)
482 )
483
484 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000485 a[1:] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000486 self.assertEqual(
487 a,
488 array.array(self.typecode, self.example[:1] + self.example)
489 )
490
491 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000492 a[1:-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000493 self.assertEqual(
494 a,
495 array.array(
496 self.typecode,
497 self.example[:1] + self.example + self.example[-1:]
498 )
499 )
500
501 a = array.array(self.typecode, self.example)
502 a[1000:] = a
503 self.assertEqual(
504 a,
505 array.array(self.typecode, 2*self.example)
506 )
507
508 a = array.array(self.typecode, self.example)
509 a[-1000:] = a
510 self.assertEqual(
511 a,
512 array.array(self.typecode, self.example)
513 )
514
515 a = array.array(self.typecode, self.example)
516 a[:1000] = a
517 self.assertEqual(
518 a,
519 array.array(self.typecode, self.example)
520 )
521
522 a = array.array(self.typecode, self.example)
523 a[:-1000] = a
524 self.assertEqual(
525 a,
526 array.array(self.typecode, 2*self.example)
527 )
528
529 a = array.array(self.typecode, self.example)
530 a[1:0] = a
531 self.assertEqual(
532 a,
533 array.array(self.typecode, self.example[:1] + self.example + self.example[1:])
534 )
535
536 a = array.array(self.typecode, self.example)
537 a[2000:1000] = a
538 self.assertEqual(
539 a,
540 array.array(self.typecode, 2*self.example)
541 )
542
543 a = array.array(self.typecode, self.example)
544 self.assertRaises(TypeError, a.__setslice__, 0, 0, None)
545 self.assertRaises(TypeError, a.__setitem__, slice(0, 1), None)
546
547 b = array.array(self.badtypecode())
548 self.assertRaises(TypeError, a.__setslice__, 0, 0, b)
549 self.assertRaises(TypeError, a.__setitem__, slice(0, 1), b)
550
551 def test_index(self):
552 example = 2*self.example
553 a = array.array(self.typecode, example)
554 self.assertRaises(TypeError, a.index)
555 for x in example:
556 self.assertEqual(a.index(x), example.index(x))
557 self.assertRaises(ValueError, a.index, None)
558 self.assertRaises(ValueError, a.index, self.outside)
559
560 def test_count(self):
561 example = 2*self.example
562 a = array.array(self.typecode, example)
563 self.assertRaises(TypeError, a.count)
564 for x in example:
565 self.assertEqual(a.count(x), example.count(x))
566 self.assertEqual(a.count(self.outside), 0)
567 self.assertEqual(a.count(None), 0)
568
569 def test_remove(self):
570 for x in self.example:
571 example = 2*self.example
572 a = array.array(self.typecode, example)
573 pos = example.index(x)
574 example2 = example[:pos] + example[pos+1:]
575 a.remove(x)
576 self.assertEqual(a, array.array(self.typecode, example2))
577
578 a = array.array(self.typecode, self.example)
579 self.assertRaises(ValueError, a.remove, self.outside)
580
581 self.assertRaises(ValueError, a.remove, None)
582
583 def test_pop(self):
584 a = array.array(self.typecode)
585 self.assertRaises(IndexError, a.pop)
586
587 a = array.array(self.typecode, 2*self.example)
588 self.assertRaises(TypeError, a.pop, 42, 42)
589 self.assertRaises(TypeError, a.pop, None)
590 self.assertRaises(IndexError, a.pop, len(a))
591 self.assertRaises(IndexError, a.pop, -len(a)-1)
592
593 self.assertEntryEqual(a.pop(0), self.example[0])
594 self.assertEqual(
595 a,
596 array.array(self.typecode, self.example[1:]+self.example)
597 )
598 self.assertEntryEqual(a.pop(1), self.example[2])
599 self.assertEqual(
600 a,
601 array.array(self.typecode, self.example[1:2]+self.example[3:]+self.example)
602 )
603 self.assertEntryEqual(a.pop(0), self.example[1])
604 self.assertEntryEqual(a.pop(), self.example[-1])
605 self.assertEqual(
606 a,
607 array.array(self.typecode, self.example[3:]+self.example[:-1])
608 )
609
610 def test_reverse(self):
611 a = array.array(self.typecode, self.example)
612 self.assertRaises(TypeError, a.reverse, 42)
Fred Drake004d5e62000-10-23 17:22:08 +0000613 a.reverse()
Walter Dörwald7fd94242003-05-18 00:47:47 +0000614 self.assertEqual(
615 a,
616 array.array(self.typecode, self.example[::-1])
617 )
618
619 def test_extend(self):
620 a = array.array(self.typecode, self.example)
621 self.assertRaises(TypeError, a.extend)
622 a.extend(array.array(self.typecode, self.example[::-1]))
623 self.assertEqual(
624 a,
625 array.array(self.typecode, self.example+self.example[::-1])
626 )
627
628 b = array.array(self.badtypecode())
629 self.assertRaises(TypeError, a.extend, b)
630
Raymond Hettinger49f9bd12004-03-14 05:43:59 +0000631 a = array.array(self.typecode, self.example)
632 a.extend(self.example[::-1])
633 self.assertEqual(
634 a,
635 array.array(self.typecode, self.example+self.example[::-1])
636 )
637
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +0000638 def test_constructor_with_iterable_argument(self):
639 a = array.array(self.typecode, iter(self.example))
640 b = array.array(self.typecode, self.example)
641 self.assertEqual(a, b)
642
643 # non-iterable argument
644 self.assertRaises(TypeError, array.array, self.typecode, 10)
645
646 # pass through errors raised in __iter__
647 class A:
648 def __iter__(self):
649 raise UnicodeError
650 self.assertRaises(UnicodeError, array.array, self.typecode, A())
651
652 # pass through errors raised in next()
653 def B():
654 raise UnicodeError
655 yield None
656 self.assertRaises(UnicodeError, array.array, self.typecode, B())
657
Walter Dörwald7fd94242003-05-18 00:47:47 +0000658 def test_coveritertraverse(self):
659 try:
660 import gc
661 except ImportError:
662 return
663 a = array.array(self.typecode)
664 l = [iter(a)]
665 l.append(l)
666 gc.collect()
667
668 def test_buffer(self):
669 a = array.array(self.typecode, self.example)
670 b = buffer(a)
671 self.assertEqual(b[0], a.tostring()[0])
672
Raymond Hettingercb87bc82004-05-31 00:35:52 +0000673 def test_weakref(self):
674 s = array.array(self.typecode, self.example)
675 p = proxy(s)
676 self.assertEqual(p.tostring(), s.tostring())
677 s = None
678 self.assertRaises(ReferenceError, len, p)
679
Skip Montanarod5cf0b82003-08-03 23:02:10 +0000680 def test_bug_782369(self):
681 import sys
Skip Montanaroed9bf122003-08-03 23:30:40 +0000682 if hasattr(sys, "getrefcount"):
683 for i in range(10):
684 b = array.array('B', range(64))
685 rc = sys.getrefcount(10)
686 for i in range(10):
687 b = array.array('B', range(64))
688 self.assertEqual(rc, sys.getrefcount(10))
Skip Montanarod5cf0b82003-08-03 23:02:10 +0000689
Thomas Woutersb2137042007-02-01 18:02:27 +0000690 def test_subclass_with_kwargs(self):
691 # SF bug #1486663 -- this used to erroneously raise a TypeError
692 ArraySubclassWithKwargs('b', newarg=1)
Raymond Hettingercb87bc82004-05-31 00:35:52 +0000693
694
Walter Dörwald7fd94242003-05-18 00:47:47 +0000695class StringTest(BaseTest):
696
697 def test_setitem(self):
698 super(StringTest, self).test_setitem()
699 a = array.array(self.typecode, self.example)
700 self.assertRaises(TypeError, a.__setitem__, 0, self.example[:2])
701
702class CharacterTest(StringTest):
703 typecode = 'c'
704 example = '\x01azAZ\x00\xfe'
705 smallerexample = '\x01azAY\x00\xfe'
706 biggerexample = '\x01azAZ\x00\xff'
707 outside = '\x33'
708 minitemsize = 1
709
710 def test_subbclassing(self):
711 class EditableString(array.array):
712 def __new__(cls, s, *args, **kwargs):
713 return array.array.__new__(cls, 'c', s)
714
715 def __init__(self, s, color='blue'):
716 array.array.__init__(self, 'c', s)
717 self.color = color
718
719 def strip(self):
720 self[:] = array.array('c', self.tostring().strip())
721
722 def __repr__(self):
723 return 'EditableString(%r)' % self.tostring()
724
725 s = EditableString("\ttest\r\n")
726 s.strip()
727 self.assertEqual(s.tostring(), "test")
728
729 self.assertEqual(s.color, "blue")
730 s.color = "red"
731 self.assertEqual(s.color, "red")
732 self.assertEqual(s.__dict__.keys(), ["color"])
733
734 def test_nounicode(self):
735 a = array.array(self.typecode, self.example)
736 self.assertRaises(ValueError, a.fromunicode, unicode(''))
737 self.assertRaises(ValueError, a.tounicode)
738
739tests.append(CharacterTest)
740
741if test_support.have_unicode:
742 class UnicodeTest(StringTest):
743 typecode = 'u'
744 example = unicode(r'\x01\u263a\x00\ufeff', 'unicode-escape')
745 smallerexample = unicode(r'\x01\u263a\x00\ufefe', 'unicode-escape')
746 biggerexample = unicode(r'\x01\u263a\x01\ufeff', 'unicode-escape')
747 outside = unicode('\x33')
748 minitemsize = 2
749
750 def test_unicode(self):
751 self.assertRaises(TypeError, array.array, 'b', unicode('foo', 'ascii'))
752
753 a = array.array('u', unicode(r'\xa0\xc2\u1234', 'unicode-escape'))
754 a.fromunicode(unicode(' ', 'ascii'))
755 a.fromunicode(unicode('', 'ascii'))
756 a.fromunicode(unicode('', 'ascii'))
757 a.fromunicode(unicode(r'\x11abc\xff\u1234', 'unicode-escape'))
758 s = a.tounicode()
759 self.assertEqual(
760 s,
761 unicode(r'\xa0\xc2\u1234 \x11abc\xff\u1234', 'unicode-escape')
762 )
763
764 s = unicode(r'\x00="\'a\\b\x80\xff\u0000\u0001\u1234', 'unicode-escape')
765 a = array.array('u', s)
766 self.assertEqual(
767 repr(a),
768 r"""array('u', u'\x00="\'a\\b\x80\xff\x00\x01\u1234')"""
769 )
770
771 self.assertRaises(TypeError, a.fromunicode)
772
773 tests.append(UnicodeTest)
774
775class NumberTest(BaseTest):
776
777 def test_extslice(self):
778 a = array.array(self.typecode, range(5))
779 self.assertEqual(a[::], a)
780 self.assertEqual(a[::2], array.array(self.typecode, [0,2,4]))
781 self.assertEqual(a[1::2], array.array(self.typecode, [1,3]))
782 self.assertEqual(a[::-1], array.array(self.typecode, [4,3,2,1,0]))
783 self.assertEqual(a[::-2], array.array(self.typecode, [4,2,0]))
784 self.assertEqual(a[3::-2], array.array(self.typecode, [3,1]))
785 self.assertEqual(a[-100:100:], a)
786 self.assertEqual(a[100:-100:-1], a[::-1])
Guido van Rossume2a383d2007-01-15 16:59:06 +0000787 self.assertEqual(a[-100:100:2], array.array(self.typecode, [0,2,4]))
Walter Dörwald7fd94242003-05-18 00:47:47 +0000788 self.assertEqual(a[1000:2000:2], array.array(self.typecode, []))
789 self.assertEqual(a[-1000:-2000:-2], array.array(self.typecode, []))
790
791 def test_delslice(self):
792 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000793 del a[::2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000794 self.assertEqual(a, array.array(self.typecode, [1,3]))
795 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000796 del a[1::2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000797 self.assertEqual(a, array.array(self.typecode, [0,2,4]))
798 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000799 del a[1::-2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000800 self.assertEqual(a, array.array(self.typecode, [0,2,3,4]))
801 a = array.array(self.typecode, range(10))
Michael W. Hudson56796f62002-07-29 14:35:04 +0000802 del a[::1000]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000803 self.assertEqual(a, array.array(self.typecode, [1,2,3,4,5,6,7,8,9]))
804
805 def test_assignment(self):
806 a = array.array(self.typecode, range(10))
807 a[::2] = array.array(self.typecode, [42]*5)
808 self.assertEqual(a, array.array(self.typecode, [42, 1, 42, 3, 42, 5, 42, 7, 42, 9]))
809 a = array.array(self.typecode, range(10))
810 a[::-4] = array.array(self.typecode, [10]*3)
811 self.assertEqual(a, array.array(self.typecode, [0, 10, 2, 3, 4, 10, 6, 7, 8 ,10]))
812 a = array.array(self.typecode, range(4))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000813 a[::-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000814 self.assertEqual(a, array.array(self.typecode, [3, 2, 1, 0]))
815 a = array.array(self.typecode, range(10))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000816 b = a[:]
817 c = a[:]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000818 ins = array.array(self.typecode, range(2))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000819 a[2:3] = ins
820 b[slice(2,3)] = ins
821 c[2:3:] = ins
Fred Drake004d5e62000-10-23 17:22:08 +0000822
Walter Dörwald7fd94242003-05-18 00:47:47 +0000823 def test_iterationcontains(self):
824 a = array.array(self.typecode, range(10))
825 self.assertEqual(list(a), range(10))
826 b = array.array(self.typecode, [20])
827 self.assertEqual(a[-1] in a, True)
828 self.assertEqual(b[0] not in a, True)
829
830 def check_overflow(self, lower, upper):
831 # method to be used by subclasses
832
833 # should not overflow assigning lower limit
834 a = array.array(self.typecode, [lower])
835 a[0] = lower
836 # should overflow assigning less than lower limit
837 self.assertRaises(OverflowError, array.array, self.typecode, [lower-1])
838 self.assertRaises(OverflowError, a.__setitem__, 0, lower-1)
839 # should not overflow assigning upper limit
840 a = array.array(self.typecode, [upper])
841 a[0] = upper
842 # should overflow assigning more than upper limit
843 self.assertRaises(OverflowError, array.array, self.typecode, [upper+1])
844 self.assertRaises(OverflowError, a.__setitem__, 0, upper+1)
845
846 def test_subclassing(self):
847 typecode = self.typecode
848 class ExaggeratingArray(array.array):
849 __slots__ = ['offset']
850
851 def __new__(cls, typecode, data, offset):
852 return array.array.__new__(cls, typecode, data)
853
854 def __init__(self, typecode, data, offset):
855 self.offset = offset
856
857 def __getitem__(self, i):
858 return array.array.__getitem__(self, i) + self.offset
859
860 a = ExaggeratingArray(self.typecode, [3, 6, 7, 11], 4)
861 self.assertEntryEqual(a[0], 7)
862
863 self.assertRaises(AttributeError, setattr, a, "color", "blue")
864
865class SignedNumberTest(NumberTest):
866 example = [-1, 0, 1, 42, 0x7f]
867 smallerexample = [-1, 0, 1, 42, 0x7e]
868 biggerexample = [-1, 0, 1, 43, 0x7f]
869 outside = 23
870
871 def test_overflow(self):
872 a = array.array(self.typecode)
Guido van Rossume2a383d2007-01-15 16:59:06 +0000873 lower = -1 * int(pow(2, a.itemsize * 8 - 1))
874 upper = int(pow(2, a.itemsize * 8 - 1)) - 1
Walter Dörwald7fd94242003-05-18 00:47:47 +0000875 self.check_overflow(lower, upper)
876
877class UnsignedNumberTest(NumberTest):
878 example = [0, 1, 17, 23, 42, 0xff]
879 smallerexample = [0, 1, 17, 23, 42, 0xfe]
880 biggerexample = [0, 1, 17, 23, 43, 0xff]
881 outside = 0xaa
882
883 def test_overflow(self):
884 a = array.array(self.typecode)
885 lower = 0
Guido van Rossume2a383d2007-01-15 16:59:06 +0000886 upper = int(pow(2, a.itemsize * 8)) - 1
Walter Dörwald7fd94242003-05-18 00:47:47 +0000887 self.check_overflow(lower, upper)
Fred Drake004d5e62000-10-23 17:22:08 +0000888
889
Walter Dörwald7fd94242003-05-18 00:47:47 +0000890class ByteTest(SignedNumberTest):
891 typecode = 'b'
892 minitemsize = 1
893tests.append(ByteTest)
Fred Drake004d5e62000-10-23 17:22:08 +0000894
Walter Dörwald7fd94242003-05-18 00:47:47 +0000895class UnsignedByteTest(UnsignedNumberTest):
896 typecode = 'B'
897 minitemsize = 1
898tests.append(UnsignedByteTest)
899
900class ShortTest(SignedNumberTest):
901 typecode = 'h'
902 minitemsize = 2
903tests.append(ShortTest)
904
905class UnsignedShortTest(UnsignedNumberTest):
906 typecode = 'H'
907 minitemsize = 2
908tests.append(UnsignedShortTest)
909
910class IntTest(SignedNumberTest):
911 typecode = 'i'
912 minitemsize = 2
913tests.append(IntTest)
914
915class UnsignedIntTest(UnsignedNumberTest):
916 typecode = 'I'
917 minitemsize = 2
918tests.append(UnsignedIntTest)
919
920class LongTest(SignedNumberTest):
921 typecode = 'l'
922 minitemsize = 4
923tests.append(LongTest)
924
925class UnsignedLongTest(UnsignedNumberTest):
926 typecode = 'L'
927 minitemsize = 4
928tests.append(UnsignedLongTest)
929
930class FPTest(NumberTest):
931 example = [-42.0, 0, 42, 1e5, -1e10]
932 smallerexample = [-42.0, 0, 42, 1e5, -2e10]
933 biggerexample = [-42.0, 0, 42, 1e5, 1e10]
934 outside = 23
935
936 def assertEntryEqual(self, entry1, entry2):
937 self.assertAlmostEqual(entry1, entry2)
938
Walter Dörwaldcf99b0a2003-05-22 13:15:31 +0000939 def test_byteswap(self):
940 a = array.array(self.typecode, self.example)
941 self.assertRaises(TypeError, a.byteswap, 42)
942 if a.itemsize in (1, 2, 4, 8):
943 b = array.array(self.typecode, self.example)
944 b.byteswap()
945 if a.itemsize==1:
946 self.assertEqual(a, b)
947 else:
948 # On alphas treating the byte swapped bit patters as
949 # floats/doubles results in floating point exceptions
950 # => compare the 8bit string values instead
951 self.assertNotEqual(a.tostring(), b.tostring())
952 b.byteswap()
953 self.assertEqual(a, b)
954
Neal Norwitz35c6cd02003-05-22 13:29:15 +0000955class FloatTest(FPTest):
956 typecode = 'f'
957 minitemsize = 4
Walter Dörwald7fd94242003-05-18 00:47:47 +0000958tests.append(FloatTest)
959
960class DoubleTest(FPTest):
961 typecode = 'd'
962 minitemsize = 8
963tests.append(DoubleTest)
964
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +0000965def test_main(verbose=None):
966 import sys
967
Walter Dörwald7fd94242003-05-18 00:47:47 +0000968 test_support.run_unittest(*tests)
969
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +0000970 # verify reference counting
971 if verbose and hasattr(sys, "gettotalrefcount"):
972 import gc
973 counts = [None] * 5
974 for i in xrange(len(counts)):
975 test_support.run_unittest(*tests)
976 gc.collect()
977 counts[i] = sys.gettotalrefcount()
978 print counts
979
980if __name__ == "__main__":
981 test_main(verbose=True)