blob: 0d4c219c783b682a76cfa494d8ed542cf9b9fe8b [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
Guido van Rossum2c94aa52007-05-24 19:02:32 +00009import array, io, 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)
Walter Dörwaldaa97f042007-05-03 21:05:51 +000068 self.assert_(isinstance(bi[0], 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
Guido van Rossumd8faa362007-04-27 19:54:29 +0000114 def test_pickle_for_empty_array(self):
115 for protocol in (0, 1, 2):
116 a = array.array(self.typecode)
117 b = loads(dumps(a, protocol))
118 self.assertNotEqual(id(a), id(b))
119 self.assertEqual(a, b)
120
121 a = ArraySubclass(self.typecode)
122 a.x = 10
123 b = loads(dumps(a, protocol))
124 self.assertNotEqual(id(a), id(b))
125 self.assertEqual(a, b)
126 self.assertEqual(a.x, b.x)
127 self.assertEqual(type(a), type(b))
128
Walter Dörwald7fd94242003-05-18 00:47:47 +0000129 def test_insert(self):
130 a = array.array(self.typecode, self.example)
131 a.insert(0, self.example[0])
132 self.assertEqual(len(a), 1+len(self.example))
133 self.assertEqual(a[0], a[1])
134 self.assertRaises(TypeError, a.insert)
135 self.assertRaises(TypeError, a.insert, None)
Walter Dörwaldba39d9c2003-05-18 01:56:25 +0000136 self.assertRaises(TypeError, a.insert, 0, None)
Martin v. Löwis99866332002-03-01 10:27:01 +0000137
Walter Dörwald9e46abe2003-05-18 03:15:10 +0000138 a = array.array(self.typecode, self.example)
139 a.insert(-1, self.example[0])
140 self.assertEqual(
141 a,
142 array.array(
143 self.typecode,
144 self.example[:-1] + self.example[:1] + self.example[-1:]
145 )
146 )
147
148 a = array.array(self.typecode, self.example)
149 a.insert(-1000, self.example[0])
150 self.assertEqual(
151 a,
152 array.array(self.typecode, self.example[:1] + self.example)
153 )
154
155 a = array.array(self.typecode, self.example)
156 a.insert(1000, self.example[0])
157 self.assertEqual(
158 a,
159 array.array(self.typecode, self.example + self.example[:1])
160 )
161
Walter Dörwald7fd94242003-05-18 00:47:47 +0000162 def test_tofromfile(self):
163 a = array.array(self.typecode, 2*self.example)
164 self.assertRaises(TypeError, a.tofile)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000165 f = open(test_support.TESTFN, 'wb')
166 try:
167 a.tofile(f)
168 f.close()
169 b = array.array(self.typecode)
170 f = open(test_support.TESTFN, 'rb')
171 self.assertRaises(TypeError, b.fromfile)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000172 b.fromfile(f, len(self.example))
173 self.assertEqual(b, array.array(self.typecode, self.example))
174 self.assertNotEqual(a, b)
175 b.fromfile(f, len(self.example))
176 self.assertEqual(a, b)
177 self.assertRaises(EOFError, b.fromfile, f, 1)
178 f.close()
179 finally:
180 if not f.closed:
181 f.close()
182 test_support.unlink(test_support.TESTFN)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000183
Walter Dörwald7fd94242003-05-18 00:47:47 +0000184 def test_tofromlist(self):
185 a = array.array(self.typecode, 2*self.example)
186 b = array.array(self.typecode)
187 self.assertRaises(TypeError, a.tolist, 42)
188 self.assertRaises(TypeError, b.fromlist)
189 self.assertRaises(TypeError, b.fromlist, 42)
190 self.assertRaises(TypeError, b.fromlist, [None])
191 b.fromlist(a.tolist())
192 self.assertEqual(a, b)
Fred Drake78334472000-06-28 17:50:51 +0000193
Walter Dörwald7fd94242003-05-18 00:47:47 +0000194 def test_tofromstring(self):
195 a = array.array(self.typecode, 2*self.example)
196 b = array.array(self.typecode)
197 self.assertRaises(TypeError, a.tostring, 42)
198 self.assertRaises(TypeError, b.fromstring)
199 self.assertRaises(TypeError, b.fromstring, 42)
200 b.fromstring(a.tostring())
201 self.assertEqual(a, b)
202 if a.itemsize>1:
203 self.assertRaises(ValueError, b.fromstring, "x")
Fred Drake78334472000-06-28 17:50:51 +0000204
Walter Dörwald7fd94242003-05-18 00:47:47 +0000205 def test_repr(self):
206 a = array.array(self.typecode, 2*self.example)
207 self.assertEqual(a, eval(repr(a), {"array": array.array}))
Fred Drake78334472000-06-28 17:50:51 +0000208
Walter Dörwald7fd94242003-05-18 00:47:47 +0000209 a = array.array(self.typecode)
210 self.assertEqual(repr(a), "array('%s')" % self.typecode)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000211
Walter Dörwald7fd94242003-05-18 00:47:47 +0000212 def test_str(self):
213 a = array.array(self.typecode, 2*self.example)
214 str(a)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000215
Walter Dörwald7fd94242003-05-18 00:47:47 +0000216 def test_cmp(self):
217 a = array.array(self.typecode, self.example)
218 self.assert_((a == 42) is False)
219 self.assert_((a != 42) is True)
Tim Peterscc78e472000-11-14 21:36:07 +0000220
Walter Dörwald7fd94242003-05-18 00:47:47 +0000221 self.assert_((a == a) is True)
222 self.assert_((a != a) is False)
223 self.assert_((a < a) is False)
224 self.assert_((a <= a) is True)
225 self.assert_((a > a) is False)
226 self.assert_((a >= a) is True)
Tim Peterscc78e472000-11-14 21:36:07 +0000227
Neal Norwitzbd2835c2006-03-17 08:54:15 +0000228 al = array.array(self.typecode, self.smallerexample)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000229 ab = array.array(self.typecode, self.biggerexample)
Guido van Rossum7f1d3aa1998-07-16 15:31:43 +0000230
Walter Dörwald7fd94242003-05-18 00:47:47 +0000231 self.assert_((a == 2*a) is False)
232 self.assert_((a != 2*a) is True)
233 self.assert_((a < 2*a) is True)
234 self.assert_((a <= 2*a) is True)
235 self.assert_((a > 2*a) is False)
236 self.assert_((a >= 2*a) is False)
Martin v. Löwis99866332002-03-01 10:27:01 +0000237
Neal Norwitzbd2835c2006-03-17 08:54:15 +0000238 self.assert_((a == al) is False)
239 self.assert_((a != al) is True)
240 self.assert_((a < al) is False)
241 self.assert_((a <= al) is False)
242 self.assert_((a > al) is True)
243 self.assert_((a >= al) is True)
Martin v. Löwis99866332002-03-01 10:27:01 +0000244
Walter Dörwald7fd94242003-05-18 00:47:47 +0000245 self.assert_((a == ab) is False)
246 self.assert_((a != ab) is True)
247 self.assert_((a < ab) is True)
248 self.assert_((a <= ab) is True)
249 self.assert_((a > ab) is False)
250 self.assert_((a >= ab) is False)
Martin v. Löwis99866332002-03-01 10:27:01 +0000251
Walter Dörwald7fd94242003-05-18 00:47:47 +0000252 def test_add(self):
253 a = array.array(self.typecode, self.example) \
254 + array.array(self.typecode, self.example[::-1])
255 self.assertEqual(
256 a,
257 array.array(self.typecode, self.example + self.example[::-1])
258 )
Martin v. Löwis99866332002-03-01 10:27:01 +0000259
Walter Dörwald7fd94242003-05-18 00:47:47 +0000260 b = array.array(self.badtypecode())
261 self.assertRaises(TypeError, a.__add__, b)
262
263 self.assertRaises(TypeError, a.__add__, "bad")
264
265 def test_iadd(self):
266 a = array.array(self.typecode, self.example[::-1])
267 b = a
268 a += array.array(self.typecode, 2*self.example)
269 self.assert_(a is b)
270 self.assertEqual(
271 a,
272 array.array(self.typecode, self.example[::-1]+2*self.example)
273 )
274
275 b = array.array(self.badtypecode())
276 self.assertRaises(TypeError, a.__add__, b)
277
278 self.assertRaises(TypeError, a.__iadd__, "bad")
279
280 def test_mul(self):
281 a = 5*array.array(self.typecode, self.example)
282 self.assertEqual(
283 a,
284 array.array(self.typecode, 5*self.example)
285 )
286
287 a = array.array(self.typecode, self.example)*5
288 self.assertEqual(
289 a,
290 array.array(self.typecode, self.example*5)
291 )
292
293 a = 0*array.array(self.typecode, self.example)
294 self.assertEqual(
295 a,
296 array.array(self.typecode)
297 )
298
299 a = (-1)*array.array(self.typecode, self.example)
300 self.assertEqual(
301 a,
302 array.array(self.typecode)
303 )
304
305 self.assertRaises(TypeError, a.__mul__, "bad")
306
307 def test_imul(self):
308 a = array.array(self.typecode, self.example)
309 b = a
310
311 a *= 5
312 self.assert_(a is b)
313 self.assertEqual(
314 a,
315 array.array(self.typecode, 5*self.example)
316 )
317
318 a *= 0
319 self.assert_(a is b)
320 self.assertEqual(a, array.array(self.typecode))
321
322 a *= 1000
323 self.assert_(a is b)
324 self.assertEqual(a, array.array(self.typecode))
325
326 a *= -1
327 self.assert_(a is b)
328 self.assertEqual(a, array.array(self.typecode))
329
330 a = array.array(self.typecode, self.example)
331 a *= -1
332 self.assertEqual(a, array.array(self.typecode))
333
334 self.assertRaises(TypeError, a.__imul__, "bad")
335
336 def test_getitem(self):
337 a = array.array(self.typecode, self.example)
338 self.assertEntryEqual(a[0], self.example[0])
Guido van Rossume2a383d2007-01-15 16:59:06 +0000339 self.assertEntryEqual(a[0], self.example[0])
Walter Dörwald7fd94242003-05-18 00:47:47 +0000340 self.assertEntryEqual(a[-1], self.example[-1])
Guido van Rossume2a383d2007-01-15 16:59:06 +0000341 self.assertEntryEqual(a[-1], self.example[-1])
Walter Dörwald7fd94242003-05-18 00:47:47 +0000342 self.assertEntryEqual(a[len(self.example)-1], self.example[-1])
343 self.assertEntryEqual(a[-len(self.example)], self.example[0])
344 self.assertRaises(TypeError, a.__getitem__)
345 self.assertRaises(IndexError, a.__getitem__, len(self.example))
346 self.assertRaises(IndexError, a.__getitem__, -len(self.example)-1)
347
348 def test_setitem(self):
349 a = array.array(self.typecode, self.example)
350 a[0] = a[-1]
351 self.assertEntryEqual(a[0], a[-1])
352
353 a = array.array(self.typecode, self.example)
Guido van Rossume2a383d2007-01-15 16:59:06 +0000354 a[0] = a[-1]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000355 self.assertEntryEqual(a[0], a[-1])
356
357 a = array.array(self.typecode, self.example)
358 a[-1] = a[0]
359 self.assertEntryEqual(a[0], a[-1])
360
361 a = array.array(self.typecode, self.example)
Guido van Rossume2a383d2007-01-15 16:59:06 +0000362 a[-1] = a[0]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000363 self.assertEntryEqual(a[0], a[-1])
364
365 a = array.array(self.typecode, self.example)
366 a[len(self.example)-1] = a[0]
367 self.assertEntryEqual(a[0], a[-1])
368
369 a = array.array(self.typecode, self.example)
370 a[-len(self.example)] = a[-1]
371 self.assertEntryEqual(a[0], a[-1])
372
373 self.assertRaises(TypeError, a.__setitem__)
374 self.assertRaises(TypeError, a.__setitem__, None)
375 self.assertRaises(TypeError, a.__setitem__, 0, None)
376 self.assertRaises(
377 IndexError,
378 a.__setitem__,
379 len(self.example), self.example[0]
380 )
381 self.assertRaises(
382 IndexError,
383 a.__setitem__,
384 -len(self.example)-1, self.example[0]
385 )
386
387 def test_delitem(self):
388 a = array.array(self.typecode, self.example)
389 del a[0]
390 self.assertEqual(
391 a,
392 array.array(self.typecode, self.example[1:])
393 )
394
395 a = array.array(self.typecode, self.example)
396 del a[-1]
397 self.assertEqual(
398 a,
399 array.array(self.typecode, self.example[:-1])
400 )
401
402 a = array.array(self.typecode, self.example)
403 del a[len(self.example)-1]
404 self.assertEqual(
405 a,
406 array.array(self.typecode, self.example[:-1])
407 )
408
409 a = array.array(self.typecode, self.example)
410 del a[-len(self.example)]
411 self.assertEqual(
412 a,
413 array.array(self.typecode, self.example[1:])
414 )
415
416 self.assertRaises(TypeError, a.__delitem__)
417 self.assertRaises(TypeError, a.__delitem__, None)
418 self.assertRaises(IndexError, a.__delitem__, len(self.example))
419 self.assertRaises(IndexError, a.__delitem__, -len(self.example)-1)
420
421 def test_getslice(self):
422 a = array.array(self.typecode, self.example)
423 self.assertEqual(a[:], a)
424
425 self.assertEqual(
426 a[1:],
427 array.array(self.typecode, self.example[1:])
428 )
429
430 self.assertEqual(
431 a[:1],
432 array.array(self.typecode, self.example[:1])
433 )
434
435 self.assertEqual(
436 a[:-1],
437 array.array(self.typecode, self.example[:-1])
438 )
439
440 self.assertEqual(
441 a[-1:],
442 array.array(self.typecode, self.example[-1:])
443 )
444
445 self.assertEqual(
446 a[-1:-1],
447 array.array(self.typecode)
448 )
449
450 self.assertEqual(
Walter Dörwald1083c242005-01-21 21:16:51 +0000451 a[2:1],
452 array.array(self.typecode)
453 )
454
455 self.assertEqual(
Walter Dörwald7fd94242003-05-18 00:47:47 +0000456 a[1000:],
457 array.array(self.typecode)
458 )
459 self.assertEqual(a[-1000:], a)
460 self.assertEqual(a[:1000], a)
461 self.assertEqual(
462 a[:-1000],
463 array.array(self.typecode)
464 )
465 self.assertEqual(a[-1000:1000], a)
466 self.assertEqual(
467 a[2000:1000],
468 array.array(self.typecode)
469 )
470
471 def test_setslice(self):
472 a = array.array(self.typecode, self.example)
473 a[:1] = a
474 self.assertEqual(
475 a,
476 array.array(self.typecode, self.example + self.example[1:])
477 )
478
479 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000480 a[:-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000481 self.assertEqual(
482 a,
483 array.array(self.typecode, self.example + self.example[-1:])
484 )
485
486 a = array.array(self.typecode, self.example)
487 a[-1:] = a
488 self.assertEqual(
489 a,
490 array.array(self.typecode, self.example[:-1] + self.example)
491 )
492
493 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000494 a[1:] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000495 self.assertEqual(
496 a,
497 array.array(self.typecode, self.example[:1] + self.example)
498 )
499
500 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000501 a[1:-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000502 self.assertEqual(
503 a,
504 array.array(
505 self.typecode,
506 self.example[:1] + self.example + self.example[-1:]
507 )
508 )
509
510 a = array.array(self.typecode, self.example)
511 a[1000:] = a
512 self.assertEqual(
513 a,
514 array.array(self.typecode, 2*self.example)
515 )
516
517 a = array.array(self.typecode, self.example)
518 a[-1000:] = a
519 self.assertEqual(
520 a,
521 array.array(self.typecode, self.example)
522 )
523
524 a = array.array(self.typecode, self.example)
525 a[:1000] = a
526 self.assertEqual(
527 a,
528 array.array(self.typecode, self.example)
529 )
530
531 a = array.array(self.typecode, self.example)
532 a[:-1000] = a
533 self.assertEqual(
534 a,
535 array.array(self.typecode, 2*self.example)
536 )
537
538 a = array.array(self.typecode, self.example)
539 a[1:0] = a
540 self.assertEqual(
541 a,
542 array.array(self.typecode, self.example[:1] + self.example + self.example[1:])
543 )
544
545 a = array.array(self.typecode, self.example)
546 a[2000:1000] = a
547 self.assertEqual(
548 a,
549 array.array(self.typecode, 2*self.example)
550 )
551
552 a = array.array(self.typecode, self.example)
553 self.assertRaises(TypeError, a.__setslice__, 0, 0, None)
554 self.assertRaises(TypeError, a.__setitem__, slice(0, 1), None)
555
556 b = array.array(self.badtypecode())
557 self.assertRaises(TypeError, a.__setslice__, 0, 0, b)
558 self.assertRaises(TypeError, a.__setitem__, slice(0, 1), b)
559
560 def test_index(self):
561 example = 2*self.example
562 a = array.array(self.typecode, example)
563 self.assertRaises(TypeError, a.index)
564 for x in example:
565 self.assertEqual(a.index(x), example.index(x))
566 self.assertRaises(ValueError, a.index, None)
567 self.assertRaises(ValueError, a.index, self.outside)
568
569 def test_count(self):
570 example = 2*self.example
571 a = array.array(self.typecode, example)
572 self.assertRaises(TypeError, a.count)
573 for x in example:
574 self.assertEqual(a.count(x), example.count(x))
575 self.assertEqual(a.count(self.outside), 0)
576 self.assertEqual(a.count(None), 0)
577
578 def test_remove(self):
579 for x in self.example:
580 example = 2*self.example
581 a = array.array(self.typecode, example)
582 pos = example.index(x)
583 example2 = example[:pos] + example[pos+1:]
584 a.remove(x)
585 self.assertEqual(a, array.array(self.typecode, example2))
586
587 a = array.array(self.typecode, self.example)
588 self.assertRaises(ValueError, a.remove, self.outside)
589
590 self.assertRaises(ValueError, a.remove, None)
591
592 def test_pop(self):
593 a = array.array(self.typecode)
594 self.assertRaises(IndexError, a.pop)
595
596 a = array.array(self.typecode, 2*self.example)
597 self.assertRaises(TypeError, a.pop, 42, 42)
598 self.assertRaises(TypeError, a.pop, None)
599 self.assertRaises(IndexError, a.pop, len(a))
600 self.assertRaises(IndexError, a.pop, -len(a)-1)
601
602 self.assertEntryEqual(a.pop(0), self.example[0])
603 self.assertEqual(
604 a,
605 array.array(self.typecode, self.example[1:]+self.example)
606 )
607 self.assertEntryEqual(a.pop(1), self.example[2])
608 self.assertEqual(
609 a,
610 array.array(self.typecode, self.example[1:2]+self.example[3:]+self.example)
611 )
612 self.assertEntryEqual(a.pop(0), self.example[1])
613 self.assertEntryEqual(a.pop(), self.example[-1])
614 self.assertEqual(
615 a,
616 array.array(self.typecode, self.example[3:]+self.example[:-1])
617 )
618
619 def test_reverse(self):
620 a = array.array(self.typecode, self.example)
621 self.assertRaises(TypeError, a.reverse, 42)
Fred Drake004d5e62000-10-23 17:22:08 +0000622 a.reverse()
Walter Dörwald7fd94242003-05-18 00:47:47 +0000623 self.assertEqual(
624 a,
625 array.array(self.typecode, self.example[::-1])
626 )
627
628 def test_extend(self):
629 a = array.array(self.typecode, self.example)
630 self.assertRaises(TypeError, a.extend)
631 a.extend(array.array(self.typecode, self.example[::-1]))
632 self.assertEqual(
633 a,
634 array.array(self.typecode, self.example+self.example[::-1])
635 )
636
637 b = array.array(self.badtypecode())
638 self.assertRaises(TypeError, a.extend, b)
639
Raymond Hettinger49f9bd12004-03-14 05:43:59 +0000640 a = array.array(self.typecode, self.example)
641 a.extend(self.example[::-1])
642 self.assertEqual(
643 a,
644 array.array(self.typecode, self.example+self.example[::-1])
645 )
646
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +0000647 def test_constructor_with_iterable_argument(self):
648 a = array.array(self.typecode, iter(self.example))
649 b = array.array(self.typecode, self.example)
650 self.assertEqual(a, b)
651
652 # non-iterable argument
653 self.assertRaises(TypeError, array.array, self.typecode, 10)
654
655 # pass through errors raised in __iter__
656 class A:
657 def __iter__(self):
658 raise UnicodeError
659 self.assertRaises(UnicodeError, array.array, self.typecode, A())
660
661 # pass through errors raised in next()
662 def B():
663 raise UnicodeError
664 yield None
665 self.assertRaises(UnicodeError, array.array, self.typecode, B())
666
Walter Dörwald7fd94242003-05-18 00:47:47 +0000667 def test_coveritertraverse(self):
668 try:
669 import gc
670 except ImportError:
671 return
672 a = array.array(self.typecode)
673 l = [iter(a)]
674 l.append(l)
675 gc.collect()
676
677 def test_buffer(self):
678 a = array.array(self.typecode, self.example)
679 b = buffer(a)
680 self.assertEqual(b[0], a.tostring()[0])
681
Raymond Hettingercb87bc82004-05-31 00:35:52 +0000682 def test_weakref(self):
683 s = array.array(self.typecode, self.example)
684 p = proxy(s)
685 self.assertEqual(p.tostring(), s.tostring())
686 s = None
687 self.assertRaises(ReferenceError, len, p)
688
Skip Montanarod5cf0b82003-08-03 23:02:10 +0000689 def test_bug_782369(self):
690 import sys
Skip Montanaroed9bf122003-08-03 23:30:40 +0000691 if hasattr(sys, "getrefcount"):
692 for i in range(10):
693 b = array.array('B', range(64))
694 rc = sys.getrefcount(10)
695 for i in range(10):
696 b = array.array('B', range(64))
697 self.assertEqual(rc, sys.getrefcount(10))
Skip Montanarod5cf0b82003-08-03 23:02:10 +0000698
Thomas Woutersb2137042007-02-01 18:02:27 +0000699 def test_subclass_with_kwargs(self):
700 # SF bug #1486663 -- this used to erroneously raise a TypeError
701 ArraySubclassWithKwargs('b', newarg=1)
Raymond Hettingercb87bc82004-05-31 00:35:52 +0000702
703
Walter Dörwald7fd94242003-05-18 00:47:47 +0000704class StringTest(BaseTest):
705
706 def test_setitem(self):
Guido van Rossumcd16bf62007-06-13 18:07:49 +0000707 super().test_setitem()
Walter Dörwald7fd94242003-05-18 00:47:47 +0000708 a = array.array(self.typecode, self.example)
709 self.assertRaises(TypeError, a.__setitem__, 0, self.example[:2])
710
711class CharacterTest(StringTest):
712 typecode = 'c'
713 example = '\x01azAZ\x00\xfe'
714 smallerexample = '\x01azAY\x00\xfe'
715 biggerexample = '\x01azAZ\x00\xff'
716 outside = '\x33'
717 minitemsize = 1
718
719 def test_subbclassing(self):
720 class EditableString(array.array):
721 def __new__(cls, s, *args, **kwargs):
722 return array.array.__new__(cls, 'c', s)
723
724 def __init__(self, s, color='blue'):
Walter Dörwald7fd94242003-05-18 00:47:47 +0000725 self.color = color
726
727 def strip(self):
728 self[:] = array.array('c', self.tostring().strip())
729
730 def __repr__(self):
731 return 'EditableString(%r)' % self.tostring()
732
733 s = EditableString("\ttest\r\n")
734 s.strip()
735 self.assertEqual(s.tostring(), "test")
736
737 self.assertEqual(s.color, "blue")
738 s.color = "red"
739 self.assertEqual(s.color, "red")
Guido van Rossumcc2b0162007-02-11 06:12:03 +0000740 self.assertEqual(list(s.__dict__.keys()), ["color"])
Walter Dörwald7fd94242003-05-18 00:47:47 +0000741
742 def test_nounicode(self):
743 a = array.array(self.typecode, self.example)
Guido van Rossumef87d6e2007-05-02 19:09:54 +0000744 self.assertRaises(ValueError, a.fromunicode, str(''))
Walter Dörwald7fd94242003-05-18 00:47:47 +0000745 self.assertRaises(ValueError, a.tounicode)
746
747tests.append(CharacterTest)
748
Walter Dörwald1f5947b2007-05-22 16:52:54 +0000749class UnicodeTest(StringTest):
750 typecode = 'u'
751 example = '\x01\u263a\x00\ufeff'
752 smallerexample = '\x01\u263a\x00\ufefe'
753 biggerexample = '\x01\u263a\x01\ufeff'
754 outside = str('\x33')
755 minitemsize = 2
Walter Dörwald7fd94242003-05-18 00:47:47 +0000756
Walter Dörwald1f5947b2007-05-22 16:52:54 +0000757 def test_unicode(self):
758 self.assertRaises(TypeError, array.array, 'b', 'foo')
Walter Dörwald7fd94242003-05-18 00:47:47 +0000759
Walter Dörwald1f5947b2007-05-22 16:52:54 +0000760 a = array.array('u', '\xa0\xc2\u1234')
761 a.fromunicode(' ')
762 a.fromunicode('')
763 a.fromunicode('')
764 a.fromunicode('\x11abc\xff\u1234')
765 s = a.tounicode()
766 self.assertEqual(s, '\xa0\xc2\u1234 \x11abc\xff\u1234')
Walter Dörwald7fd94242003-05-18 00:47:47 +0000767
Walter Dörwald1f5947b2007-05-22 16:52:54 +0000768 s = '\x00="\'a\\b\x80\xff\u0000\u0001\u1234'
769 a = array.array('u', s)
770 self.assertEqual(
771 repr(a),
772 "array('u', '\\x00=\"\\'a\\\\b\\x80\\xff\\x00\\x01\\u1234')")
Walter Dörwald7fd94242003-05-18 00:47:47 +0000773
Walter Dörwald1f5947b2007-05-22 16:52:54 +0000774 self.assertRaises(TypeError, a.fromunicode)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000775
Walter Dörwald1f5947b2007-05-22 16:52:54 +0000776tests.append(UnicodeTest)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000777
778class NumberTest(BaseTest):
779
780 def test_extslice(self):
781 a = array.array(self.typecode, range(5))
782 self.assertEqual(a[::], a)
783 self.assertEqual(a[::2], array.array(self.typecode, [0,2,4]))
784 self.assertEqual(a[1::2], array.array(self.typecode, [1,3]))
785 self.assertEqual(a[::-1], array.array(self.typecode, [4,3,2,1,0]))
786 self.assertEqual(a[::-2], array.array(self.typecode, [4,2,0]))
787 self.assertEqual(a[3::-2], array.array(self.typecode, [3,1]))
788 self.assertEqual(a[-100:100:], a)
789 self.assertEqual(a[100:-100:-1], a[::-1])
Guido van Rossume2a383d2007-01-15 16:59:06 +0000790 self.assertEqual(a[-100:100:2], array.array(self.typecode, [0,2,4]))
Walter Dörwald7fd94242003-05-18 00:47:47 +0000791 self.assertEqual(a[1000:2000:2], array.array(self.typecode, []))
792 self.assertEqual(a[-1000:-2000:-2], array.array(self.typecode, []))
793
794 def test_delslice(self):
795 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000796 del a[::2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000797 self.assertEqual(a, array.array(self.typecode, [1,3]))
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,4]))
801 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000802 del a[1::-2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000803 self.assertEqual(a, array.array(self.typecode, [0,2,3,4]))
804 a = array.array(self.typecode, range(10))
Michael W. Hudson56796f62002-07-29 14:35:04 +0000805 del a[::1000]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000806 self.assertEqual(a, array.array(self.typecode, [1,2,3,4,5,6,7,8,9]))
807
808 def test_assignment(self):
809 a = array.array(self.typecode, range(10))
810 a[::2] = array.array(self.typecode, [42]*5)
811 self.assertEqual(a, array.array(self.typecode, [42, 1, 42, 3, 42, 5, 42, 7, 42, 9]))
812 a = array.array(self.typecode, range(10))
813 a[::-4] = array.array(self.typecode, [10]*3)
814 self.assertEqual(a, array.array(self.typecode, [0, 10, 2, 3, 4, 10, 6, 7, 8 ,10]))
815 a = array.array(self.typecode, range(4))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000816 a[::-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000817 self.assertEqual(a, array.array(self.typecode, [3, 2, 1, 0]))
818 a = array.array(self.typecode, range(10))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000819 b = a[:]
820 c = a[:]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000821 ins = array.array(self.typecode, range(2))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000822 a[2:3] = ins
823 b[slice(2,3)] = ins
824 c[2:3:] = ins
Fred Drake004d5e62000-10-23 17:22:08 +0000825
Walter Dörwald7fd94242003-05-18 00:47:47 +0000826 def test_iterationcontains(self):
827 a = array.array(self.typecode, range(10))
Guido van Rossum805365e2007-05-07 22:24:25 +0000828 self.assertEqual(list(a), list(range(10)))
Walter Dörwald7fd94242003-05-18 00:47:47 +0000829 b = array.array(self.typecode, [20])
830 self.assertEqual(a[-1] in a, True)
831 self.assertEqual(b[0] not in a, True)
832
833 def check_overflow(self, lower, upper):
834 # method to be used by subclasses
835
836 # should not overflow assigning lower limit
837 a = array.array(self.typecode, [lower])
838 a[0] = lower
839 # should overflow assigning less than lower limit
840 self.assertRaises(OverflowError, array.array, self.typecode, [lower-1])
841 self.assertRaises(OverflowError, a.__setitem__, 0, lower-1)
842 # should not overflow assigning upper limit
843 a = array.array(self.typecode, [upper])
844 a[0] = upper
845 # should overflow assigning more than upper limit
846 self.assertRaises(OverflowError, array.array, self.typecode, [upper+1])
847 self.assertRaises(OverflowError, a.__setitem__, 0, upper+1)
848
849 def test_subclassing(self):
850 typecode = self.typecode
851 class ExaggeratingArray(array.array):
852 __slots__ = ['offset']
853
854 def __new__(cls, typecode, data, offset):
855 return array.array.__new__(cls, typecode, data)
856
857 def __init__(self, typecode, data, offset):
858 self.offset = offset
859
860 def __getitem__(self, i):
861 return array.array.__getitem__(self, i) + self.offset
862
863 a = ExaggeratingArray(self.typecode, [3, 6, 7, 11], 4)
864 self.assertEntryEqual(a[0], 7)
865
866 self.assertRaises(AttributeError, setattr, a, "color", "blue")
867
868class SignedNumberTest(NumberTest):
869 example = [-1, 0, 1, 42, 0x7f]
870 smallerexample = [-1, 0, 1, 42, 0x7e]
871 biggerexample = [-1, 0, 1, 43, 0x7f]
872 outside = 23
873
874 def test_overflow(self):
875 a = array.array(self.typecode)
Guido van Rossume2a383d2007-01-15 16:59:06 +0000876 lower = -1 * int(pow(2, a.itemsize * 8 - 1))
877 upper = int(pow(2, a.itemsize * 8 - 1)) - 1
Walter Dörwald7fd94242003-05-18 00:47:47 +0000878 self.check_overflow(lower, upper)
879
880class UnsignedNumberTest(NumberTest):
881 example = [0, 1, 17, 23, 42, 0xff]
882 smallerexample = [0, 1, 17, 23, 42, 0xfe]
883 biggerexample = [0, 1, 17, 23, 43, 0xff]
884 outside = 0xaa
885
886 def test_overflow(self):
887 a = array.array(self.typecode)
888 lower = 0
Guido van Rossume2a383d2007-01-15 16:59:06 +0000889 upper = int(pow(2, a.itemsize * 8)) - 1
Walter Dörwald7fd94242003-05-18 00:47:47 +0000890 self.check_overflow(lower, upper)
Fred Drake004d5e62000-10-23 17:22:08 +0000891
892
Walter Dörwald7fd94242003-05-18 00:47:47 +0000893class ByteTest(SignedNumberTest):
894 typecode = 'b'
895 minitemsize = 1
896tests.append(ByteTest)
Fred Drake004d5e62000-10-23 17:22:08 +0000897
Walter Dörwald7fd94242003-05-18 00:47:47 +0000898class UnsignedByteTest(UnsignedNumberTest):
899 typecode = 'B'
900 minitemsize = 1
901tests.append(UnsignedByteTest)
902
903class ShortTest(SignedNumberTest):
904 typecode = 'h'
905 minitemsize = 2
906tests.append(ShortTest)
907
908class UnsignedShortTest(UnsignedNumberTest):
909 typecode = 'H'
910 minitemsize = 2
911tests.append(UnsignedShortTest)
912
913class IntTest(SignedNumberTest):
914 typecode = 'i'
915 minitemsize = 2
916tests.append(IntTest)
917
918class UnsignedIntTest(UnsignedNumberTest):
919 typecode = 'I'
920 minitemsize = 2
921tests.append(UnsignedIntTest)
922
923class LongTest(SignedNumberTest):
924 typecode = 'l'
925 minitemsize = 4
926tests.append(LongTest)
927
928class UnsignedLongTest(UnsignedNumberTest):
929 typecode = 'L'
930 minitemsize = 4
931tests.append(UnsignedLongTest)
932
933class FPTest(NumberTest):
934 example = [-42.0, 0, 42, 1e5, -1e10]
935 smallerexample = [-42.0, 0, 42, 1e5, -2e10]
936 biggerexample = [-42.0, 0, 42, 1e5, 1e10]
937 outside = 23
938
939 def assertEntryEqual(self, entry1, entry2):
940 self.assertAlmostEqual(entry1, entry2)
941
Walter Dörwaldcf99b0a2003-05-22 13:15:31 +0000942 def test_byteswap(self):
943 a = array.array(self.typecode, self.example)
944 self.assertRaises(TypeError, a.byteswap, 42)
945 if a.itemsize in (1, 2, 4, 8):
946 b = array.array(self.typecode, self.example)
947 b.byteswap()
948 if a.itemsize==1:
949 self.assertEqual(a, b)
950 else:
951 # On alphas treating the byte swapped bit patters as
952 # floats/doubles results in floating point exceptions
953 # => compare the 8bit string values instead
954 self.assertNotEqual(a.tostring(), b.tostring())
955 b.byteswap()
956 self.assertEqual(a, b)
957
Neal Norwitz35c6cd02003-05-22 13:29:15 +0000958class FloatTest(FPTest):
959 typecode = 'f'
960 minitemsize = 4
Walter Dörwald7fd94242003-05-18 00:47:47 +0000961tests.append(FloatTest)
962
963class DoubleTest(FPTest):
964 typecode = 'd'
965 minitemsize = 8
966tests.append(DoubleTest)
967
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +0000968def test_main(verbose=None):
969 import sys
970
Walter Dörwald7fd94242003-05-18 00:47:47 +0000971 test_support.run_unittest(*tests)
972
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +0000973 # verify reference counting
974 if verbose and hasattr(sys, "gettotalrefcount"):
975 import gc
976 counts = [None] * 5
Guido van Rossum805365e2007-05-07 22:24:25 +0000977 for i in range(len(counts)):
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +0000978 test_support.run_unittest(*tests)
979 gc.collect()
980 counts[i] = sys.gettotalrefcount()
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000981 print(counts)
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +0000982
983if __name__ == "__main__":
984 test_main(verbose=True)