blob: 5c79b4826131a4a4ee6e8e1a730ff9a6800e3529 [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
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)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000064 self.assert_(isinstance(bi[0], (int, long)))
Walter Dörwald7fd94242003-05-18 00:47:47 +000065 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
Thomas Wouters89f507f2006-12-13 04:49:30 +000088 def test_deepcopy(self):
89 import copy
90 a = array.array(self.typecode, self.example)
91 b = copy.deepcopy(a)
92 self.assertNotEqual(id(a), id(b))
93 self.assertEqual(a, b)
94
Raymond Hettingerb0900e62004-12-16 16:23:40 +000095 def test_pickle(self):
96 for protocol in (0, 1, 2):
97 a = array.array(self.typecode, self.example)
98 b = loads(dumps(a, protocol))
99 self.assertNotEqual(id(a), id(b))
100 self.assertEqual(a, b)
101
102 a = ArraySubclass(self.typecode, self.example)
103 a.x = 10
104 b = loads(dumps(a, protocol))
105 self.assertNotEqual(id(a), id(b))
106 self.assertEqual(a, b)
107 self.assertEqual(a.x, b.x)
108 self.assertEqual(type(a), type(b))
109
Walter Dörwald7fd94242003-05-18 00:47:47 +0000110 def test_insert(self):
111 a = array.array(self.typecode, self.example)
112 a.insert(0, self.example[0])
113 self.assertEqual(len(a), 1+len(self.example))
114 self.assertEqual(a[0], a[1])
115 self.assertRaises(TypeError, a.insert)
116 self.assertRaises(TypeError, a.insert, None)
Walter Dörwaldba39d9c2003-05-18 01:56:25 +0000117 self.assertRaises(TypeError, a.insert, 0, None)
Martin v. Löwis99866332002-03-01 10:27:01 +0000118
Walter Dörwald9e46abe2003-05-18 03:15:10 +0000119 a = array.array(self.typecode, self.example)
120 a.insert(-1, self.example[0])
121 self.assertEqual(
122 a,
123 array.array(
124 self.typecode,
125 self.example[:-1] + self.example[:1] + self.example[-1:]
126 )
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[:1] + self.example)
134 )
135
136 a = array.array(self.typecode, self.example)
137 a.insert(1000, self.example[0])
138 self.assertEqual(
139 a,
140 array.array(self.typecode, self.example + self.example[:1])
141 )
142
Walter Dörwald7fd94242003-05-18 00:47:47 +0000143 def test_tofromfile(self):
144 a = array.array(self.typecode, 2*self.example)
145 self.assertRaises(TypeError, a.tofile)
146 self.assertRaises(TypeError, a.tofile, cStringIO.StringIO())
147 f = open(test_support.TESTFN, 'wb')
148 try:
149 a.tofile(f)
150 f.close()
151 b = array.array(self.typecode)
152 f = open(test_support.TESTFN, 'rb')
153 self.assertRaises(TypeError, b.fromfile)
154 self.assertRaises(
155 TypeError,
156 b.fromfile,
157 cStringIO.StringIO(), len(self.example)
158 )
159 b.fromfile(f, len(self.example))
160 self.assertEqual(b, array.array(self.typecode, self.example))
161 self.assertNotEqual(a, b)
162 b.fromfile(f, len(self.example))
163 self.assertEqual(a, b)
164 self.assertRaises(EOFError, b.fromfile, f, 1)
165 f.close()
166 finally:
167 if not f.closed:
168 f.close()
169 test_support.unlink(test_support.TESTFN)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000170
Walter Dörwald7fd94242003-05-18 00:47:47 +0000171 def test_tofromlist(self):
172 a = array.array(self.typecode, 2*self.example)
173 b = array.array(self.typecode)
174 self.assertRaises(TypeError, a.tolist, 42)
175 self.assertRaises(TypeError, b.fromlist)
176 self.assertRaises(TypeError, b.fromlist, 42)
177 self.assertRaises(TypeError, b.fromlist, [None])
178 b.fromlist(a.tolist())
179 self.assertEqual(a, b)
Fred Drake78334472000-06-28 17:50:51 +0000180
Walter Dörwald7fd94242003-05-18 00:47:47 +0000181 def test_tofromstring(self):
182 a = array.array(self.typecode, 2*self.example)
183 b = array.array(self.typecode)
184 self.assertRaises(TypeError, a.tostring, 42)
185 self.assertRaises(TypeError, b.fromstring)
186 self.assertRaises(TypeError, b.fromstring, 42)
187 b.fromstring(a.tostring())
188 self.assertEqual(a, b)
189 if a.itemsize>1:
190 self.assertRaises(ValueError, b.fromstring, "x")
Fred Drake78334472000-06-28 17:50:51 +0000191
Walter Dörwald7fd94242003-05-18 00:47:47 +0000192 def test_repr(self):
193 a = array.array(self.typecode, 2*self.example)
194 self.assertEqual(a, eval(repr(a), {"array": array.array}))
Fred Drake78334472000-06-28 17:50:51 +0000195
Walter Dörwald7fd94242003-05-18 00:47:47 +0000196 a = array.array(self.typecode)
197 self.assertEqual(repr(a), "array('%s')" % self.typecode)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000198
Walter Dörwald7fd94242003-05-18 00:47:47 +0000199 def test_str(self):
200 a = array.array(self.typecode, 2*self.example)
201 str(a)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000202
Walter Dörwald7fd94242003-05-18 00:47:47 +0000203 def test_cmp(self):
204 a = array.array(self.typecode, self.example)
205 self.assert_((a == 42) is False)
206 self.assert_((a != 42) is True)
Tim Peterscc78e472000-11-14 21:36:07 +0000207
Walter Dörwald7fd94242003-05-18 00:47:47 +0000208 self.assert_((a == a) is True)
209 self.assert_((a != a) is False)
210 self.assert_((a < a) is False)
211 self.assert_((a <= a) is True)
212 self.assert_((a > a) is False)
213 self.assert_((a >= a) is True)
Tim Peterscc78e472000-11-14 21:36:07 +0000214
Neal Norwitzbd2835c2006-03-17 08:54:15 +0000215 al = array.array(self.typecode, self.smallerexample)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000216 ab = array.array(self.typecode, self.biggerexample)
Guido van Rossum7f1d3aa1998-07-16 15:31:43 +0000217
Walter Dörwald7fd94242003-05-18 00:47:47 +0000218 self.assert_((a == 2*a) is False)
219 self.assert_((a != 2*a) is True)
220 self.assert_((a < 2*a) is True)
221 self.assert_((a <= 2*a) is True)
222 self.assert_((a > 2*a) is False)
223 self.assert_((a >= 2*a) is False)
Martin v. Löwis99866332002-03-01 10:27:01 +0000224
Neal Norwitzbd2835c2006-03-17 08:54:15 +0000225 self.assert_((a == al) is False)
226 self.assert_((a != al) is True)
227 self.assert_((a < al) is False)
228 self.assert_((a <= al) is False)
229 self.assert_((a > al) is True)
230 self.assert_((a >= al) is True)
Martin v. Löwis99866332002-03-01 10:27:01 +0000231
Walter Dörwald7fd94242003-05-18 00:47:47 +0000232 self.assert_((a == ab) is False)
233 self.assert_((a != ab) is True)
234 self.assert_((a < ab) is True)
235 self.assert_((a <= ab) is True)
236 self.assert_((a > ab) is False)
237 self.assert_((a >= ab) is False)
Martin v. Löwis99866332002-03-01 10:27:01 +0000238
Walter Dörwald7fd94242003-05-18 00:47:47 +0000239 def test_add(self):
240 a = array.array(self.typecode, self.example) \
241 + array.array(self.typecode, self.example[::-1])
242 self.assertEqual(
243 a,
244 array.array(self.typecode, self.example + self.example[::-1])
245 )
Martin v. Löwis99866332002-03-01 10:27:01 +0000246
Walter Dörwald7fd94242003-05-18 00:47:47 +0000247 b = array.array(self.badtypecode())
248 self.assertRaises(TypeError, a.__add__, b)
249
250 self.assertRaises(TypeError, a.__add__, "bad")
251
252 def test_iadd(self):
253 a = array.array(self.typecode, self.example[::-1])
254 b = a
255 a += array.array(self.typecode, 2*self.example)
256 self.assert_(a is b)
257 self.assertEqual(
258 a,
259 array.array(self.typecode, self.example[::-1]+2*self.example)
260 )
261
262 b = array.array(self.badtypecode())
263 self.assertRaises(TypeError, a.__add__, b)
264
265 self.assertRaises(TypeError, a.__iadd__, "bad")
266
267 def test_mul(self):
268 a = 5*array.array(self.typecode, self.example)
269 self.assertEqual(
270 a,
271 array.array(self.typecode, 5*self.example)
272 )
273
274 a = array.array(self.typecode, self.example)*5
275 self.assertEqual(
276 a,
277 array.array(self.typecode, self.example*5)
278 )
279
280 a = 0*array.array(self.typecode, self.example)
281 self.assertEqual(
282 a,
283 array.array(self.typecode)
284 )
285
286 a = (-1)*array.array(self.typecode, self.example)
287 self.assertEqual(
288 a,
289 array.array(self.typecode)
290 )
291
292 self.assertRaises(TypeError, a.__mul__, "bad")
293
294 def test_imul(self):
295 a = array.array(self.typecode, self.example)
296 b = a
297
298 a *= 5
299 self.assert_(a is b)
300 self.assertEqual(
301 a,
302 array.array(self.typecode, 5*self.example)
303 )
304
305 a *= 0
306 self.assert_(a is b)
307 self.assertEqual(a, array.array(self.typecode))
308
309 a *= 1000
310 self.assert_(a is b)
311 self.assertEqual(a, array.array(self.typecode))
312
313 a *= -1
314 self.assert_(a is b)
315 self.assertEqual(a, array.array(self.typecode))
316
317 a = array.array(self.typecode, self.example)
318 a *= -1
319 self.assertEqual(a, array.array(self.typecode))
320
321 self.assertRaises(TypeError, a.__imul__, "bad")
322
323 def test_getitem(self):
324 a = array.array(self.typecode, self.example)
325 self.assertEntryEqual(a[0], self.example[0])
326 self.assertEntryEqual(a[0L], self.example[0])
327 self.assertEntryEqual(a[-1], self.example[-1])
328 self.assertEntryEqual(a[-1L], self.example[-1])
329 self.assertEntryEqual(a[len(self.example)-1], self.example[-1])
330 self.assertEntryEqual(a[-len(self.example)], self.example[0])
331 self.assertRaises(TypeError, a.__getitem__)
332 self.assertRaises(IndexError, a.__getitem__, len(self.example))
333 self.assertRaises(IndexError, a.__getitem__, -len(self.example)-1)
334
335 def test_setitem(self):
336 a = array.array(self.typecode, self.example)
337 a[0] = a[-1]
338 self.assertEntryEqual(a[0], a[-1])
339
340 a = array.array(self.typecode, self.example)
341 a[0L] = a[-1]
342 self.assertEntryEqual(a[0], a[-1])
343
344 a = array.array(self.typecode, self.example)
345 a[-1] = a[0]
346 self.assertEntryEqual(a[0], a[-1])
347
348 a = array.array(self.typecode, self.example)
349 a[-1L] = a[0]
350 self.assertEntryEqual(a[0], a[-1])
351
352 a = array.array(self.typecode, self.example)
353 a[len(self.example)-1] = a[0]
354 self.assertEntryEqual(a[0], a[-1])
355
356 a = array.array(self.typecode, self.example)
357 a[-len(self.example)] = a[-1]
358 self.assertEntryEqual(a[0], a[-1])
359
360 self.assertRaises(TypeError, a.__setitem__)
361 self.assertRaises(TypeError, a.__setitem__, None)
362 self.assertRaises(TypeError, a.__setitem__, 0, None)
363 self.assertRaises(
364 IndexError,
365 a.__setitem__,
366 len(self.example), self.example[0]
367 )
368 self.assertRaises(
369 IndexError,
370 a.__setitem__,
371 -len(self.example)-1, self.example[0]
372 )
373
374 def test_delitem(self):
375 a = array.array(self.typecode, self.example)
376 del a[0]
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[-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)-1]
391 self.assertEqual(
392 a,
393 array.array(self.typecode, self.example[:-1])
394 )
395
396 a = array.array(self.typecode, self.example)
397 del a[-len(self.example)]
398 self.assertEqual(
399 a,
400 array.array(self.typecode, self.example[1:])
401 )
402
403 self.assertRaises(TypeError, a.__delitem__)
404 self.assertRaises(TypeError, a.__delitem__, None)
405 self.assertRaises(IndexError, a.__delitem__, len(self.example))
406 self.assertRaises(IndexError, a.__delitem__, -len(self.example)-1)
407
408 def test_getslice(self):
409 a = array.array(self.typecode, self.example)
410 self.assertEqual(a[:], a)
411
412 self.assertEqual(
413 a[1:],
414 array.array(self.typecode, self.example[1:])
415 )
416
417 self.assertEqual(
418 a[:1],
419 array.array(self.typecode, self.example[:1])
420 )
421
422 self.assertEqual(
423 a[:-1],
424 array.array(self.typecode, self.example[:-1])
425 )
426
427 self.assertEqual(
428 a[-1:],
429 array.array(self.typecode, self.example[-1:])
430 )
431
432 self.assertEqual(
433 a[-1:-1],
434 array.array(self.typecode)
435 )
436
437 self.assertEqual(
Walter Dörwald1083c242005-01-21 21:16:51 +0000438 a[2:1],
439 array.array(self.typecode)
440 )
441
442 self.assertEqual(
Walter Dörwald7fd94242003-05-18 00:47:47 +0000443 a[1000:],
444 array.array(self.typecode)
445 )
446 self.assertEqual(a[-1000:], a)
447 self.assertEqual(a[:1000], a)
448 self.assertEqual(
449 a[:-1000],
450 array.array(self.typecode)
451 )
452 self.assertEqual(a[-1000:1000], a)
453 self.assertEqual(
454 a[2000:1000],
455 array.array(self.typecode)
456 )
457
458 def test_setslice(self):
459 a = array.array(self.typecode, self.example)
460 a[:1] = a
461 self.assertEqual(
462 a,
463 array.array(self.typecode, self.example + self.example[1:])
464 )
465
466 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000467 a[:-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000468 self.assertEqual(
469 a,
470 array.array(self.typecode, self.example + self.example[-1:])
471 )
472
473 a = array.array(self.typecode, self.example)
474 a[-1:] = a
475 self.assertEqual(
476 a,
477 array.array(self.typecode, self.example[:-1] + self.example)
478 )
479
480 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000481 a[1:] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000482 self.assertEqual(
483 a,
484 array.array(self.typecode, self.example[:1] + self.example)
485 )
486
487 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000488 a[1:-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000489 self.assertEqual(
490 a,
491 array.array(
492 self.typecode,
493 self.example[:1] + self.example + self.example[-1:]
494 )
495 )
496
497 a = array.array(self.typecode, self.example)
498 a[1000:] = a
499 self.assertEqual(
500 a,
501 array.array(self.typecode, 2*self.example)
502 )
503
504 a = array.array(self.typecode, self.example)
505 a[-1000:] = a
506 self.assertEqual(
507 a,
508 array.array(self.typecode, self.example)
509 )
510
511 a = array.array(self.typecode, self.example)
512 a[:1000] = a
513 self.assertEqual(
514 a,
515 array.array(self.typecode, self.example)
516 )
517
518 a = array.array(self.typecode, self.example)
519 a[:-1000] = a
520 self.assertEqual(
521 a,
522 array.array(self.typecode, 2*self.example)
523 )
524
525 a = array.array(self.typecode, self.example)
526 a[1:0] = a
527 self.assertEqual(
528 a,
529 array.array(self.typecode, self.example[:1] + self.example + self.example[1:])
530 )
531
532 a = array.array(self.typecode, self.example)
533 a[2000:1000] = a
534 self.assertEqual(
535 a,
536 array.array(self.typecode, 2*self.example)
537 )
538
539 a = array.array(self.typecode, self.example)
540 self.assertRaises(TypeError, a.__setslice__, 0, 0, None)
541 self.assertRaises(TypeError, a.__setitem__, slice(0, 1), None)
542
543 b = array.array(self.badtypecode())
544 self.assertRaises(TypeError, a.__setslice__, 0, 0, b)
545 self.assertRaises(TypeError, a.__setitem__, slice(0, 1), b)
546
547 def test_index(self):
548 example = 2*self.example
549 a = array.array(self.typecode, example)
550 self.assertRaises(TypeError, a.index)
551 for x in example:
552 self.assertEqual(a.index(x), example.index(x))
553 self.assertRaises(ValueError, a.index, None)
554 self.assertRaises(ValueError, a.index, self.outside)
555
556 def test_count(self):
557 example = 2*self.example
558 a = array.array(self.typecode, example)
559 self.assertRaises(TypeError, a.count)
560 for x in example:
561 self.assertEqual(a.count(x), example.count(x))
562 self.assertEqual(a.count(self.outside), 0)
563 self.assertEqual(a.count(None), 0)
564
565 def test_remove(self):
566 for x in self.example:
567 example = 2*self.example
568 a = array.array(self.typecode, example)
569 pos = example.index(x)
570 example2 = example[:pos] + example[pos+1:]
571 a.remove(x)
572 self.assertEqual(a, array.array(self.typecode, example2))
573
574 a = array.array(self.typecode, self.example)
575 self.assertRaises(ValueError, a.remove, self.outside)
576
577 self.assertRaises(ValueError, a.remove, None)
578
579 def test_pop(self):
580 a = array.array(self.typecode)
581 self.assertRaises(IndexError, a.pop)
582
583 a = array.array(self.typecode, 2*self.example)
584 self.assertRaises(TypeError, a.pop, 42, 42)
585 self.assertRaises(TypeError, a.pop, None)
586 self.assertRaises(IndexError, a.pop, len(a))
587 self.assertRaises(IndexError, a.pop, -len(a)-1)
588
589 self.assertEntryEqual(a.pop(0), self.example[0])
590 self.assertEqual(
591 a,
592 array.array(self.typecode, self.example[1:]+self.example)
593 )
594 self.assertEntryEqual(a.pop(1), self.example[2])
595 self.assertEqual(
596 a,
597 array.array(self.typecode, self.example[1:2]+self.example[3:]+self.example)
598 )
599 self.assertEntryEqual(a.pop(0), self.example[1])
600 self.assertEntryEqual(a.pop(), self.example[-1])
601 self.assertEqual(
602 a,
603 array.array(self.typecode, self.example[3:]+self.example[:-1])
604 )
605
606 def test_reverse(self):
607 a = array.array(self.typecode, self.example)
608 self.assertRaises(TypeError, a.reverse, 42)
Fred Drake004d5e62000-10-23 17:22:08 +0000609 a.reverse()
Walter Dörwald7fd94242003-05-18 00:47:47 +0000610 self.assertEqual(
611 a,
612 array.array(self.typecode, self.example[::-1])
613 )
614
615 def test_extend(self):
616 a = array.array(self.typecode, self.example)
617 self.assertRaises(TypeError, a.extend)
618 a.extend(array.array(self.typecode, self.example[::-1]))
619 self.assertEqual(
620 a,
621 array.array(self.typecode, self.example+self.example[::-1])
622 )
623
624 b = array.array(self.badtypecode())
625 self.assertRaises(TypeError, a.extend, b)
626
Raymond Hettinger49f9bd12004-03-14 05:43:59 +0000627 a = array.array(self.typecode, self.example)
628 a.extend(self.example[::-1])
629 self.assertEqual(
630 a,
631 array.array(self.typecode, self.example+self.example[::-1])
632 )
633
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +0000634 def test_constructor_with_iterable_argument(self):
635 a = array.array(self.typecode, iter(self.example))
636 b = array.array(self.typecode, self.example)
637 self.assertEqual(a, b)
638
639 # non-iterable argument
640 self.assertRaises(TypeError, array.array, self.typecode, 10)
641
642 # pass through errors raised in __iter__
643 class A:
644 def __iter__(self):
645 raise UnicodeError
646 self.assertRaises(UnicodeError, array.array, self.typecode, A())
647
648 # pass through errors raised in next()
649 def B():
650 raise UnicodeError
651 yield None
652 self.assertRaises(UnicodeError, array.array, self.typecode, B())
653
Walter Dörwald7fd94242003-05-18 00:47:47 +0000654 def test_coveritertraverse(self):
655 try:
656 import gc
657 except ImportError:
658 return
659 a = array.array(self.typecode)
660 l = [iter(a)]
661 l.append(l)
662 gc.collect()
663
664 def test_buffer(self):
665 a = array.array(self.typecode, self.example)
666 b = buffer(a)
667 self.assertEqual(b[0], a.tostring()[0])
668
Raymond Hettingercb87bc82004-05-31 00:35:52 +0000669 def test_weakref(self):
670 s = array.array(self.typecode, self.example)
671 p = proxy(s)
672 self.assertEqual(p.tostring(), s.tostring())
673 s = None
674 self.assertRaises(ReferenceError, len, p)
675
Skip Montanarod5cf0b82003-08-03 23:02:10 +0000676 def test_bug_782369(self):
677 import sys
Skip Montanaroed9bf122003-08-03 23:30:40 +0000678 if hasattr(sys, "getrefcount"):
679 for i in range(10):
680 b = array.array('B', range(64))
681 rc = sys.getrefcount(10)
682 for i in range(10):
683 b = array.array('B', range(64))
684 self.assertEqual(rc, sys.getrefcount(10))
Skip Montanarod5cf0b82003-08-03 23:02:10 +0000685
Raymond Hettingercb87bc82004-05-31 00:35:52 +0000686
687
Walter Dörwald7fd94242003-05-18 00:47:47 +0000688class StringTest(BaseTest):
689
690 def test_setitem(self):
691 super(StringTest, self).test_setitem()
692 a = array.array(self.typecode, self.example)
693 self.assertRaises(TypeError, a.__setitem__, 0, self.example[:2])
694
695class CharacterTest(StringTest):
696 typecode = 'c'
697 example = '\x01azAZ\x00\xfe'
698 smallerexample = '\x01azAY\x00\xfe'
699 biggerexample = '\x01azAZ\x00\xff'
700 outside = '\x33'
701 minitemsize = 1
702
703 def test_subbclassing(self):
704 class EditableString(array.array):
705 def __new__(cls, s, *args, **kwargs):
706 return array.array.__new__(cls, 'c', s)
707
708 def __init__(self, s, color='blue'):
709 array.array.__init__(self, 'c', s)
710 self.color = color
711
712 def strip(self):
713 self[:] = array.array('c', self.tostring().strip())
714
715 def __repr__(self):
716 return 'EditableString(%r)' % self.tostring()
717
718 s = EditableString("\ttest\r\n")
719 s.strip()
720 self.assertEqual(s.tostring(), "test")
721
722 self.assertEqual(s.color, "blue")
723 s.color = "red"
724 self.assertEqual(s.color, "red")
725 self.assertEqual(s.__dict__.keys(), ["color"])
726
727 def test_nounicode(self):
728 a = array.array(self.typecode, self.example)
729 self.assertRaises(ValueError, a.fromunicode, unicode(''))
730 self.assertRaises(ValueError, a.tounicode)
731
732tests.append(CharacterTest)
733
734if test_support.have_unicode:
735 class UnicodeTest(StringTest):
736 typecode = 'u'
737 example = unicode(r'\x01\u263a\x00\ufeff', 'unicode-escape')
738 smallerexample = unicode(r'\x01\u263a\x00\ufefe', 'unicode-escape')
739 biggerexample = unicode(r'\x01\u263a\x01\ufeff', 'unicode-escape')
740 outside = unicode('\x33')
741 minitemsize = 2
742
743 def test_unicode(self):
744 self.assertRaises(TypeError, array.array, 'b', unicode('foo', 'ascii'))
745
746 a = array.array('u', unicode(r'\xa0\xc2\u1234', 'unicode-escape'))
747 a.fromunicode(unicode(' ', 'ascii'))
748 a.fromunicode(unicode('', 'ascii'))
749 a.fromunicode(unicode('', 'ascii'))
750 a.fromunicode(unicode(r'\x11abc\xff\u1234', 'unicode-escape'))
751 s = a.tounicode()
752 self.assertEqual(
753 s,
754 unicode(r'\xa0\xc2\u1234 \x11abc\xff\u1234', 'unicode-escape')
755 )
756
757 s = unicode(r'\x00="\'a\\b\x80\xff\u0000\u0001\u1234', 'unicode-escape')
758 a = array.array('u', s)
759 self.assertEqual(
760 repr(a),
761 r"""array('u', u'\x00="\'a\\b\x80\xff\x00\x01\u1234')"""
762 )
763
764 self.assertRaises(TypeError, a.fromunicode)
765
766 tests.append(UnicodeTest)
767
768class NumberTest(BaseTest):
769
770 def test_extslice(self):
771 a = array.array(self.typecode, range(5))
772 self.assertEqual(a[::], a)
773 self.assertEqual(a[::2], array.array(self.typecode, [0,2,4]))
774 self.assertEqual(a[1::2], array.array(self.typecode, [1,3]))
775 self.assertEqual(a[::-1], array.array(self.typecode, [4,3,2,1,0]))
776 self.assertEqual(a[::-2], array.array(self.typecode, [4,2,0]))
777 self.assertEqual(a[3::-2], array.array(self.typecode, [3,1]))
778 self.assertEqual(a[-100:100:], a)
779 self.assertEqual(a[100:-100:-1], a[::-1])
780 self.assertEqual(a[-100L:100L:2L], array.array(self.typecode, [0,2,4]))
781 self.assertEqual(a[1000:2000:2], array.array(self.typecode, []))
782 self.assertEqual(a[-1000:-2000:-2], array.array(self.typecode, []))
783
784 def test_delslice(self):
785 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000786 del a[::2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000787 self.assertEqual(a, array.array(self.typecode, [1,3]))
788 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000789 del a[1::2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000790 self.assertEqual(a, array.array(self.typecode, [0,2,4]))
791 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000792 del a[1::-2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000793 self.assertEqual(a, array.array(self.typecode, [0,2,3,4]))
794 a = array.array(self.typecode, range(10))
Michael W. Hudson56796f62002-07-29 14:35:04 +0000795 del a[::1000]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000796 self.assertEqual(a, array.array(self.typecode, [1,2,3,4,5,6,7,8,9]))
797
798 def test_assignment(self):
799 a = array.array(self.typecode, range(10))
800 a[::2] = array.array(self.typecode, [42]*5)
801 self.assertEqual(a, array.array(self.typecode, [42, 1, 42, 3, 42, 5, 42, 7, 42, 9]))
802 a = array.array(self.typecode, range(10))
803 a[::-4] = array.array(self.typecode, [10]*3)
804 self.assertEqual(a, array.array(self.typecode, [0, 10, 2, 3, 4, 10, 6, 7, 8 ,10]))
805 a = array.array(self.typecode, range(4))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000806 a[::-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000807 self.assertEqual(a, array.array(self.typecode, [3, 2, 1, 0]))
808 a = array.array(self.typecode, range(10))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000809 b = a[:]
810 c = a[:]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000811 ins = array.array(self.typecode, range(2))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000812 a[2:3] = ins
813 b[slice(2,3)] = ins
814 c[2:3:] = ins
Fred Drake004d5e62000-10-23 17:22:08 +0000815
Walter Dörwald7fd94242003-05-18 00:47:47 +0000816 def test_iterationcontains(self):
817 a = array.array(self.typecode, range(10))
818 self.assertEqual(list(a), range(10))
819 b = array.array(self.typecode, [20])
820 self.assertEqual(a[-1] in a, True)
821 self.assertEqual(b[0] not in a, True)
822
823 def check_overflow(self, lower, upper):
824 # method to be used by subclasses
825
826 # should not overflow assigning lower limit
827 a = array.array(self.typecode, [lower])
828 a[0] = lower
829 # should overflow assigning less than lower limit
830 self.assertRaises(OverflowError, array.array, self.typecode, [lower-1])
831 self.assertRaises(OverflowError, a.__setitem__, 0, lower-1)
832 # should not overflow assigning upper limit
833 a = array.array(self.typecode, [upper])
834 a[0] = upper
835 # should overflow assigning more than upper limit
836 self.assertRaises(OverflowError, array.array, self.typecode, [upper+1])
837 self.assertRaises(OverflowError, a.__setitem__, 0, upper+1)
838
839 def test_subclassing(self):
840 typecode = self.typecode
841 class ExaggeratingArray(array.array):
842 __slots__ = ['offset']
843
844 def __new__(cls, typecode, data, offset):
845 return array.array.__new__(cls, typecode, data)
846
847 def __init__(self, typecode, data, offset):
848 self.offset = offset
849
850 def __getitem__(self, i):
851 return array.array.__getitem__(self, i) + self.offset
852
853 a = ExaggeratingArray(self.typecode, [3, 6, 7, 11], 4)
854 self.assertEntryEqual(a[0], 7)
855
856 self.assertRaises(AttributeError, setattr, a, "color", "blue")
857
858class SignedNumberTest(NumberTest):
859 example = [-1, 0, 1, 42, 0x7f]
860 smallerexample = [-1, 0, 1, 42, 0x7e]
861 biggerexample = [-1, 0, 1, 43, 0x7f]
862 outside = 23
863
864 def test_overflow(self):
865 a = array.array(self.typecode)
866 lower = -1 * long(pow(2, a.itemsize * 8 - 1))
867 upper = long(pow(2, a.itemsize * 8 - 1)) - 1L
868 self.check_overflow(lower, upper)
869
870class UnsignedNumberTest(NumberTest):
871 example = [0, 1, 17, 23, 42, 0xff]
872 smallerexample = [0, 1, 17, 23, 42, 0xfe]
873 biggerexample = [0, 1, 17, 23, 43, 0xff]
874 outside = 0xaa
875
876 def test_overflow(self):
877 a = array.array(self.typecode)
878 lower = 0
879 upper = long(pow(2, a.itemsize * 8)) - 1L
880 self.check_overflow(lower, upper)
Fred Drake004d5e62000-10-23 17:22:08 +0000881
882
Walter Dörwald7fd94242003-05-18 00:47:47 +0000883class ByteTest(SignedNumberTest):
884 typecode = 'b'
885 minitemsize = 1
886tests.append(ByteTest)
Fred Drake004d5e62000-10-23 17:22:08 +0000887
Walter Dörwald7fd94242003-05-18 00:47:47 +0000888class UnsignedByteTest(UnsignedNumberTest):
889 typecode = 'B'
890 minitemsize = 1
891tests.append(UnsignedByteTest)
892
893class ShortTest(SignedNumberTest):
894 typecode = 'h'
895 minitemsize = 2
896tests.append(ShortTest)
897
898class UnsignedShortTest(UnsignedNumberTest):
899 typecode = 'H'
900 minitemsize = 2
901tests.append(UnsignedShortTest)
902
903class IntTest(SignedNumberTest):
904 typecode = 'i'
905 minitemsize = 2
906tests.append(IntTest)
907
908class UnsignedIntTest(UnsignedNumberTest):
909 typecode = 'I'
910 minitemsize = 2
911tests.append(UnsignedIntTest)
912
913class LongTest(SignedNumberTest):
914 typecode = 'l'
915 minitemsize = 4
916tests.append(LongTest)
917
918class UnsignedLongTest(UnsignedNumberTest):
919 typecode = 'L'
920 minitemsize = 4
921tests.append(UnsignedLongTest)
922
923class FPTest(NumberTest):
924 example = [-42.0, 0, 42, 1e5, -1e10]
925 smallerexample = [-42.0, 0, 42, 1e5, -2e10]
926 biggerexample = [-42.0, 0, 42, 1e5, 1e10]
927 outside = 23
928
929 def assertEntryEqual(self, entry1, entry2):
930 self.assertAlmostEqual(entry1, entry2)
931
Walter Dörwaldcf99b0a2003-05-22 13:15:31 +0000932 def test_byteswap(self):
933 a = array.array(self.typecode, self.example)
934 self.assertRaises(TypeError, a.byteswap, 42)
935 if a.itemsize in (1, 2, 4, 8):
936 b = array.array(self.typecode, self.example)
937 b.byteswap()
938 if a.itemsize==1:
939 self.assertEqual(a, b)
940 else:
941 # On alphas treating the byte swapped bit patters as
942 # floats/doubles results in floating point exceptions
943 # => compare the 8bit string values instead
944 self.assertNotEqual(a.tostring(), b.tostring())
945 b.byteswap()
946 self.assertEqual(a, b)
947
Neal Norwitz35c6cd02003-05-22 13:29:15 +0000948class FloatTest(FPTest):
949 typecode = 'f'
950 minitemsize = 4
Walter Dörwald7fd94242003-05-18 00:47:47 +0000951tests.append(FloatTest)
952
953class DoubleTest(FPTest):
954 typecode = 'd'
955 minitemsize = 8
956tests.append(DoubleTest)
957
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +0000958def test_main(verbose=None):
959 import sys
960
Walter Dörwald7fd94242003-05-18 00:47:47 +0000961 test_support.run_unittest(*tests)
962
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +0000963 # verify reference counting
964 if verbose and hasattr(sys, "gettotalrefcount"):
965 import gc
966 counts = [None] * 5
967 for i in xrange(len(counts)):
968 test_support.run_unittest(*tests)
969 gc.collect()
970 counts[i] = sys.gettotalrefcount()
971 print counts
972
973if __name__ == "__main__":
974 test_main(verbose=True)