blob: 0ef5f9e518bc23ae94fbec6cd80dc5eab0a9007a [file] [log] [blame]
Roger E. Masse8db1b071996-12-09 20:09:16 +00001#! /usr/bin/env python
2"""Test the arraymodule.
Roger E. Massefab8ab81996-12-20 22:36:52 +00003 Roger E. Masse
Roger E. Masse8db1b071996-12-09 20:09:16 +00004"""
Roger E. Massefab8ab81996-12-20 22:36:52 +00005
Walter Dörwald7fd94242003-05-18 00:47:47 +00006import unittest
7from test import test_support
Raymond Hettingercb87bc82004-05-31 00:35:52 +00008from weakref import proxy
Christian Heimesc5f05e42008-02-23 17:40:11 +00009import array, cStringIO
Hirokazu Yamamoto0fc07472008-12-27 04:19:48 +000010from cPickle import loads, dumps, HIGHEST_PROTOCOL
Raymond Hettingerb0900e62004-12-16 16:23:40 +000011
12class ArraySubclass(array.array):
13 pass
Guido van Rossumc9f8f141997-04-09 20:51:54 +000014
Georg Brandlb84c1372007-01-21 10:28:43 +000015class ArraySubclassWithKwargs(array.array):
16 def __init__(self, typecode, newarg=None):
17 array.array.__init__(typecode)
18
Walter Dörwald7fd94242003-05-18 00:47:47 +000019tests = [] # list to accumulate all tests
20typecodes = "cubBhHiIlLfd"
Martin v. Löwis99866332002-03-01 10:27:01 +000021
Walter Dörwald7fd94242003-05-18 00:47:47 +000022class BadConstructorTest(unittest.TestCase):
Martin v. Löwis99866332002-03-01 10:27:01 +000023
Walter Dörwald7fd94242003-05-18 00:47:47 +000024 def test_constructor(self):
25 self.assertRaises(TypeError, array.array)
26 self.assertRaises(TypeError, array.array, spam=42)
27 self.assertRaises(TypeError, array.array, 'xx')
28 self.assertRaises(ValueError, array.array, 'x')
Martin v. Löwis99866332002-03-01 10:27:01 +000029
Walter Dörwald7fd94242003-05-18 00:47:47 +000030tests.append(BadConstructorTest)
Martin v. Löwis99866332002-03-01 10:27:01 +000031
Walter Dörwald7fd94242003-05-18 00:47:47 +000032class BaseTest(unittest.TestCase):
33 # Required class attributes (provided by subclasses
34 # typecode: the typecode to test
35 # example: an initializer usable in the constructor for this type
36 # smallerexample: the same length as example, but smaller
37 # biggerexample: the same length as example, but bigger
38 # outside: An entry that is not in example
39 # minitemsize: the minimum guaranteed itemsize
Martin v. Löwis99866332002-03-01 10:27:01 +000040
Walter Dörwald7fd94242003-05-18 00:47:47 +000041 def assertEntryEqual(self, entry1, entry2):
42 self.assertEqual(entry1, entry2)
Martin v. Löwis99866332002-03-01 10:27:01 +000043
Walter Dörwald7fd94242003-05-18 00:47:47 +000044 def badtypecode(self):
45 # Return a typecode that is different from our own
46 return typecodes[(typecodes.index(self.typecode)+1) % len(typecodes)]
Martin v. Löwis99866332002-03-01 10:27:01 +000047
Walter Dörwald7fd94242003-05-18 00:47:47 +000048 def test_constructor(self):
49 a = array.array(self.typecode)
50 self.assertEqual(a.typecode, self.typecode)
Benjamin Peterson5c8da862009-06-30 22:57:08 +000051 self.assertTrue(a.itemsize>=self.minitemsize)
Walter Dörwald7fd94242003-05-18 00:47:47 +000052 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()
Benjamin Peterson5c8da862009-06-30 22:57:08 +000066 self.assertTrue(isinstance(bi, tuple))
Walter Dörwald7fd94242003-05-18 00:47:47 +000067 self.assertEqual(len(bi), 2)
Benjamin Peterson5c8da862009-06-30 22:57:08 +000068 self.assertTrue(isinstance(bi[0], (int, long)))
69 self.assertTrue(isinstance(bi[1], int))
Walter Dörwald7fd94242003-05-18 00:47:47 +000070 self.assertEqual(bi[1], len(a))
Martin v. Löwis99866332002-03-01 10:27:01 +000071
Walter Dörwald7fd94242003-05-18 00:47:47 +000072 def test_byteswap(self):
73 a = array.array(self.typecode, self.example)
74 self.assertRaises(TypeError, a.byteswap, 42)
75 if a.itemsize in (1, 2, 4, 8):
76 b = array.array(self.typecode, self.example)
77 b.byteswap()
78 if a.itemsize==1:
79 self.assertEqual(a, b)
80 else:
81 self.assertNotEqual(a, b)
82 b.byteswap()
83 self.assertEqual(a, b)
Martin v. Löwis99866332002-03-01 10:27:01 +000084
Raymond Hettinger3aa82c02004-03-13 18:18:51 +000085 def test_copy(self):
86 import copy
87 a = array.array(self.typecode, self.example)
88 b = copy.copy(a)
89 self.assertNotEqual(id(a), id(b))
90 self.assertEqual(a, b)
91
Thomas Wouters9e398ca2006-08-24 18:40:20 +000092 def test_deepcopy(self):
93 import copy
94 a = array.array(self.typecode, self.example)
95 b = copy.deepcopy(a)
96 self.assertNotEqual(id(a), id(b))
97 self.assertEqual(a, b)
98
Raymond Hettingerb0900e62004-12-16 16:23:40 +000099 def test_pickle(self):
Hirokazu Yamamoto0fc07472008-12-27 04:19:48 +0000100 for protocol in range(HIGHEST_PROTOCOL + 1):
Raymond Hettingerb0900e62004-12-16 16:23:40 +0000101 a = array.array(self.typecode, self.example)
102 b = loads(dumps(a, protocol))
103 self.assertNotEqual(id(a), id(b))
104 self.assertEqual(a, b)
105
106 a = ArraySubclass(self.typecode, self.example)
107 a.x = 10
108 b = loads(dumps(a, protocol))
109 self.assertNotEqual(id(a), id(b))
110 self.assertEqual(a, b)
111 self.assertEqual(a.x, b.x)
112 self.assertEqual(type(a), type(b))
113
Raymond Hettingere6e660b2007-04-02 17:29:30 +0000114 def test_pickle_for_empty_array(self):
Hirokazu Yamamoto0fc07472008-12-27 04:19:48 +0000115 for protocol in range(HIGHEST_PROTOCOL + 1):
Raymond Hettingere6e660b2007-04-02 17:29:30 +0000116 a = array.array(self.typecode)
117 b = loads(dumps(a, protocol))
118 self.assertNotEqual(id(a), id(b))
119 self.assertEqual(a, b)
120
121 a = ArraySubclass(self.typecode)
122 a.x = 10
123 b = loads(dumps(a, protocol))
124 self.assertNotEqual(id(a), id(b))
125 self.assertEqual(a, b)
126 self.assertEqual(a.x, b.x)
127 self.assertEqual(type(a), type(b))
128
Walter Dörwald7fd94242003-05-18 00:47:47 +0000129 def test_insert(self):
130 a = array.array(self.typecode, self.example)
131 a.insert(0, self.example[0])
132 self.assertEqual(len(a), 1+len(self.example))
133 self.assertEqual(a[0], a[1])
134 self.assertRaises(TypeError, a.insert)
135 self.assertRaises(TypeError, a.insert, None)
Walter Dörwaldba39d9c2003-05-18 01:56:25 +0000136 self.assertRaises(TypeError, a.insert, 0, None)
Martin v. Löwis99866332002-03-01 10:27:01 +0000137
Walter Dörwald9e46abe2003-05-18 03:15:10 +0000138 a = array.array(self.typecode, self.example)
139 a.insert(-1, self.example[0])
140 self.assertEqual(
141 a,
142 array.array(
143 self.typecode,
144 self.example[:-1] + self.example[:1] + self.example[-1:]
145 )
146 )
147
148 a = array.array(self.typecode, self.example)
149 a.insert(-1000, self.example[0])
150 self.assertEqual(
151 a,
152 array.array(self.typecode, self.example[:1] + self.example)
153 )
154
155 a = array.array(self.typecode, self.example)
156 a.insert(1000, self.example[0])
157 self.assertEqual(
158 a,
159 array.array(self.typecode, self.example + self.example[:1])
160 )
161
Walter Dörwald7fd94242003-05-18 00:47:47 +0000162 def test_tofromfile(self):
163 a = array.array(self.typecode, 2*self.example)
164 self.assertRaises(TypeError, a.tofile)
165 self.assertRaises(TypeError, a.tofile, cStringIO.StringIO())
Neal Norwitz36a59b42008-04-10 05:46:39 +0000166 test_support.unlink(test_support.TESTFN)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000167 f = open(test_support.TESTFN, 'wb')
168 try:
169 a.tofile(f)
170 f.close()
171 b = array.array(self.typecode)
172 f = open(test_support.TESTFN, 'rb')
173 self.assertRaises(TypeError, b.fromfile)
174 self.assertRaises(
175 TypeError,
176 b.fromfile,
177 cStringIO.StringIO(), len(self.example)
178 )
179 b.fromfile(f, len(self.example))
180 self.assertEqual(b, array.array(self.typecode, self.example))
181 self.assertNotEqual(a, b)
182 b.fromfile(f, len(self.example))
183 self.assertEqual(a, b)
184 self.assertRaises(EOFError, b.fromfile, f, 1)
185 f.close()
186 finally:
187 if not f.closed:
188 f.close()
189 test_support.unlink(test_support.TESTFN)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000190
Walter Dörwald7fd94242003-05-18 00:47:47 +0000191 def test_tofromlist(self):
192 a = array.array(self.typecode, 2*self.example)
193 b = array.array(self.typecode)
194 self.assertRaises(TypeError, a.tolist, 42)
195 self.assertRaises(TypeError, b.fromlist)
196 self.assertRaises(TypeError, b.fromlist, 42)
197 self.assertRaises(TypeError, b.fromlist, [None])
198 b.fromlist(a.tolist())
199 self.assertEqual(a, b)
Fred Drake78334472000-06-28 17:50:51 +0000200
Walter Dörwald7fd94242003-05-18 00:47:47 +0000201 def test_tofromstring(self):
202 a = array.array(self.typecode, 2*self.example)
203 b = array.array(self.typecode)
204 self.assertRaises(TypeError, a.tostring, 42)
205 self.assertRaises(TypeError, b.fromstring)
206 self.assertRaises(TypeError, b.fromstring, 42)
207 b.fromstring(a.tostring())
208 self.assertEqual(a, b)
209 if a.itemsize>1:
210 self.assertRaises(ValueError, b.fromstring, "x")
Fred Drake78334472000-06-28 17:50:51 +0000211
Walter Dörwald7fd94242003-05-18 00:47:47 +0000212 def test_repr(self):
213 a = array.array(self.typecode, 2*self.example)
214 self.assertEqual(a, eval(repr(a), {"array": array.array}))
Fred Drake78334472000-06-28 17:50:51 +0000215
Walter Dörwald7fd94242003-05-18 00:47:47 +0000216 a = array.array(self.typecode)
217 self.assertEqual(repr(a), "array('%s')" % self.typecode)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000218
Walter Dörwald7fd94242003-05-18 00:47:47 +0000219 def test_str(self):
220 a = array.array(self.typecode, 2*self.example)
221 str(a)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000222
Walter Dörwald7fd94242003-05-18 00:47:47 +0000223 def test_cmp(self):
224 a = array.array(self.typecode, self.example)
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000225 self.assertTrue((a == 42) is False)
226 self.assertTrue((a != 42) is True)
Tim Peterscc78e472000-11-14 21:36:07 +0000227
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000228 self.assertTrue((a == a) is True)
229 self.assertTrue((a != a) is False)
230 self.assertTrue((a < a) is False)
231 self.assertTrue((a <= a) is True)
232 self.assertTrue((a > a) is False)
233 self.assertTrue((a >= a) is True)
Tim Peterscc78e472000-11-14 21:36:07 +0000234
Neal Norwitzc72f5012006-03-17 08:55:46 +0000235 al = array.array(self.typecode, self.smallerexample)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000236 ab = array.array(self.typecode, self.biggerexample)
Guido van Rossum7f1d3aa1998-07-16 15:31:43 +0000237
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000238 self.assertTrue((a == 2*a) is False)
239 self.assertTrue((a != 2*a) is True)
240 self.assertTrue((a < 2*a) is True)
241 self.assertTrue((a <= 2*a) is True)
242 self.assertTrue((a > 2*a) is False)
243 self.assertTrue((a >= 2*a) is False)
Martin v. Löwis99866332002-03-01 10:27:01 +0000244
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000245 self.assertTrue((a == al) is False)
246 self.assertTrue((a != al) is True)
247 self.assertTrue((a < al) is False)
248 self.assertTrue((a <= al) is False)
249 self.assertTrue((a > al) is True)
250 self.assertTrue((a >= al) is True)
Martin v. Löwis99866332002-03-01 10:27:01 +0000251
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000252 self.assertTrue((a == ab) is False)
253 self.assertTrue((a != ab) is True)
254 self.assertTrue((a < ab) is True)
255 self.assertTrue((a <= ab) is True)
256 self.assertTrue((a > ab) is False)
257 self.assertTrue((a >= ab) is False)
Martin v. Löwis99866332002-03-01 10:27:01 +0000258
Walter Dörwald7fd94242003-05-18 00:47:47 +0000259 def test_add(self):
260 a = array.array(self.typecode, self.example) \
261 + array.array(self.typecode, self.example[::-1])
262 self.assertEqual(
263 a,
264 array.array(self.typecode, self.example + self.example[::-1])
265 )
Martin v. Löwis99866332002-03-01 10:27:01 +0000266
Walter Dörwald7fd94242003-05-18 00:47:47 +0000267 b = array.array(self.badtypecode())
268 self.assertRaises(TypeError, a.__add__, b)
269
270 self.assertRaises(TypeError, a.__add__, "bad")
271
272 def test_iadd(self):
273 a = array.array(self.typecode, self.example[::-1])
274 b = a
275 a += array.array(self.typecode, 2*self.example)
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000276 self.assertTrue(a is b)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000277 self.assertEqual(
278 a,
279 array.array(self.typecode, self.example[::-1]+2*self.example)
280 )
Alexandre Vassalotti5b1abb72009-07-05 06:33:41 +0000281 a = array.array(self.typecode, self.example)
282 a += a
283 self.assertEqual(
284 a,
285 array.array(self.typecode, self.example + self.example)
286 )
Walter Dörwald7fd94242003-05-18 00:47:47 +0000287
288 b = array.array(self.badtypecode())
289 self.assertRaises(TypeError, a.__add__, b)
290
291 self.assertRaises(TypeError, a.__iadd__, "bad")
292
293 def test_mul(self):
294 a = 5*array.array(self.typecode, self.example)
295 self.assertEqual(
296 a,
297 array.array(self.typecode, 5*self.example)
298 )
299
300 a = array.array(self.typecode, self.example)*5
301 self.assertEqual(
302 a,
303 array.array(self.typecode, self.example*5)
304 )
305
306 a = 0*array.array(self.typecode, self.example)
307 self.assertEqual(
308 a,
309 array.array(self.typecode)
310 )
311
312 a = (-1)*array.array(self.typecode, self.example)
313 self.assertEqual(
314 a,
315 array.array(self.typecode)
316 )
317
318 self.assertRaises(TypeError, a.__mul__, "bad")
319
320 def test_imul(self):
321 a = array.array(self.typecode, self.example)
322 b = a
323
324 a *= 5
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000325 self.assertTrue(a is b)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000326 self.assertEqual(
327 a,
328 array.array(self.typecode, 5*self.example)
329 )
330
331 a *= 0
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000332 self.assertTrue(a is b)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000333 self.assertEqual(a, array.array(self.typecode))
334
335 a *= 1000
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000336 self.assertTrue(a is b)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000337 self.assertEqual(a, array.array(self.typecode))
338
339 a *= -1
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000340 self.assertTrue(a is b)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000341 self.assertEqual(a, array.array(self.typecode))
342
343 a = array.array(self.typecode, self.example)
344 a *= -1
345 self.assertEqual(a, array.array(self.typecode))
346
347 self.assertRaises(TypeError, a.__imul__, "bad")
348
349 def test_getitem(self):
350 a = array.array(self.typecode, self.example)
351 self.assertEntryEqual(a[0], self.example[0])
352 self.assertEntryEqual(a[0L], self.example[0])
353 self.assertEntryEqual(a[-1], self.example[-1])
354 self.assertEntryEqual(a[-1L], self.example[-1])
355 self.assertEntryEqual(a[len(self.example)-1], self.example[-1])
356 self.assertEntryEqual(a[-len(self.example)], self.example[0])
357 self.assertRaises(TypeError, a.__getitem__)
358 self.assertRaises(IndexError, a.__getitem__, len(self.example))
359 self.assertRaises(IndexError, a.__getitem__, -len(self.example)-1)
360
361 def test_setitem(self):
362 a = array.array(self.typecode, self.example)
363 a[0] = a[-1]
364 self.assertEntryEqual(a[0], a[-1])
365
366 a = array.array(self.typecode, self.example)
367 a[0L] = a[-1]
368 self.assertEntryEqual(a[0], a[-1])
369
370 a = array.array(self.typecode, self.example)
371 a[-1] = a[0]
372 self.assertEntryEqual(a[0], a[-1])
373
374 a = array.array(self.typecode, self.example)
375 a[-1L] = a[0]
376 self.assertEntryEqual(a[0], a[-1])
377
378 a = array.array(self.typecode, self.example)
379 a[len(self.example)-1] = a[0]
380 self.assertEntryEqual(a[0], a[-1])
381
382 a = array.array(self.typecode, self.example)
383 a[-len(self.example)] = a[-1]
384 self.assertEntryEqual(a[0], a[-1])
385
386 self.assertRaises(TypeError, a.__setitem__)
387 self.assertRaises(TypeError, a.__setitem__, None)
388 self.assertRaises(TypeError, a.__setitem__, 0, None)
389 self.assertRaises(
390 IndexError,
391 a.__setitem__,
392 len(self.example), self.example[0]
393 )
394 self.assertRaises(
395 IndexError,
396 a.__setitem__,
397 -len(self.example)-1, self.example[0]
398 )
399
400 def test_delitem(self):
401 a = array.array(self.typecode, self.example)
402 del a[0]
403 self.assertEqual(
404 a,
405 array.array(self.typecode, self.example[1:])
406 )
407
408 a = array.array(self.typecode, self.example)
409 del a[-1]
410 self.assertEqual(
411 a,
412 array.array(self.typecode, self.example[:-1])
413 )
414
415 a = array.array(self.typecode, self.example)
416 del a[len(self.example)-1]
417 self.assertEqual(
418 a,
419 array.array(self.typecode, self.example[:-1])
420 )
421
422 a = array.array(self.typecode, self.example)
423 del a[-len(self.example)]
424 self.assertEqual(
425 a,
426 array.array(self.typecode, self.example[1:])
427 )
428
429 self.assertRaises(TypeError, a.__delitem__)
430 self.assertRaises(TypeError, a.__delitem__, None)
431 self.assertRaises(IndexError, a.__delitem__, len(self.example))
432 self.assertRaises(IndexError, a.__delitem__, -len(self.example)-1)
433
434 def test_getslice(self):
435 a = array.array(self.typecode, self.example)
436 self.assertEqual(a[:], a)
437
438 self.assertEqual(
439 a[1:],
440 array.array(self.typecode, self.example[1:])
441 )
442
443 self.assertEqual(
444 a[:1],
445 array.array(self.typecode, self.example[:1])
446 )
447
448 self.assertEqual(
449 a[:-1],
450 array.array(self.typecode, self.example[:-1])
451 )
452
453 self.assertEqual(
454 a[-1:],
455 array.array(self.typecode, self.example[-1:])
456 )
457
458 self.assertEqual(
459 a[-1:-1],
460 array.array(self.typecode)
461 )
462
463 self.assertEqual(
Walter Dörwald1083c242005-01-21 21:16:51 +0000464 a[2:1],
465 array.array(self.typecode)
466 )
467
468 self.assertEqual(
Walter Dörwald7fd94242003-05-18 00:47:47 +0000469 a[1000:],
470 array.array(self.typecode)
471 )
472 self.assertEqual(a[-1000:], a)
473 self.assertEqual(a[:1000], a)
474 self.assertEqual(
475 a[:-1000],
476 array.array(self.typecode)
477 )
478 self.assertEqual(a[-1000:1000], a)
479 self.assertEqual(
480 a[2000:1000],
481 array.array(self.typecode)
482 )
483
Thomas Wouters3ccec682007-08-28 15:28:19 +0000484 def test_extended_getslice(self):
485 # Test extended slicing by comparing with list slicing
486 # (Assumes list conversion works correctly, too)
487 a = array.array(self.typecode, self.example)
488 indices = (0, None, 1, 3, 19, 100, -1, -2, -31, -100)
489 for start in indices:
490 for stop in indices:
491 # Everything except the initial 0 (invalid step)
492 for step in indices[1:]:
493 self.assertEqual(list(a[start:stop:step]),
494 list(a)[start:stop:step])
495
Walter Dörwald7fd94242003-05-18 00:47:47 +0000496 def test_setslice(self):
497 a = array.array(self.typecode, self.example)
498 a[:1] = a
499 self.assertEqual(
500 a,
501 array.array(self.typecode, self.example + self.example[1:])
502 )
503
504 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000505 a[:-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000506 self.assertEqual(
507 a,
508 array.array(self.typecode, self.example + self.example[-1:])
509 )
510
511 a = array.array(self.typecode, self.example)
512 a[-1:] = a
513 self.assertEqual(
514 a,
515 array.array(self.typecode, self.example[:-1] + self.example)
516 )
517
518 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000519 a[1:] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000520 self.assertEqual(
521 a,
522 array.array(self.typecode, self.example[:1] + self.example)
523 )
524
525 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000526 a[1:-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000527 self.assertEqual(
528 a,
529 array.array(
530 self.typecode,
531 self.example[:1] + self.example + self.example[-1:]
532 )
533 )
534
535 a = array.array(self.typecode, self.example)
536 a[1000:] = a
537 self.assertEqual(
538 a,
539 array.array(self.typecode, 2*self.example)
540 )
541
542 a = array.array(self.typecode, self.example)
543 a[-1000:] = a
544 self.assertEqual(
545 a,
546 array.array(self.typecode, self.example)
547 )
548
549 a = array.array(self.typecode, self.example)
550 a[:1000] = a
551 self.assertEqual(
552 a,
553 array.array(self.typecode, self.example)
554 )
555
556 a = array.array(self.typecode, self.example)
557 a[:-1000] = a
558 self.assertEqual(
559 a,
560 array.array(self.typecode, 2*self.example)
561 )
562
563 a = array.array(self.typecode, self.example)
564 a[1:0] = a
565 self.assertEqual(
566 a,
567 array.array(self.typecode, self.example[:1] + self.example + self.example[1:])
568 )
569
570 a = array.array(self.typecode, self.example)
571 a[2000:1000] = a
572 self.assertEqual(
573 a,
574 array.array(self.typecode, 2*self.example)
575 )
576
577 a = array.array(self.typecode, self.example)
578 self.assertRaises(TypeError, a.__setslice__, 0, 0, None)
Thomas Wouters3ccec682007-08-28 15:28:19 +0000579 self.assertRaises(TypeError, a.__setitem__, slice(0, 0), None)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000580 self.assertRaises(TypeError, a.__setitem__, slice(0, 1), None)
581
582 b = array.array(self.badtypecode())
583 self.assertRaises(TypeError, a.__setslice__, 0, 0, b)
Thomas Wouters3ccec682007-08-28 15:28:19 +0000584 self.assertRaises(TypeError, a.__setitem__, slice(0, 0), b)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000585 self.assertRaises(TypeError, a.__setitem__, slice(0, 1), b)
586
Thomas Wouters3ccec682007-08-28 15:28:19 +0000587 def test_extended_set_del_slice(self):
588 indices = (0, None, 1, 3, 19, 100, -1, -2, -31, -100)
589 for start in indices:
590 for stop in indices:
591 # Everything except the initial 0 (invalid step)
592 for step in indices[1:]:
593 a = array.array(self.typecode, self.example)
594 L = list(a)
595 # Make sure we have a slice of exactly the right length,
596 # but with (hopefully) different data.
597 data = L[start:stop:step]
598 data.reverse()
599 L[start:stop:step] = data
600 a[start:stop:step] = array.array(self.typecode, data)
601 self.assertEquals(a, array.array(self.typecode, L))
602
603 del L[start:stop:step]
604 del a[start:stop:step]
605 self.assertEquals(a, array.array(self.typecode, L))
606
Walter Dörwald7fd94242003-05-18 00:47:47 +0000607 def test_index(self):
608 example = 2*self.example
609 a = array.array(self.typecode, example)
610 self.assertRaises(TypeError, a.index)
611 for x in example:
612 self.assertEqual(a.index(x), example.index(x))
613 self.assertRaises(ValueError, a.index, None)
614 self.assertRaises(ValueError, a.index, self.outside)
615
616 def test_count(self):
617 example = 2*self.example
618 a = array.array(self.typecode, example)
619 self.assertRaises(TypeError, a.count)
620 for x in example:
621 self.assertEqual(a.count(x), example.count(x))
622 self.assertEqual(a.count(self.outside), 0)
623 self.assertEqual(a.count(None), 0)
624
625 def test_remove(self):
626 for x in self.example:
627 example = 2*self.example
628 a = array.array(self.typecode, example)
629 pos = example.index(x)
630 example2 = example[:pos] + example[pos+1:]
631 a.remove(x)
632 self.assertEqual(a, array.array(self.typecode, example2))
633
634 a = array.array(self.typecode, self.example)
635 self.assertRaises(ValueError, a.remove, self.outside)
636
637 self.assertRaises(ValueError, a.remove, None)
638
639 def test_pop(self):
640 a = array.array(self.typecode)
641 self.assertRaises(IndexError, a.pop)
642
643 a = array.array(self.typecode, 2*self.example)
644 self.assertRaises(TypeError, a.pop, 42, 42)
645 self.assertRaises(TypeError, a.pop, None)
646 self.assertRaises(IndexError, a.pop, len(a))
647 self.assertRaises(IndexError, a.pop, -len(a)-1)
648
649 self.assertEntryEqual(a.pop(0), self.example[0])
650 self.assertEqual(
651 a,
652 array.array(self.typecode, self.example[1:]+self.example)
653 )
654 self.assertEntryEqual(a.pop(1), self.example[2])
655 self.assertEqual(
656 a,
657 array.array(self.typecode, self.example[1:2]+self.example[3:]+self.example)
658 )
659 self.assertEntryEqual(a.pop(0), self.example[1])
660 self.assertEntryEqual(a.pop(), self.example[-1])
661 self.assertEqual(
662 a,
663 array.array(self.typecode, self.example[3:]+self.example[:-1])
664 )
665
666 def test_reverse(self):
667 a = array.array(self.typecode, self.example)
668 self.assertRaises(TypeError, a.reverse, 42)
Fred Drake004d5e62000-10-23 17:22:08 +0000669 a.reverse()
Walter Dörwald7fd94242003-05-18 00:47:47 +0000670 self.assertEqual(
671 a,
672 array.array(self.typecode, self.example[::-1])
673 )
674
675 def test_extend(self):
676 a = array.array(self.typecode, self.example)
677 self.assertRaises(TypeError, a.extend)
678 a.extend(array.array(self.typecode, self.example[::-1]))
679 self.assertEqual(
680 a,
681 array.array(self.typecode, self.example+self.example[::-1])
682 )
683
Alexandre Vassalotti5b1abb72009-07-05 06:33:41 +0000684 a = array.array(self.typecode, self.example)
685 a.extend(a)
686 self.assertEqual(
687 a,
688 array.array(self.typecode, self.example+self.example)
689 )
690
Walter Dörwald7fd94242003-05-18 00:47:47 +0000691 b = array.array(self.badtypecode())
692 self.assertRaises(TypeError, a.extend, b)
693
Raymond Hettinger49f9bd12004-03-14 05:43:59 +0000694 a = array.array(self.typecode, self.example)
695 a.extend(self.example[::-1])
696 self.assertEqual(
697 a,
698 array.array(self.typecode, self.example+self.example[::-1])
699 )
700
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +0000701 def test_constructor_with_iterable_argument(self):
702 a = array.array(self.typecode, iter(self.example))
703 b = array.array(self.typecode, self.example)
704 self.assertEqual(a, b)
705
706 # non-iterable argument
707 self.assertRaises(TypeError, array.array, self.typecode, 10)
708
709 # pass through errors raised in __iter__
710 class A:
711 def __iter__(self):
712 raise UnicodeError
713 self.assertRaises(UnicodeError, array.array, self.typecode, A())
714
715 # pass through errors raised in next()
716 def B():
717 raise UnicodeError
718 yield None
719 self.assertRaises(UnicodeError, array.array, self.typecode, B())
720
Walter Dörwald7fd94242003-05-18 00:47:47 +0000721 def test_coveritertraverse(self):
722 try:
723 import gc
724 except ImportError:
725 return
726 a = array.array(self.typecode)
727 l = [iter(a)]
728 l.append(l)
729 gc.collect()
730
731 def test_buffer(self):
732 a = array.array(self.typecode, self.example)
733 b = buffer(a)
734 self.assertEqual(b[0], a.tostring()[0])
735
Raymond Hettingercb87bc82004-05-31 00:35:52 +0000736 def test_weakref(self):
737 s = array.array(self.typecode, self.example)
738 p = proxy(s)
739 self.assertEqual(p.tostring(), s.tostring())
740 s = None
741 self.assertRaises(ReferenceError, len, p)
742
Skip Montanarod5cf0b82003-08-03 23:02:10 +0000743 def test_bug_782369(self):
744 import sys
Skip Montanaroed9bf122003-08-03 23:30:40 +0000745 if hasattr(sys, "getrefcount"):
746 for i in range(10):
747 b = array.array('B', range(64))
748 rc = sys.getrefcount(10)
749 for i in range(10):
750 b = array.array('B', range(64))
751 self.assertEqual(rc, sys.getrefcount(10))
Skip Montanarod5cf0b82003-08-03 23:02:10 +0000752
Georg Brandlb84c1372007-01-21 10:28:43 +0000753 def test_subclass_with_kwargs(self):
754 # SF bug #1486663 -- this used to erroneously raise a TypeError
755 ArraySubclassWithKwargs('b', newarg=1)
Raymond Hettingercb87bc82004-05-31 00:35:52 +0000756
757
Walter Dörwald7fd94242003-05-18 00:47:47 +0000758class StringTest(BaseTest):
759
760 def test_setitem(self):
761 super(StringTest, self).test_setitem()
762 a = array.array(self.typecode, self.example)
763 self.assertRaises(TypeError, a.__setitem__, 0, self.example[:2])
764
765class CharacterTest(StringTest):
766 typecode = 'c'
767 example = '\x01azAZ\x00\xfe'
768 smallerexample = '\x01azAY\x00\xfe'
769 biggerexample = '\x01azAZ\x00\xff'
770 outside = '\x33'
771 minitemsize = 1
772
773 def test_subbclassing(self):
774 class EditableString(array.array):
775 def __new__(cls, s, *args, **kwargs):
776 return array.array.__new__(cls, 'c', s)
777
778 def __init__(self, s, color='blue'):
Walter Dörwald7fd94242003-05-18 00:47:47 +0000779 self.color = color
780
781 def strip(self):
782 self[:] = array.array('c', self.tostring().strip())
783
784 def __repr__(self):
785 return 'EditableString(%r)' % self.tostring()
786
787 s = EditableString("\ttest\r\n")
788 s.strip()
789 self.assertEqual(s.tostring(), "test")
790
791 self.assertEqual(s.color, "blue")
792 s.color = "red"
793 self.assertEqual(s.color, "red")
794 self.assertEqual(s.__dict__.keys(), ["color"])
795
796 def test_nounicode(self):
797 a = array.array(self.typecode, self.example)
798 self.assertRaises(ValueError, a.fromunicode, unicode(''))
799 self.assertRaises(ValueError, a.tounicode)
800
801tests.append(CharacterTest)
802
803if test_support.have_unicode:
804 class UnicodeTest(StringTest):
805 typecode = 'u'
806 example = unicode(r'\x01\u263a\x00\ufeff', 'unicode-escape')
807 smallerexample = unicode(r'\x01\u263a\x00\ufefe', 'unicode-escape')
808 biggerexample = unicode(r'\x01\u263a\x01\ufeff', 'unicode-escape')
809 outside = unicode('\x33')
810 minitemsize = 2
811
812 def test_unicode(self):
813 self.assertRaises(TypeError, array.array, 'b', unicode('foo', 'ascii'))
814
815 a = array.array('u', unicode(r'\xa0\xc2\u1234', 'unicode-escape'))
816 a.fromunicode(unicode(' ', 'ascii'))
817 a.fromunicode(unicode('', 'ascii'))
818 a.fromunicode(unicode('', 'ascii'))
819 a.fromunicode(unicode(r'\x11abc\xff\u1234', 'unicode-escape'))
820 s = a.tounicode()
821 self.assertEqual(
822 s,
823 unicode(r'\xa0\xc2\u1234 \x11abc\xff\u1234', 'unicode-escape')
824 )
825
826 s = unicode(r'\x00="\'a\\b\x80\xff\u0000\u0001\u1234', 'unicode-escape')
827 a = array.array('u', s)
828 self.assertEqual(
829 repr(a),
830 r"""array('u', u'\x00="\'a\\b\x80\xff\x00\x01\u1234')"""
831 )
832
833 self.assertRaises(TypeError, a.fromunicode)
834
835 tests.append(UnicodeTest)
836
837class NumberTest(BaseTest):
838
839 def test_extslice(self):
840 a = array.array(self.typecode, range(5))
841 self.assertEqual(a[::], a)
842 self.assertEqual(a[::2], array.array(self.typecode, [0,2,4]))
843 self.assertEqual(a[1::2], array.array(self.typecode, [1,3]))
844 self.assertEqual(a[::-1], array.array(self.typecode, [4,3,2,1,0]))
845 self.assertEqual(a[::-2], array.array(self.typecode, [4,2,0]))
846 self.assertEqual(a[3::-2], array.array(self.typecode, [3,1]))
847 self.assertEqual(a[-100:100:], a)
848 self.assertEqual(a[100:-100:-1], a[::-1])
849 self.assertEqual(a[-100L:100L:2L], array.array(self.typecode, [0,2,4]))
850 self.assertEqual(a[1000:2000:2], array.array(self.typecode, []))
851 self.assertEqual(a[-1000:-2000:-2], array.array(self.typecode, []))
852
853 def test_delslice(self):
854 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000855 del a[::2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000856 self.assertEqual(a, array.array(self.typecode, [1,3]))
857 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000858 del a[1::2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000859 self.assertEqual(a, array.array(self.typecode, [0,2,4]))
860 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000861 del a[1::-2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000862 self.assertEqual(a, array.array(self.typecode, [0,2,3,4]))
863 a = array.array(self.typecode, range(10))
Michael W. Hudson56796f62002-07-29 14:35:04 +0000864 del a[::1000]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000865 self.assertEqual(a, array.array(self.typecode, [1,2,3,4,5,6,7,8,9]))
866
867 def test_assignment(self):
868 a = array.array(self.typecode, range(10))
869 a[::2] = array.array(self.typecode, [42]*5)
870 self.assertEqual(a, array.array(self.typecode, [42, 1, 42, 3, 42, 5, 42, 7, 42, 9]))
871 a = array.array(self.typecode, range(10))
872 a[::-4] = array.array(self.typecode, [10]*3)
873 self.assertEqual(a, array.array(self.typecode, [0, 10, 2, 3, 4, 10, 6, 7, 8 ,10]))
874 a = array.array(self.typecode, range(4))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000875 a[::-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000876 self.assertEqual(a, array.array(self.typecode, [3, 2, 1, 0]))
877 a = array.array(self.typecode, range(10))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000878 b = a[:]
879 c = a[:]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000880 ins = array.array(self.typecode, range(2))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000881 a[2:3] = ins
882 b[slice(2,3)] = ins
883 c[2:3:] = ins
Fred Drake004d5e62000-10-23 17:22:08 +0000884
Walter Dörwald7fd94242003-05-18 00:47:47 +0000885 def test_iterationcontains(self):
886 a = array.array(self.typecode, range(10))
887 self.assertEqual(list(a), range(10))
888 b = array.array(self.typecode, [20])
889 self.assertEqual(a[-1] in a, True)
890 self.assertEqual(b[0] not in a, True)
891
892 def check_overflow(self, lower, upper):
893 # method to be used by subclasses
894
895 # should not overflow assigning lower limit
896 a = array.array(self.typecode, [lower])
897 a[0] = lower
898 # should overflow assigning less than lower limit
899 self.assertRaises(OverflowError, array.array, self.typecode, [lower-1])
900 self.assertRaises(OverflowError, a.__setitem__, 0, lower-1)
901 # should not overflow assigning upper limit
902 a = array.array(self.typecode, [upper])
903 a[0] = upper
904 # should overflow assigning more than upper limit
905 self.assertRaises(OverflowError, array.array, self.typecode, [upper+1])
906 self.assertRaises(OverflowError, a.__setitem__, 0, upper+1)
907
908 def test_subclassing(self):
909 typecode = self.typecode
910 class ExaggeratingArray(array.array):
911 __slots__ = ['offset']
912
913 def __new__(cls, typecode, data, offset):
914 return array.array.__new__(cls, typecode, data)
915
916 def __init__(self, typecode, data, offset):
917 self.offset = offset
918
919 def __getitem__(self, i):
920 return array.array.__getitem__(self, i) + self.offset
921
922 a = ExaggeratingArray(self.typecode, [3, 6, 7, 11], 4)
923 self.assertEntryEqual(a[0], 7)
924
925 self.assertRaises(AttributeError, setattr, a, "color", "blue")
926
927class SignedNumberTest(NumberTest):
928 example = [-1, 0, 1, 42, 0x7f]
929 smallerexample = [-1, 0, 1, 42, 0x7e]
930 biggerexample = [-1, 0, 1, 43, 0x7f]
931 outside = 23
932
933 def test_overflow(self):
934 a = array.array(self.typecode)
935 lower = -1 * long(pow(2, a.itemsize * 8 - 1))
936 upper = long(pow(2, a.itemsize * 8 - 1)) - 1L
937 self.check_overflow(lower, upper)
938
939class UnsignedNumberTest(NumberTest):
940 example = [0, 1, 17, 23, 42, 0xff]
941 smallerexample = [0, 1, 17, 23, 42, 0xfe]
942 biggerexample = [0, 1, 17, 23, 43, 0xff]
943 outside = 0xaa
944
945 def test_overflow(self):
946 a = array.array(self.typecode)
947 lower = 0
948 upper = long(pow(2, a.itemsize * 8)) - 1L
949 self.check_overflow(lower, upper)
Fred Drake004d5e62000-10-23 17:22:08 +0000950
951
Walter Dörwald7fd94242003-05-18 00:47:47 +0000952class ByteTest(SignedNumberTest):
953 typecode = 'b'
954 minitemsize = 1
955tests.append(ByteTest)
Fred Drake004d5e62000-10-23 17:22:08 +0000956
Walter Dörwald7fd94242003-05-18 00:47:47 +0000957class UnsignedByteTest(UnsignedNumberTest):
958 typecode = 'B'
959 minitemsize = 1
960tests.append(UnsignedByteTest)
961
962class ShortTest(SignedNumberTest):
963 typecode = 'h'
964 minitemsize = 2
965tests.append(ShortTest)
966
967class UnsignedShortTest(UnsignedNumberTest):
968 typecode = 'H'
969 minitemsize = 2
970tests.append(UnsignedShortTest)
971
972class IntTest(SignedNumberTest):
973 typecode = 'i'
974 minitemsize = 2
975tests.append(IntTest)
976
977class UnsignedIntTest(UnsignedNumberTest):
978 typecode = 'I'
979 minitemsize = 2
980tests.append(UnsignedIntTest)
981
982class LongTest(SignedNumberTest):
983 typecode = 'l'
984 minitemsize = 4
985tests.append(LongTest)
986
987class UnsignedLongTest(UnsignedNumberTest):
988 typecode = 'L'
989 minitemsize = 4
990tests.append(UnsignedLongTest)
991
992class FPTest(NumberTest):
993 example = [-42.0, 0, 42, 1e5, -1e10]
994 smallerexample = [-42.0, 0, 42, 1e5, -2e10]
995 biggerexample = [-42.0, 0, 42, 1e5, 1e10]
996 outside = 23
997
998 def assertEntryEqual(self, entry1, entry2):
999 self.assertAlmostEqual(entry1, entry2)
1000
Walter Dörwaldcf99b0a2003-05-22 13:15:31 +00001001 def test_byteswap(self):
1002 a = array.array(self.typecode, self.example)
1003 self.assertRaises(TypeError, a.byteswap, 42)
1004 if a.itemsize in (1, 2, 4, 8):
1005 b = array.array(self.typecode, self.example)
1006 b.byteswap()
1007 if a.itemsize==1:
1008 self.assertEqual(a, b)
1009 else:
1010 # On alphas treating the byte swapped bit patters as
1011 # floats/doubles results in floating point exceptions
1012 # => compare the 8bit string values instead
1013 self.assertNotEqual(a.tostring(), b.tostring())
1014 b.byteswap()
1015 self.assertEqual(a, b)
1016
Neal Norwitz35c6cd02003-05-22 13:29:15 +00001017class FloatTest(FPTest):
1018 typecode = 'f'
1019 minitemsize = 4
Walter Dörwald7fd94242003-05-18 00:47:47 +00001020tests.append(FloatTest)
1021
1022class DoubleTest(FPTest):
1023 typecode = 'd'
1024 minitemsize = 8
Gregory P. Smith9d534572008-06-11 07:41:16 +00001025
1026 def test_alloc_overflow(self):
Andrew MacIntyrebf244012008-10-01 03:25:25 +00001027 from sys import maxsize
Gregory P. Smith9d534572008-06-11 07:41:16 +00001028 a = array.array('d', [-1]*65536)
1029 try:
Andrew MacIntyrebf244012008-10-01 03:25:25 +00001030 a *= maxsize//65536 + 1
Gregory P. Smith9d534572008-06-11 07:41:16 +00001031 except MemoryError:
1032 pass
1033 else:
Andrew MacIntyrebf244012008-10-01 03:25:25 +00001034 self.fail("Array of size > maxsize created - MemoryError expected")
Gregory P. Smith9d534572008-06-11 07:41:16 +00001035 b = array.array('d', [ 2.71828183, 3.14159265, -1])
1036 try:
Andrew MacIntyrebf244012008-10-01 03:25:25 +00001037 b * (maxsize//3 + 1)
Gregory P. Smith9d534572008-06-11 07:41:16 +00001038 except MemoryError:
1039 pass
1040 else:
Andrew MacIntyrebf244012008-10-01 03:25:25 +00001041 self.fail("Array of size > maxsize created - MemoryError expected")
Gregory P. Smith9d534572008-06-11 07:41:16 +00001042
Walter Dörwald7fd94242003-05-18 00:47:47 +00001043tests.append(DoubleTest)
1044
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +00001045def test_main(verbose=None):
1046 import sys
1047
Walter Dörwald7fd94242003-05-18 00:47:47 +00001048 test_support.run_unittest(*tests)
1049
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +00001050 # verify reference counting
1051 if verbose and hasattr(sys, "gettotalrefcount"):
1052 import gc
1053 counts = [None] * 5
1054 for i in xrange(len(counts)):
1055 test_support.run_unittest(*tests)
1056 gc.collect()
1057 counts[i] = sys.gettotalrefcount()
1058 print counts
1059
1060if __name__ == "__main__":
1061 test_main(verbose=True)