blob: c24b41b931a825971a0435388e479458831795aa [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
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
Walter Dörwald7fd94242003-05-18 00:47:47 +000015tests = [] # list to accumulate all tests
16typecodes = "cubBhHiIlLfd"
Martin v. Löwis99866332002-03-01 10:27:01 +000017
Walter Dörwald7fd94242003-05-18 00:47:47 +000018class BadConstructorTest(unittest.TestCase):
Martin v. Löwis99866332002-03-01 10:27:01 +000019
Walter Dörwald7fd94242003-05-18 00:47:47 +000020 def test_constructor(self):
21 self.assertRaises(TypeError, array.array)
22 self.assertRaises(TypeError, array.array, spam=42)
23 self.assertRaises(TypeError, array.array, 'xx')
24 self.assertRaises(ValueError, array.array, 'x')
Martin v. Löwis99866332002-03-01 10:27:01 +000025
Walter Dörwald7fd94242003-05-18 00:47:47 +000026tests.append(BadConstructorTest)
Martin v. Löwis99866332002-03-01 10:27:01 +000027
Walter Dörwald7fd94242003-05-18 00:47:47 +000028class BaseTest(unittest.TestCase):
29 # Required class attributes (provided by subclasses
30 # typecode: the typecode to test
31 # example: an initializer usable in the constructor for this type
32 # smallerexample: the same length as example, but smaller
33 # biggerexample: the same length as example, but bigger
34 # outside: An entry that is not in example
35 # minitemsize: the minimum guaranteed itemsize
Martin v. Löwis99866332002-03-01 10:27:01 +000036
Walter Dörwald7fd94242003-05-18 00:47:47 +000037 def assertEntryEqual(self, entry1, entry2):
38 self.assertEqual(entry1, entry2)
Martin v. Löwis99866332002-03-01 10:27:01 +000039
Walter Dörwald7fd94242003-05-18 00:47:47 +000040 def badtypecode(self):
41 # Return a typecode that is different from our own
42 return typecodes[(typecodes.index(self.typecode)+1) % len(typecodes)]
Martin v. Löwis99866332002-03-01 10:27:01 +000043
Walter Dörwald7fd94242003-05-18 00:47:47 +000044 def test_constructor(self):
45 a = array.array(self.typecode)
46 self.assertEqual(a.typecode, self.typecode)
47 self.assert_(a.itemsize>=self.minitemsize)
48 self.assertRaises(TypeError, array.array, self.typecode, None)
Martin v. Löwis99866332002-03-01 10:27:01 +000049
Walter Dörwald7fd94242003-05-18 00:47:47 +000050 def test_len(self):
51 a = array.array(self.typecode)
52 a.append(self.example[0])
53 self.assertEqual(len(a), 1)
Martin v. Löwis99866332002-03-01 10:27:01 +000054
Walter Dörwald7fd94242003-05-18 00:47:47 +000055 a = array.array(self.typecode, self.example)
56 self.assertEqual(len(a), len(self.example))
Martin v. Löwis99866332002-03-01 10:27:01 +000057
Walter Dörwald7fd94242003-05-18 00:47:47 +000058 def test_buffer_info(self):
59 a = array.array(self.typecode, self.example)
60 self.assertRaises(TypeError, a.buffer_info, 42)
61 bi = a.buffer_info()
62 self.assert_(isinstance(bi, tuple))
63 self.assertEqual(len(bi), 2)
64 self.assert_(isinstance(bi[0], int))
65 self.assert_(isinstance(bi[1], int))
66 self.assertEqual(bi[1], len(a))
Martin v. Löwis99866332002-03-01 10:27:01 +000067
Walter Dörwald7fd94242003-05-18 00:47:47 +000068 def test_byteswap(self):
69 a = array.array(self.typecode, self.example)
70 self.assertRaises(TypeError, a.byteswap, 42)
71 if a.itemsize in (1, 2, 4, 8):
72 b = array.array(self.typecode, self.example)
73 b.byteswap()
74 if a.itemsize==1:
75 self.assertEqual(a, b)
76 else:
77 self.assertNotEqual(a, b)
78 b.byteswap()
79 self.assertEqual(a, b)
Martin v. Löwis99866332002-03-01 10:27:01 +000080
Raymond Hettinger3aa82c02004-03-13 18:18:51 +000081 def test_copy(self):
82 import copy
83 a = array.array(self.typecode, self.example)
84 b = copy.copy(a)
85 self.assertNotEqual(id(a), id(b))
86 self.assertEqual(a, b)
87
Raymond Hettingerb0900e62004-12-16 16:23:40 +000088 def test_pickle(self):
89 for protocol in (0, 1, 2):
90 a = array.array(self.typecode, self.example)
91 b = loads(dumps(a, protocol))
92 self.assertNotEqual(id(a), id(b))
93 self.assertEqual(a, b)
94
95 a = ArraySubclass(self.typecode, self.example)
96 a.x = 10
97 b = loads(dumps(a, protocol))
98 self.assertNotEqual(id(a), id(b))
99 self.assertEqual(a, b)
100 self.assertEqual(a.x, b.x)
101 self.assertEqual(type(a), type(b))
102
Walter Dörwald7fd94242003-05-18 00:47:47 +0000103 def test_insert(self):
104 a = array.array(self.typecode, self.example)
105 a.insert(0, self.example[0])
106 self.assertEqual(len(a), 1+len(self.example))
107 self.assertEqual(a[0], a[1])
108 self.assertRaises(TypeError, a.insert)
109 self.assertRaises(TypeError, a.insert, None)
Walter Dörwaldba39d9c2003-05-18 01:56:25 +0000110 self.assertRaises(TypeError, a.insert, 0, None)
Martin v. Löwis99866332002-03-01 10:27:01 +0000111
Walter Dörwald9e46abe2003-05-18 03:15:10 +0000112 a = array.array(self.typecode, self.example)
113 a.insert(-1, self.example[0])
114 self.assertEqual(
115 a,
116 array.array(
117 self.typecode,
118 self.example[:-1] + self.example[:1] + self.example[-1:]
119 )
120 )
121
122 a = array.array(self.typecode, self.example)
123 a.insert(-1000, self.example[0])
124 self.assertEqual(
125 a,
126 array.array(self.typecode, self.example[:1] + self.example)
127 )
128
129 a = array.array(self.typecode, self.example)
130 a.insert(1000, self.example[0])
131 self.assertEqual(
132 a,
133 array.array(self.typecode, self.example + self.example[:1])
134 )
135
Walter Dörwald7fd94242003-05-18 00:47:47 +0000136 def test_tofromfile(self):
137 a = array.array(self.typecode, 2*self.example)
138 self.assertRaises(TypeError, a.tofile)
139 self.assertRaises(TypeError, a.tofile, cStringIO.StringIO())
140 f = open(test_support.TESTFN, 'wb')
141 try:
142 a.tofile(f)
143 f.close()
144 b = array.array(self.typecode)
145 f = open(test_support.TESTFN, 'rb')
146 self.assertRaises(TypeError, b.fromfile)
147 self.assertRaises(
148 TypeError,
149 b.fromfile,
150 cStringIO.StringIO(), len(self.example)
151 )
152 b.fromfile(f, len(self.example))
153 self.assertEqual(b, array.array(self.typecode, self.example))
154 self.assertNotEqual(a, b)
155 b.fromfile(f, len(self.example))
156 self.assertEqual(a, b)
157 self.assertRaises(EOFError, b.fromfile, f, 1)
158 f.close()
159 finally:
160 if not f.closed:
161 f.close()
162 test_support.unlink(test_support.TESTFN)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000163
Walter Dörwald7fd94242003-05-18 00:47:47 +0000164 def test_tofromlist(self):
165 a = array.array(self.typecode, 2*self.example)
166 b = array.array(self.typecode)
167 self.assertRaises(TypeError, a.tolist, 42)
168 self.assertRaises(TypeError, b.fromlist)
169 self.assertRaises(TypeError, b.fromlist, 42)
170 self.assertRaises(TypeError, b.fromlist, [None])
171 b.fromlist(a.tolist())
172 self.assertEqual(a, b)
Fred Drake78334472000-06-28 17:50:51 +0000173
Walter Dörwald7fd94242003-05-18 00:47:47 +0000174 def test_tofromstring(self):
175 a = array.array(self.typecode, 2*self.example)
176 b = array.array(self.typecode)
177 self.assertRaises(TypeError, a.tostring, 42)
178 self.assertRaises(TypeError, b.fromstring)
179 self.assertRaises(TypeError, b.fromstring, 42)
180 b.fromstring(a.tostring())
181 self.assertEqual(a, b)
182 if a.itemsize>1:
183 self.assertRaises(ValueError, b.fromstring, "x")
Fred Drake78334472000-06-28 17:50:51 +0000184
Walter Dörwald7fd94242003-05-18 00:47:47 +0000185 def test_repr(self):
186 a = array.array(self.typecode, 2*self.example)
187 self.assertEqual(a, eval(repr(a), {"array": array.array}))
Fred Drake78334472000-06-28 17:50:51 +0000188
Walter Dörwald7fd94242003-05-18 00:47:47 +0000189 a = array.array(self.typecode)
190 self.assertEqual(repr(a), "array('%s')" % self.typecode)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000191
Walter Dörwald7fd94242003-05-18 00:47:47 +0000192 def test_str(self):
193 a = array.array(self.typecode, 2*self.example)
194 str(a)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000195
Walter Dörwald7fd94242003-05-18 00:47:47 +0000196 def test_cmp(self):
197 a = array.array(self.typecode, self.example)
198 self.assert_((a == 42) is False)
199 self.assert_((a != 42) is True)
Tim Peterscc78e472000-11-14 21:36:07 +0000200
Walter Dörwald7fd94242003-05-18 00:47:47 +0000201 self.assert_((a == a) is True)
202 self.assert_((a != a) is False)
203 self.assert_((a < a) is False)
204 self.assert_((a <= a) is True)
205 self.assert_((a > a) is False)
206 self.assert_((a >= a) is True)
Tim Peterscc78e472000-11-14 21:36:07 +0000207
Walter Dörwald7fd94242003-05-18 00:47:47 +0000208 as = array.array(self.typecode, self.smallerexample)
209 ab = array.array(self.typecode, self.biggerexample)
Guido van Rossum7f1d3aa1998-07-16 15:31:43 +0000210
Walter Dörwald7fd94242003-05-18 00:47:47 +0000211 self.assert_((a == 2*a) is False)
212 self.assert_((a != 2*a) is True)
213 self.assert_((a < 2*a) is True)
214 self.assert_((a <= 2*a) is True)
215 self.assert_((a > 2*a) is False)
216 self.assert_((a >= 2*a) is False)
Martin v. Löwis99866332002-03-01 10:27:01 +0000217
Walter Dörwald7fd94242003-05-18 00:47:47 +0000218 self.assert_((a == as) is False)
219 self.assert_((a != as) is True)
220 self.assert_((a < as) is False)
221 self.assert_((a <= as) is False)
222 self.assert_((a > as) is True)
223 self.assert_((a >= as) is True)
Martin v. Löwis99866332002-03-01 10:27:01 +0000224
Walter Dörwald7fd94242003-05-18 00:47:47 +0000225 self.assert_((a == ab) is False)
226 self.assert_((a != ab) is True)
227 self.assert_((a < ab) is True)
228 self.assert_((a <= ab) is True)
229 self.assert_((a > ab) is False)
230 self.assert_((a >= ab) is False)
Martin v. Löwis99866332002-03-01 10:27:01 +0000231
Walter Dörwald7fd94242003-05-18 00:47:47 +0000232 def test_add(self):
233 a = array.array(self.typecode, self.example) \
234 + array.array(self.typecode, self.example[::-1])
235 self.assertEqual(
236 a,
237 array.array(self.typecode, self.example + self.example[::-1])
238 )
Martin v. Löwis99866332002-03-01 10:27:01 +0000239
Walter Dörwald7fd94242003-05-18 00:47:47 +0000240 b = array.array(self.badtypecode())
241 self.assertRaises(TypeError, a.__add__, b)
242
243 self.assertRaises(TypeError, a.__add__, "bad")
244
245 def test_iadd(self):
246 a = array.array(self.typecode, self.example[::-1])
247 b = a
248 a += array.array(self.typecode, 2*self.example)
249 self.assert_(a is b)
250 self.assertEqual(
251 a,
252 array.array(self.typecode, self.example[::-1]+2*self.example)
253 )
254
255 b = array.array(self.badtypecode())
256 self.assertRaises(TypeError, a.__add__, b)
257
258 self.assertRaises(TypeError, a.__iadd__, "bad")
259
260 def test_mul(self):
261 a = 5*array.array(self.typecode, self.example)
262 self.assertEqual(
263 a,
264 array.array(self.typecode, 5*self.example)
265 )
266
267 a = array.array(self.typecode, self.example)*5
268 self.assertEqual(
269 a,
270 array.array(self.typecode, self.example*5)
271 )
272
273 a = 0*array.array(self.typecode, self.example)
274 self.assertEqual(
275 a,
276 array.array(self.typecode)
277 )
278
279 a = (-1)*array.array(self.typecode, self.example)
280 self.assertEqual(
281 a,
282 array.array(self.typecode)
283 )
284
285 self.assertRaises(TypeError, a.__mul__, "bad")
286
287 def test_imul(self):
288 a = array.array(self.typecode, self.example)
289 b = a
290
291 a *= 5
292 self.assert_(a is b)
293 self.assertEqual(
294 a,
295 array.array(self.typecode, 5*self.example)
296 )
297
298 a *= 0
299 self.assert_(a is b)
300 self.assertEqual(a, array.array(self.typecode))
301
302 a *= 1000
303 self.assert_(a is b)
304 self.assertEqual(a, array.array(self.typecode))
305
306 a *= -1
307 self.assert_(a is b)
308 self.assertEqual(a, array.array(self.typecode))
309
310 a = array.array(self.typecode, self.example)
311 a *= -1
312 self.assertEqual(a, array.array(self.typecode))
313
314 self.assertRaises(TypeError, a.__imul__, "bad")
315
316 def test_getitem(self):
317 a = array.array(self.typecode, self.example)
318 self.assertEntryEqual(a[0], self.example[0])
319 self.assertEntryEqual(a[0L], self.example[0])
320 self.assertEntryEqual(a[-1], self.example[-1])
321 self.assertEntryEqual(a[-1L], self.example[-1])
322 self.assertEntryEqual(a[len(self.example)-1], self.example[-1])
323 self.assertEntryEqual(a[-len(self.example)], self.example[0])
324 self.assertRaises(TypeError, a.__getitem__)
325 self.assertRaises(IndexError, a.__getitem__, len(self.example))
326 self.assertRaises(IndexError, a.__getitem__, -len(self.example)-1)
327
328 def test_setitem(self):
329 a = array.array(self.typecode, self.example)
330 a[0] = a[-1]
331 self.assertEntryEqual(a[0], a[-1])
332
333 a = array.array(self.typecode, self.example)
334 a[0L] = a[-1]
335 self.assertEntryEqual(a[0], a[-1])
336
337 a = array.array(self.typecode, self.example)
338 a[-1] = a[0]
339 self.assertEntryEqual(a[0], a[-1])
340
341 a = array.array(self.typecode, self.example)
342 a[-1L] = a[0]
343 self.assertEntryEqual(a[0], a[-1])
344
345 a = array.array(self.typecode, self.example)
346 a[len(self.example)-1] = a[0]
347 self.assertEntryEqual(a[0], a[-1])
348
349 a = array.array(self.typecode, self.example)
350 a[-len(self.example)] = a[-1]
351 self.assertEntryEqual(a[0], a[-1])
352
353 self.assertRaises(TypeError, a.__setitem__)
354 self.assertRaises(TypeError, a.__setitem__, None)
355 self.assertRaises(TypeError, a.__setitem__, 0, None)
356 self.assertRaises(
357 IndexError,
358 a.__setitem__,
359 len(self.example), self.example[0]
360 )
361 self.assertRaises(
362 IndexError,
363 a.__setitem__,
364 -len(self.example)-1, self.example[0]
365 )
366
367 def test_delitem(self):
368 a = array.array(self.typecode, self.example)
369 del a[0]
370 self.assertEqual(
371 a,
372 array.array(self.typecode, self.example[1:])
373 )
374
375 a = array.array(self.typecode, self.example)
376 del a[-1]
377 self.assertEqual(
378 a,
379 array.array(self.typecode, self.example[:-1])
380 )
381
382 a = array.array(self.typecode, self.example)
383 del a[len(self.example)-1]
384 self.assertEqual(
385 a,
386 array.array(self.typecode, self.example[:-1])
387 )
388
389 a = array.array(self.typecode, self.example)
390 del a[-len(self.example)]
391 self.assertEqual(
392 a,
393 array.array(self.typecode, self.example[1:])
394 )
395
396 self.assertRaises(TypeError, a.__delitem__)
397 self.assertRaises(TypeError, a.__delitem__, None)
398 self.assertRaises(IndexError, a.__delitem__, len(self.example))
399 self.assertRaises(IndexError, a.__delitem__, -len(self.example)-1)
400
401 def test_getslice(self):
402 a = array.array(self.typecode, self.example)
403 self.assertEqual(a[:], a)
404
405 self.assertEqual(
406 a[1:],
407 array.array(self.typecode, self.example[1:])
408 )
409
410 self.assertEqual(
411 a[:1],
412 array.array(self.typecode, self.example[:1])
413 )
414
415 self.assertEqual(
416 a[:-1],
417 array.array(self.typecode, self.example[:-1])
418 )
419
420 self.assertEqual(
421 a[-1:],
422 array.array(self.typecode, self.example[-1:])
423 )
424
425 self.assertEqual(
426 a[-1:-1],
427 array.array(self.typecode)
428 )
429
430 self.assertEqual(
431 a[1000:],
432 array.array(self.typecode)
433 )
434 self.assertEqual(a[-1000:], a)
435 self.assertEqual(a[:1000], a)
436 self.assertEqual(
437 a[:-1000],
438 array.array(self.typecode)
439 )
440 self.assertEqual(a[-1000:1000], a)
441 self.assertEqual(
442 a[2000:1000],
443 array.array(self.typecode)
444 )
445
446 def test_setslice(self):
447 a = array.array(self.typecode, self.example)
448 a[:1] = a
449 self.assertEqual(
450 a,
451 array.array(self.typecode, self.example + self.example[1:])
452 )
453
454 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000455 a[:-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000456 self.assertEqual(
457 a,
458 array.array(self.typecode, self.example + self.example[-1:])
459 )
460
461 a = array.array(self.typecode, self.example)
462 a[-1:] = a
463 self.assertEqual(
464 a,
465 array.array(self.typecode, self.example[:-1] + self.example)
466 )
467
468 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000469 a[1:] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000470 self.assertEqual(
471 a,
472 array.array(self.typecode, self.example[:1] + self.example)
473 )
474
475 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000476 a[1:-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000477 self.assertEqual(
478 a,
479 array.array(
480 self.typecode,
481 self.example[:1] + self.example + self.example[-1:]
482 )
483 )
484
485 a = array.array(self.typecode, self.example)
486 a[1000:] = a
487 self.assertEqual(
488 a,
489 array.array(self.typecode, 2*self.example)
490 )
491
492 a = array.array(self.typecode, self.example)
493 a[-1000:] = a
494 self.assertEqual(
495 a,
496 array.array(self.typecode, self.example)
497 )
498
499 a = array.array(self.typecode, self.example)
500 a[:1000] = a
501 self.assertEqual(
502 a,
503 array.array(self.typecode, self.example)
504 )
505
506 a = array.array(self.typecode, self.example)
507 a[:-1000] = a
508 self.assertEqual(
509 a,
510 array.array(self.typecode, 2*self.example)
511 )
512
513 a = array.array(self.typecode, self.example)
514 a[1:0] = a
515 self.assertEqual(
516 a,
517 array.array(self.typecode, self.example[:1] + self.example + self.example[1:])
518 )
519
520 a = array.array(self.typecode, self.example)
521 a[2000:1000] = a
522 self.assertEqual(
523 a,
524 array.array(self.typecode, 2*self.example)
525 )
526
527 a = array.array(self.typecode, self.example)
528 self.assertRaises(TypeError, a.__setslice__, 0, 0, None)
529 self.assertRaises(TypeError, a.__setitem__, slice(0, 1), None)
530
531 b = array.array(self.badtypecode())
532 self.assertRaises(TypeError, a.__setslice__, 0, 0, b)
533 self.assertRaises(TypeError, a.__setitem__, slice(0, 1), b)
534
535 def test_index(self):
536 example = 2*self.example
537 a = array.array(self.typecode, example)
538 self.assertRaises(TypeError, a.index)
539 for x in example:
540 self.assertEqual(a.index(x), example.index(x))
541 self.assertRaises(ValueError, a.index, None)
542 self.assertRaises(ValueError, a.index, self.outside)
543
544 def test_count(self):
545 example = 2*self.example
546 a = array.array(self.typecode, example)
547 self.assertRaises(TypeError, a.count)
548 for x in example:
549 self.assertEqual(a.count(x), example.count(x))
550 self.assertEqual(a.count(self.outside), 0)
551 self.assertEqual(a.count(None), 0)
552
553 def test_remove(self):
554 for x in self.example:
555 example = 2*self.example
556 a = array.array(self.typecode, example)
557 pos = example.index(x)
558 example2 = example[:pos] + example[pos+1:]
559 a.remove(x)
560 self.assertEqual(a, array.array(self.typecode, example2))
561
562 a = array.array(self.typecode, self.example)
563 self.assertRaises(ValueError, a.remove, self.outside)
564
565 self.assertRaises(ValueError, a.remove, None)
566
567 def test_pop(self):
568 a = array.array(self.typecode)
569 self.assertRaises(IndexError, a.pop)
570
571 a = array.array(self.typecode, 2*self.example)
572 self.assertRaises(TypeError, a.pop, 42, 42)
573 self.assertRaises(TypeError, a.pop, None)
574 self.assertRaises(IndexError, a.pop, len(a))
575 self.assertRaises(IndexError, a.pop, -len(a)-1)
576
577 self.assertEntryEqual(a.pop(0), self.example[0])
578 self.assertEqual(
579 a,
580 array.array(self.typecode, self.example[1:]+self.example)
581 )
582 self.assertEntryEqual(a.pop(1), self.example[2])
583 self.assertEqual(
584 a,
585 array.array(self.typecode, self.example[1:2]+self.example[3:]+self.example)
586 )
587 self.assertEntryEqual(a.pop(0), self.example[1])
588 self.assertEntryEqual(a.pop(), self.example[-1])
589 self.assertEqual(
590 a,
591 array.array(self.typecode, self.example[3:]+self.example[:-1])
592 )
593
594 def test_reverse(self):
595 a = array.array(self.typecode, self.example)
596 self.assertRaises(TypeError, a.reverse, 42)
Fred Drake004d5e62000-10-23 17:22:08 +0000597 a.reverse()
Walter Dörwald7fd94242003-05-18 00:47:47 +0000598 self.assertEqual(
599 a,
600 array.array(self.typecode, self.example[::-1])
601 )
602
603 def test_extend(self):
604 a = array.array(self.typecode, self.example)
605 self.assertRaises(TypeError, a.extend)
606 a.extend(array.array(self.typecode, self.example[::-1]))
607 self.assertEqual(
608 a,
609 array.array(self.typecode, self.example+self.example[::-1])
610 )
611
612 b = array.array(self.badtypecode())
613 self.assertRaises(TypeError, a.extend, b)
614
Raymond Hettinger49f9bd12004-03-14 05:43:59 +0000615 a = array.array(self.typecode, self.example)
616 a.extend(self.example[::-1])
617 self.assertEqual(
618 a,
619 array.array(self.typecode, self.example+self.example[::-1])
620 )
621
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +0000622 def test_constructor_with_iterable_argument(self):
623 a = array.array(self.typecode, iter(self.example))
624 b = array.array(self.typecode, self.example)
625 self.assertEqual(a, b)
626
627 # non-iterable argument
628 self.assertRaises(TypeError, array.array, self.typecode, 10)
629
630 # pass through errors raised in __iter__
631 class A:
632 def __iter__(self):
633 raise UnicodeError
634 self.assertRaises(UnicodeError, array.array, self.typecode, A())
635
636 # pass through errors raised in next()
637 def B():
638 raise UnicodeError
639 yield None
640 self.assertRaises(UnicodeError, array.array, self.typecode, B())
641
Walter Dörwald7fd94242003-05-18 00:47:47 +0000642 def test_coveritertraverse(self):
643 try:
644 import gc
645 except ImportError:
646 return
647 a = array.array(self.typecode)
648 l = [iter(a)]
649 l.append(l)
650 gc.collect()
651
652 def test_buffer(self):
653 a = array.array(self.typecode, self.example)
654 b = buffer(a)
655 self.assertEqual(b[0], a.tostring()[0])
656
Raymond Hettingercb87bc82004-05-31 00:35:52 +0000657 def test_weakref(self):
658 s = array.array(self.typecode, self.example)
659 p = proxy(s)
660 self.assertEqual(p.tostring(), s.tostring())
661 s = None
662 self.assertRaises(ReferenceError, len, p)
663
Skip Montanarod5cf0b82003-08-03 23:02:10 +0000664 def test_bug_782369(self):
665 import sys
Skip Montanaroed9bf122003-08-03 23:30:40 +0000666 if hasattr(sys, "getrefcount"):
667 for i in range(10):
668 b = array.array('B', range(64))
669 rc = sys.getrefcount(10)
670 for i in range(10):
671 b = array.array('B', range(64))
672 self.assertEqual(rc, sys.getrefcount(10))
Skip Montanarod5cf0b82003-08-03 23:02:10 +0000673
Raymond Hettingercb87bc82004-05-31 00:35:52 +0000674
675
Walter Dörwald7fd94242003-05-18 00:47:47 +0000676class StringTest(BaseTest):
677
678 def test_setitem(self):
679 super(StringTest, self).test_setitem()
680 a = array.array(self.typecode, self.example)
681 self.assertRaises(TypeError, a.__setitem__, 0, self.example[:2])
682
683class CharacterTest(StringTest):
684 typecode = 'c'
685 example = '\x01azAZ\x00\xfe'
686 smallerexample = '\x01azAY\x00\xfe'
687 biggerexample = '\x01azAZ\x00\xff'
688 outside = '\x33'
689 minitemsize = 1
690
691 def test_subbclassing(self):
692 class EditableString(array.array):
693 def __new__(cls, s, *args, **kwargs):
694 return array.array.__new__(cls, 'c', s)
695
696 def __init__(self, s, color='blue'):
697 array.array.__init__(self, 'c', s)
698 self.color = color
699
700 def strip(self):
701 self[:] = array.array('c', self.tostring().strip())
702
703 def __repr__(self):
704 return 'EditableString(%r)' % self.tostring()
705
706 s = EditableString("\ttest\r\n")
707 s.strip()
708 self.assertEqual(s.tostring(), "test")
709
710 self.assertEqual(s.color, "blue")
711 s.color = "red"
712 self.assertEqual(s.color, "red")
713 self.assertEqual(s.__dict__.keys(), ["color"])
714
715 def test_nounicode(self):
716 a = array.array(self.typecode, self.example)
717 self.assertRaises(ValueError, a.fromunicode, unicode(''))
718 self.assertRaises(ValueError, a.tounicode)
719
720tests.append(CharacterTest)
721
722if test_support.have_unicode:
723 class UnicodeTest(StringTest):
724 typecode = 'u'
725 example = unicode(r'\x01\u263a\x00\ufeff', 'unicode-escape')
726 smallerexample = unicode(r'\x01\u263a\x00\ufefe', 'unicode-escape')
727 biggerexample = unicode(r'\x01\u263a\x01\ufeff', 'unicode-escape')
728 outside = unicode('\x33')
729 minitemsize = 2
730
731 def test_unicode(self):
732 self.assertRaises(TypeError, array.array, 'b', unicode('foo', 'ascii'))
733
734 a = array.array('u', unicode(r'\xa0\xc2\u1234', 'unicode-escape'))
735 a.fromunicode(unicode(' ', 'ascii'))
736 a.fromunicode(unicode('', 'ascii'))
737 a.fromunicode(unicode('', 'ascii'))
738 a.fromunicode(unicode(r'\x11abc\xff\u1234', 'unicode-escape'))
739 s = a.tounicode()
740 self.assertEqual(
741 s,
742 unicode(r'\xa0\xc2\u1234 \x11abc\xff\u1234', 'unicode-escape')
743 )
744
745 s = unicode(r'\x00="\'a\\b\x80\xff\u0000\u0001\u1234', 'unicode-escape')
746 a = array.array('u', s)
747 self.assertEqual(
748 repr(a),
749 r"""array('u', u'\x00="\'a\\b\x80\xff\x00\x01\u1234')"""
750 )
751
752 self.assertRaises(TypeError, a.fromunicode)
753
754 tests.append(UnicodeTest)
755
756class NumberTest(BaseTest):
757
758 def test_extslice(self):
759 a = array.array(self.typecode, range(5))
760 self.assertEqual(a[::], a)
761 self.assertEqual(a[::2], array.array(self.typecode, [0,2,4]))
762 self.assertEqual(a[1::2], array.array(self.typecode, [1,3]))
763 self.assertEqual(a[::-1], array.array(self.typecode, [4,3,2,1,0]))
764 self.assertEqual(a[::-2], array.array(self.typecode, [4,2,0]))
765 self.assertEqual(a[3::-2], array.array(self.typecode, [3,1]))
766 self.assertEqual(a[-100:100:], a)
767 self.assertEqual(a[100:-100:-1], a[::-1])
768 self.assertEqual(a[-100L:100L:2L], array.array(self.typecode, [0,2,4]))
769 self.assertEqual(a[1000:2000:2], array.array(self.typecode, []))
770 self.assertEqual(a[-1000:-2000:-2], array.array(self.typecode, []))
771
772 def test_delslice(self):
773 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000774 del a[::2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000775 self.assertEqual(a, array.array(self.typecode, [1,3]))
776 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000777 del a[1::2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000778 self.assertEqual(a, array.array(self.typecode, [0,2,4]))
779 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000780 del a[1::-2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000781 self.assertEqual(a, array.array(self.typecode, [0,2,3,4]))
782 a = array.array(self.typecode, range(10))
Michael W. Hudson56796f62002-07-29 14:35:04 +0000783 del a[::1000]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000784 self.assertEqual(a, array.array(self.typecode, [1,2,3,4,5,6,7,8,9]))
785
786 def test_assignment(self):
787 a = array.array(self.typecode, range(10))
788 a[::2] = array.array(self.typecode, [42]*5)
789 self.assertEqual(a, array.array(self.typecode, [42, 1, 42, 3, 42, 5, 42, 7, 42, 9]))
790 a = array.array(self.typecode, range(10))
791 a[::-4] = array.array(self.typecode, [10]*3)
792 self.assertEqual(a, array.array(self.typecode, [0, 10, 2, 3, 4, 10, 6, 7, 8 ,10]))
793 a = array.array(self.typecode, range(4))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000794 a[::-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000795 self.assertEqual(a, array.array(self.typecode, [3, 2, 1, 0]))
796 a = array.array(self.typecode, range(10))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000797 b = a[:]
798 c = a[:]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000799 ins = array.array(self.typecode, range(2))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000800 a[2:3] = ins
801 b[slice(2,3)] = ins
802 c[2:3:] = ins
Fred Drake004d5e62000-10-23 17:22:08 +0000803
Walter Dörwald7fd94242003-05-18 00:47:47 +0000804 def test_iterationcontains(self):
805 a = array.array(self.typecode, range(10))
806 self.assertEqual(list(a), range(10))
807 b = array.array(self.typecode, [20])
808 self.assertEqual(a[-1] in a, True)
809 self.assertEqual(b[0] not in a, True)
810
811 def check_overflow(self, lower, upper):
812 # method to be used by subclasses
813
814 # should not overflow assigning lower limit
815 a = array.array(self.typecode, [lower])
816 a[0] = lower
817 # should overflow assigning less than lower limit
818 self.assertRaises(OverflowError, array.array, self.typecode, [lower-1])
819 self.assertRaises(OverflowError, a.__setitem__, 0, lower-1)
820 # should not overflow assigning upper limit
821 a = array.array(self.typecode, [upper])
822 a[0] = upper
823 # should overflow assigning more than upper limit
824 self.assertRaises(OverflowError, array.array, self.typecode, [upper+1])
825 self.assertRaises(OverflowError, a.__setitem__, 0, upper+1)
826
827 def test_subclassing(self):
828 typecode = self.typecode
829 class ExaggeratingArray(array.array):
830 __slots__ = ['offset']
831
832 def __new__(cls, typecode, data, offset):
833 return array.array.__new__(cls, typecode, data)
834
835 def __init__(self, typecode, data, offset):
836 self.offset = offset
837
838 def __getitem__(self, i):
839 return array.array.__getitem__(self, i) + self.offset
840
841 a = ExaggeratingArray(self.typecode, [3, 6, 7, 11], 4)
842 self.assertEntryEqual(a[0], 7)
843
844 self.assertRaises(AttributeError, setattr, a, "color", "blue")
845
846class SignedNumberTest(NumberTest):
847 example = [-1, 0, 1, 42, 0x7f]
848 smallerexample = [-1, 0, 1, 42, 0x7e]
849 biggerexample = [-1, 0, 1, 43, 0x7f]
850 outside = 23
851
852 def test_overflow(self):
853 a = array.array(self.typecode)
854 lower = -1 * long(pow(2, a.itemsize * 8 - 1))
855 upper = long(pow(2, a.itemsize * 8 - 1)) - 1L
856 self.check_overflow(lower, upper)
857
858class UnsignedNumberTest(NumberTest):
859 example = [0, 1, 17, 23, 42, 0xff]
860 smallerexample = [0, 1, 17, 23, 42, 0xfe]
861 biggerexample = [0, 1, 17, 23, 43, 0xff]
862 outside = 0xaa
863
864 def test_overflow(self):
865 a = array.array(self.typecode)
866 lower = 0
867 upper = long(pow(2, a.itemsize * 8)) - 1L
868 self.check_overflow(lower, upper)
Fred Drake004d5e62000-10-23 17:22:08 +0000869
870
Walter Dörwald7fd94242003-05-18 00:47:47 +0000871class ByteTest(SignedNumberTest):
872 typecode = 'b'
873 minitemsize = 1
874tests.append(ByteTest)
Fred Drake004d5e62000-10-23 17:22:08 +0000875
Walter Dörwald7fd94242003-05-18 00:47:47 +0000876class UnsignedByteTest(UnsignedNumberTest):
877 typecode = 'B'
878 minitemsize = 1
879tests.append(UnsignedByteTest)
880
881class ShortTest(SignedNumberTest):
882 typecode = 'h'
883 minitemsize = 2
884tests.append(ShortTest)
885
886class UnsignedShortTest(UnsignedNumberTest):
887 typecode = 'H'
888 minitemsize = 2
889tests.append(UnsignedShortTest)
890
891class IntTest(SignedNumberTest):
892 typecode = 'i'
893 minitemsize = 2
894tests.append(IntTest)
895
896class UnsignedIntTest(UnsignedNumberTest):
897 typecode = 'I'
898 minitemsize = 2
899tests.append(UnsignedIntTest)
900
901class LongTest(SignedNumberTest):
902 typecode = 'l'
903 minitemsize = 4
904tests.append(LongTest)
905
906class UnsignedLongTest(UnsignedNumberTest):
907 typecode = 'L'
908 minitemsize = 4
909tests.append(UnsignedLongTest)
910
911class FPTest(NumberTest):
912 example = [-42.0, 0, 42, 1e5, -1e10]
913 smallerexample = [-42.0, 0, 42, 1e5, -2e10]
914 biggerexample = [-42.0, 0, 42, 1e5, 1e10]
915 outside = 23
916
917 def assertEntryEqual(self, entry1, entry2):
918 self.assertAlmostEqual(entry1, entry2)
919
Walter Dörwaldcf99b0a2003-05-22 13:15:31 +0000920 def test_byteswap(self):
921 a = array.array(self.typecode, self.example)
922 self.assertRaises(TypeError, a.byteswap, 42)
923 if a.itemsize in (1, 2, 4, 8):
924 b = array.array(self.typecode, self.example)
925 b.byteswap()
926 if a.itemsize==1:
927 self.assertEqual(a, b)
928 else:
929 # On alphas treating the byte swapped bit patters as
930 # floats/doubles results in floating point exceptions
931 # => compare the 8bit string values instead
932 self.assertNotEqual(a.tostring(), b.tostring())
933 b.byteswap()
934 self.assertEqual(a, b)
935
Neal Norwitz35c6cd02003-05-22 13:29:15 +0000936class FloatTest(FPTest):
937 typecode = 'f'
938 minitemsize = 4
Walter Dörwald7fd94242003-05-18 00:47:47 +0000939tests.append(FloatTest)
940
941class DoubleTest(FPTest):
942 typecode = 'd'
943 minitemsize = 8
944tests.append(DoubleTest)
945
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +0000946def test_main(verbose=None):
947 import sys
948
Walter Dörwald7fd94242003-05-18 00:47:47 +0000949 test_support.run_unittest(*tests)
950
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +0000951 # verify reference counting
952 if verbose and hasattr(sys, "gettotalrefcount"):
953 import gc
954 counts = [None] * 5
955 for i in xrange(len(counts)):
956 test_support.run_unittest(*tests)
957 gc.collect()
958 counts[i] = sys.gettotalrefcount()
959 print counts
960
961if __name__ == "__main__":
962 test_main(verbose=True)