blob: 9b289abd089aa306683155641c1bcfdc2949a4d3 [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()
Ezio Melottib0f5adc2010-01-24 16:58:36 +000066 self.assertIsInstance(bi, tuple)
Walter Dörwald7fd94242003-05-18 00:47:47 +000067 self.assertEqual(len(bi), 2)
Ezio Melottib0f5adc2010-01-24 16:58:36 +000068 self.assertIsInstance(bi[0], (int, long))
69 self.assertIsInstance(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
Frank Wierzbickidf756772009-08-16 20:22:51 +0000191 def test_filewrite(self):
192 a = array.array(self.typecode, 2*self.example)
193 f = open(test_support.TESTFN, 'wb')
194 try:
195 f.write(a)
196 f.close()
197 b = array.array(self.typecode)
198 f = open(test_support.TESTFN, 'rb')
199 b.fromfile(f, len(self.example))
200 self.assertEqual(b, array.array(self.typecode, self.example))
201 self.assertNotEqual(a, b)
202 b.fromfile(f, len(self.example))
203 self.assertEqual(a, b)
204 f.close()
205 finally:
206 if not f.closed:
207 f.close()
208 test_support.unlink(test_support.TESTFN)
209
Walter Dörwald7fd94242003-05-18 00:47:47 +0000210 def test_tofromlist(self):
211 a = array.array(self.typecode, 2*self.example)
212 b = array.array(self.typecode)
213 self.assertRaises(TypeError, a.tolist, 42)
214 self.assertRaises(TypeError, b.fromlist)
215 self.assertRaises(TypeError, b.fromlist, 42)
216 self.assertRaises(TypeError, b.fromlist, [None])
217 b.fromlist(a.tolist())
218 self.assertEqual(a, b)
Fred Drake78334472000-06-28 17:50:51 +0000219
Walter Dörwald7fd94242003-05-18 00:47:47 +0000220 def test_tofromstring(self):
221 a = array.array(self.typecode, 2*self.example)
222 b = array.array(self.typecode)
223 self.assertRaises(TypeError, a.tostring, 42)
224 self.assertRaises(TypeError, b.fromstring)
225 self.assertRaises(TypeError, b.fromstring, 42)
226 b.fromstring(a.tostring())
227 self.assertEqual(a, b)
228 if a.itemsize>1:
229 self.assertRaises(ValueError, b.fromstring, "x")
Fred Drake78334472000-06-28 17:50:51 +0000230
Walter Dörwald7fd94242003-05-18 00:47:47 +0000231 def test_repr(self):
232 a = array.array(self.typecode, 2*self.example)
233 self.assertEqual(a, eval(repr(a), {"array": array.array}))
Fred Drake78334472000-06-28 17:50:51 +0000234
Walter Dörwald7fd94242003-05-18 00:47:47 +0000235 a = array.array(self.typecode)
236 self.assertEqual(repr(a), "array('%s')" % self.typecode)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000237
Walter Dörwald7fd94242003-05-18 00:47:47 +0000238 def test_str(self):
239 a = array.array(self.typecode, 2*self.example)
240 str(a)
Roger E. Masse8db1b071996-12-09 20:09:16 +0000241
Walter Dörwald7fd94242003-05-18 00:47:47 +0000242 def test_cmp(self):
243 a = array.array(self.typecode, self.example)
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000244 self.assertTrue((a == 42) is False)
245 self.assertTrue((a != 42) is True)
Tim Peterscc78e472000-11-14 21:36:07 +0000246
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000247 self.assertTrue((a == a) is True)
248 self.assertTrue((a != a) is False)
249 self.assertTrue((a < a) is False)
250 self.assertTrue((a <= a) is True)
251 self.assertTrue((a > a) is False)
252 self.assertTrue((a >= a) is True)
Tim Peterscc78e472000-11-14 21:36:07 +0000253
Neal Norwitzc72f5012006-03-17 08:55:46 +0000254 al = array.array(self.typecode, self.smallerexample)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000255 ab = array.array(self.typecode, self.biggerexample)
Guido van Rossum7f1d3aa1998-07-16 15:31:43 +0000256
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000257 self.assertTrue((a == 2*a) is False)
258 self.assertTrue((a != 2*a) is True)
259 self.assertTrue((a < 2*a) is True)
260 self.assertTrue((a <= 2*a) is True)
261 self.assertTrue((a > 2*a) is False)
262 self.assertTrue((a >= 2*a) is False)
Martin v. Löwis99866332002-03-01 10:27:01 +0000263
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000264 self.assertTrue((a == al) is False)
265 self.assertTrue((a != al) is True)
266 self.assertTrue((a < al) is False)
267 self.assertTrue((a <= al) is False)
268 self.assertTrue((a > al) is True)
269 self.assertTrue((a >= al) is True)
Martin v. Löwis99866332002-03-01 10:27:01 +0000270
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000271 self.assertTrue((a == ab) is False)
272 self.assertTrue((a != ab) is True)
273 self.assertTrue((a < ab) is True)
274 self.assertTrue((a <= ab) is True)
275 self.assertTrue((a > ab) is False)
276 self.assertTrue((a >= ab) is False)
Martin v. Löwis99866332002-03-01 10:27:01 +0000277
Walter Dörwald7fd94242003-05-18 00:47:47 +0000278 def test_add(self):
279 a = array.array(self.typecode, self.example) \
280 + array.array(self.typecode, self.example[::-1])
281 self.assertEqual(
282 a,
283 array.array(self.typecode, self.example + self.example[::-1])
284 )
Martin v. Löwis99866332002-03-01 10:27:01 +0000285
Walter Dörwald7fd94242003-05-18 00:47:47 +0000286 b = array.array(self.badtypecode())
287 self.assertRaises(TypeError, a.__add__, b)
288
289 self.assertRaises(TypeError, a.__add__, "bad")
290
291 def test_iadd(self):
292 a = array.array(self.typecode, self.example[::-1])
293 b = a
294 a += array.array(self.typecode, 2*self.example)
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000295 self.assertTrue(a is b)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000296 self.assertEqual(
297 a,
298 array.array(self.typecode, self.example[::-1]+2*self.example)
299 )
Alexandre Vassalotti5b1abb72009-07-05 06:33:41 +0000300 a = array.array(self.typecode, self.example)
301 a += a
302 self.assertEqual(
303 a,
304 array.array(self.typecode, self.example + self.example)
305 )
Walter Dörwald7fd94242003-05-18 00:47:47 +0000306
307 b = array.array(self.badtypecode())
308 self.assertRaises(TypeError, a.__add__, b)
309
310 self.assertRaises(TypeError, a.__iadd__, "bad")
311
312 def test_mul(self):
313 a = 5*array.array(self.typecode, self.example)
314 self.assertEqual(
315 a,
316 array.array(self.typecode, 5*self.example)
317 )
318
319 a = array.array(self.typecode, self.example)*5
320 self.assertEqual(
321 a,
322 array.array(self.typecode, self.example*5)
323 )
324
325 a = 0*array.array(self.typecode, self.example)
326 self.assertEqual(
327 a,
328 array.array(self.typecode)
329 )
330
331 a = (-1)*array.array(self.typecode, self.example)
332 self.assertEqual(
333 a,
334 array.array(self.typecode)
335 )
336
337 self.assertRaises(TypeError, a.__mul__, "bad")
338
339 def test_imul(self):
340 a = array.array(self.typecode, self.example)
341 b = a
342
343 a *= 5
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000344 self.assertTrue(a is b)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000345 self.assertEqual(
346 a,
347 array.array(self.typecode, 5*self.example)
348 )
349
350 a *= 0
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000351 self.assertTrue(a is b)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000352 self.assertEqual(a, array.array(self.typecode))
353
354 a *= 1000
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000355 self.assertTrue(a is b)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000356 self.assertEqual(a, array.array(self.typecode))
357
358 a *= -1
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000359 self.assertTrue(a is b)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000360 self.assertEqual(a, array.array(self.typecode))
361
362 a = array.array(self.typecode, self.example)
363 a *= -1
364 self.assertEqual(a, array.array(self.typecode))
365
366 self.assertRaises(TypeError, a.__imul__, "bad")
367
368 def test_getitem(self):
369 a = array.array(self.typecode, self.example)
370 self.assertEntryEqual(a[0], self.example[0])
371 self.assertEntryEqual(a[0L], self.example[0])
372 self.assertEntryEqual(a[-1], self.example[-1])
373 self.assertEntryEqual(a[-1L], self.example[-1])
374 self.assertEntryEqual(a[len(self.example)-1], self.example[-1])
375 self.assertEntryEqual(a[-len(self.example)], self.example[0])
376 self.assertRaises(TypeError, a.__getitem__)
377 self.assertRaises(IndexError, a.__getitem__, len(self.example))
378 self.assertRaises(IndexError, a.__getitem__, -len(self.example)-1)
379
380 def test_setitem(self):
381 a = array.array(self.typecode, self.example)
382 a[0] = a[-1]
383 self.assertEntryEqual(a[0], a[-1])
384
385 a = array.array(self.typecode, self.example)
386 a[0L] = a[-1]
387 self.assertEntryEqual(a[0], a[-1])
388
389 a = array.array(self.typecode, self.example)
390 a[-1] = a[0]
391 self.assertEntryEqual(a[0], a[-1])
392
393 a = array.array(self.typecode, self.example)
394 a[-1L] = a[0]
395 self.assertEntryEqual(a[0], a[-1])
396
397 a = array.array(self.typecode, self.example)
398 a[len(self.example)-1] = a[0]
399 self.assertEntryEqual(a[0], a[-1])
400
401 a = array.array(self.typecode, self.example)
402 a[-len(self.example)] = a[-1]
403 self.assertEntryEqual(a[0], a[-1])
404
405 self.assertRaises(TypeError, a.__setitem__)
406 self.assertRaises(TypeError, a.__setitem__, None)
407 self.assertRaises(TypeError, a.__setitem__, 0, None)
408 self.assertRaises(
409 IndexError,
410 a.__setitem__,
411 len(self.example), self.example[0]
412 )
413 self.assertRaises(
414 IndexError,
415 a.__setitem__,
416 -len(self.example)-1, self.example[0]
417 )
418
419 def test_delitem(self):
420 a = array.array(self.typecode, self.example)
421 del a[0]
422 self.assertEqual(
423 a,
424 array.array(self.typecode, self.example[1:])
425 )
426
427 a = array.array(self.typecode, self.example)
428 del a[-1]
429 self.assertEqual(
430 a,
431 array.array(self.typecode, self.example[:-1])
432 )
433
434 a = array.array(self.typecode, self.example)
435 del a[len(self.example)-1]
436 self.assertEqual(
437 a,
438 array.array(self.typecode, self.example[:-1])
439 )
440
441 a = array.array(self.typecode, self.example)
442 del a[-len(self.example)]
443 self.assertEqual(
444 a,
445 array.array(self.typecode, self.example[1:])
446 )
447
448 self.assertRaises(TypeError, a.__delitem__)
449 self.assertRaises(TypeError, a.__delitem__, None)
450 self.assertRaises(IndexError, a.__delitem__, len(self.example))
451 self.assertRaises(IndexError, a.__delitem__, -len(self.example)-1)
452
453 def test_getslice(self):
454 a = array.array(self.typecode, self.example)
455 self.assertEqual(a[:], a)
456
457 self.assertEqual(
458 a[1:],
459 array.array(self.typecode, self.example[1:])
460 )
461
462 self.assertEqual(
463 a[:1],
464 array.array(self.typecode, self.example[:1])
465 )
466
467 self.assertEqual(
468 a[:-1],
469 array.array(self.typecode, self.example[:-1])
470 )
471
472 self.assertEqual(
473 a[-1:],
474 array.array(self.typecode, self.example[-1:])
475 )
476
477 self.assertEqual(
478 a[-1:-1],
479 array.array(self.typecode)
480 )
481
482 self.assertEqual(
Walter Dörwald1083c242005-01-21 21:16:51 +0000483 a[2:1],
484 array.array(self.typecode)
485 )
486
487 self.assertEqual(
Walter Dörwald7fd94242003-05-18 00:47:47 +0000488 a[1000:],
489 array.array(self.typecode)
490 )
491 self.assertEqual(a[-1000:], a)
492 self.assertEqual(a[:1000], a)
493 self.assertEqual(
494 a[:-1000],
495 array.array(self.typecode)
496 )
497 self.assertEqual(a[-1000:1000], a)
498 self.assertEqual(
499 a[2000:1000],
500 array.array(self.typecode)
501 )
502
Thomas Wouters3ccec682007-08-28 15:28:19 +0000503 def test_extended_getslice(self):
504 # Test extended slicing by comparing with list slicing
505 # (Assumes list conversion works correctly, too)
506 a = array.array(self.typecode, self.example)
507 indices = (0, None, 1, 3, 19, 100, -1, -2, -31, -100)
508 for start in indices:
509 for stop in indices:
510 # Everything except the initial 0 (invalid step)
511 for step in indices[1:]:
512 self.assertEqual(list(a[start:stop:step]),
513 list(a)[start:stop:step])
514
Walter Dörwald7fd94242003-05-18 00:47:47 +0000515 def test_setslice(self):
516 a = array.array(self.typecode, self.example)
517 a[:1] = a
518 self.assertEqual(
519 a,
520 array.array(self.typecode, self.example + self.example[1:])
521 )
522
523 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000524 a[:-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000525 self.assertEqual(
526 a,
527 array.array(self.typecode, self.example + self.example[-1:])
528 )
529
530 a = array.array(self.typecode, self.example)
531 a[-1:] = a
532 self.assertEqual(
533 a,
534 array.array(self.typecode, self.example[:-1] + self.example)
535 )
536
537 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000538 a[1:] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000539 self.assertEqual(
540 a,
541 array.array(self.typecode, self.example[:1] + self.example)
542 )
543
544 a = array.array(self.typecode, self.example)
Fred Drake004d5e62000-10-23 17:22:08 +0000545 a[1:-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000546 self.assertEqual(
547 a,
548 array.array(
549 self.typecode,
550 self.example[:1] + self.example + self.example[-1:]
551 )
552 )
553
554 a = array.array(self.typecode, self.example)
555 a[1000:] = a
556 self.assertEqual(
557 a,
558 array.array(self.typecode, 2*self.example)
559 )
560
561 a = array.array(self.typecode, self.example)
562 a[-1000:] = a
563 self.assertEqual(
564 a,
565 array.array(self.typecode, self.example)
566 )
567
568 a = array.array(self.typecode, self.example)
569 a[:1000] = a
570 self.assertEqual(
571 a,
572 array.array(self.typecode, self.example)
573 )
574
575 a = array.array(self.typecode, self.example)
576 a[:-1000] = a
577 self.assertEqual(
578 a,
579 array.array(self.typecode, 2*self.example)
580 )
581
582 a = array.array(self.typecode, self.example)
583 a[1:0] = a
584 self.assertEqual(
585 a,
586 array.array(self.typecode, self.example[:1] + self.example + self.example[1:])
587 )
588
589 a = array.array(self.typecode, self.example)
590 a[2000:1000] = a
591 self.assertEqual(
592 a,
593 array.array(self.typecode, 2*self.example)
594 )
595
596 a = array.array(self.typecode, self.example)
597 self.assertRaises(TypeError, a.__setslice__, 0, 0, None)
Thomas Wouters3ccec682007-08-28 15:28:19 +0000598 self.assertRaises(TypeError, a.__setitem__, slice(0, 0), None)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000599 self.assertRaises(TypeError, a.__setitem__, slice(0, 1), None)
600
601 b = array.array(self.badtypecode())
602 self.assertRaises(TypeError, a.__setslice__, 0, 0, b)
Thomas Wouters3ccec682007-08-28 15:28:19 +0000603 self.assertRaises(TypeError, a.__setitem__, slice(0, 0), b)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000604 self.assertRaises(TypeError, a.__setitem__, slice(0, 1), b)
605
Thomas Wouters3ccec682007-08-28 15:28:19 +0000606 def test_extended_set_del_slice(self):
607 indices = (0, None, 1, 3, 19, 100, -1, -2, -31, -100)
608 for start in indices:
609 for stop in indices:
610 # Everything except the initial 0 (invalid step)
611 for step in indices[1:]:
612 a = array.array(self.typecode, self.example)
613 L = list(a)
614 # Make sure we have a slice of exactly the right length,
615 # but with (hopefully) different data.
616 data = L[start:stop:step]
617 data.reverse()
618 L[start:stop:step] = data
619 a[start:stop:step] = array.array(self.typecode, data)
620 self.assertEquals(a, array.array(self.typecode, L))
621
622 del L[start:stop:step]
623 del a[start:stop:step]
624 self.assertEquals(a, array.array(self.typecode, L))
625
Walter Dörwald7fd94242003-05-18 00:47:47 +0000626 def test_index(self):
627 example = 2*self.example
628 a = array.array(self.typecode, example)
629 self.assertRaises(TypeError, a.index)
630 for x in example:
631 self.assertEqual(a.index(x), example.index(x))
632 self.assertRaises(ValueError, a.index, None)
633 self.assertRaises(ValueError, a.index, self.outside)
634
635 def test_count(self):
636 example = 2*self.example
637 a = array.array(self.typecode, example)
638 self.assertRaises(TypeError, a.count)
639 for x in example:
640 self.assertEqual(a.count(x), example.count(x))
641 self.assertEqual(a.count(self.outside), 0)
642 self.assertEqual(a.count(None), 0)
643
644 def test_remove(self):
645 for x in self.example:
646 example = 2*self.example
647 a = array.array(self.typecode, example)
648 pos = example.index(x)
649 example2 = example[:pos] + example[pos+1:]
650 a.remove(x)
651 self.assertEqual(a, array.array(self.typecode, example2))
652
653 a = array.array(self.typecode, self.example)
654 self.assertRaises(ValueError, a.remove, self.outside)
655
656 self.assertRaises(ValueError, a.remove, None)
657
658 def test_pop(self):
659 a = array.array(self.typecode)
660 self.assertRaises(IndexError, a.pop)
661
662 a = array.array(self.typecode, 2*self.example)
663 self.assertRaises(TypeError, a.pop, 42, 42)
664 self.assertRaises(TypeError, a.pop, None)
665 self.assertRaises(IndexError, a.pop, len(a))
666 self.assertRaises(IndexError, a.pop, -len(a)-1)
667
668 self.assertEntryEqual(a.pop(0), self.example[0])
669 self.assertEqual(
670 a,
671 array.array(self.typecode, self.example[1:]+self.example)
672 )
673 self.assertEntryEqual(a.pop(1), self.example[2])
674 self.assertEqual(
675 a,
676 array.array(self.typecode, self.example[1:2]+self.example[3:]+self.example)
677 )
678 self.assertEntryEqual(a.pop(0), self.example[1])
679 self.assertEntryEqual(a.pop(), self.example[-1])
680 self.assertEqual(
681 a,
682 array.array(self.typecode, self.example[3:]+self.example[:-1])
683 )
684
685 def test_reverse(self):
686 a = array.array(self.typecode, self.example)
687 self.assertRaises(TypeError, a.reverse, 42)
Fred Drake004d5e62000-10-23 17:22:08 +0000688 a.reverse()
Walter Dörwald7fd94242003-05-18 00:47:47 +0000689 self.assertEqual(
690 a,
691 array.array(self.typecode, self.example[::-1])
692 )
693
694 def test_extend(self):
695 a = array.array(self.typecode, self.example)
696 self.assertRaises(TypeError, a.extend)
697 a.extend(array.array(self.typecode, self.example[::-1]))
698 self.assertEqual(
699 a,
700 array.array(self.typecode, self.example+self.example[::-1])
701 )
702
Alexandre Vassalotti5b1abb72009-07-05 06:33:41 +0000703 a = array.array(self.typecode, self.example)
704 a.extend(a)
705 self.assertEqual(
706 a,
707 array.array(self.typecode, self.example+self.example)
708 )
709
Walter Dörwald7fd94242003-05-18 00:47:47 +0000710 b = array.array(self.badtypecode())
711 self.assertRaises(TypeError, a.extend, b)
712
Raymond Hettinger49f9bd12004-03-14 05:43:59 +0000713 a = array.array(self.typecode, self.example)
714 a.extend(self.example[::-1])
715 self.assertEqual(
716 a,
717 array.array(self.typecode, self.example+self.example[::-1])
718 )
719
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +0000720 def test_constructor_with_iterable_argument(self):
721 a = array.array(self.typecode, iter(self.example))
722 b = array.array(self.typecode, self.example)
723 self.assertEqual(a, b)
724
725 # non-iterable argument
726 self.assertRaises(TypeError, array.array, self.typecode, 10)
727
728 # pass through errors raised in __iter__
729 class A:
730 def __iter__(self):
731 raise UnicodeError
732 self.assertRaises(UnicodeError, array.array, self.typecode, A())
733
734 # pass through errors raised in next()
735 def B():
736 raise UnicodeError
737 yield None
738 self.assertRaises(UnicodeError, array.array, self.typecode, B())
739
Walter Dörwald7fd94242003-05-18 00:47:47 +0000740 def test_coveritertraverse(self):
741 try:
742 import gc
743 except ImportError:
744 return
745 a = array.array(self.typecode)
746 l = [iter(a)]
747 l.append(l)
748 gc.collect()
749
750 def test_buffer(self):
751 a = array.array(self.typecode, self.example)
Senthil Kumarance8e33a2010-01-08 19:04:16 +0000752 b = buffer(a)
Walter Dörwald7fd94242003-05-18 00:47:47 +0000753 self.assertEqual(b[0], a.tostring()[0])
754
Raymond Hettingercb87bc82004-05-31 00:35:52 +0000755 def test_weakref(self):
756 s = array.array(self.typecode, self.example)
757 p = proxy(s)
758 self.assertEqual(p.tostring(), s.tostring())
759 s = None
760 self.assertRaises(ReferenceError, len, p)
761
Skip Montanarod5cf0b82003-08-03 23:02:10 +0000762 def test_bug_782369(self):
763 import sys
Skip Montanaroed9bf122003-08-03 23:30:40 +0000764 if hasattr(sys, "getrefcount"):
765 for i in range(10):
766 b = array.array('B', range(64))
767 rc = sys.getrefcount(10)
768 for i in range(10):
769 b = array.array('B', range(64))
770 self.assertEqual(rc, sys.getrefcount(10))
Skip Montanarod5cf0b82003-08-03 23:02:10 +0000771
Georg Brandlb84c1372007-01-21 10:28:43 +0000772 def test_subclass_with_kwargs(self):
773 # SF bug #1486663 -- this used to erroneously raise a TypeError
774 ArraySubclassWithKwargs('b', newarg=1)
Raymond Hettingercb87bc82004-05-31 00:35:52 +0000775
776
Walter Dörwald7fd94242003-05-18 00:47:47 +0000777class StringTest(BaseTest):
778
779 def test_setitem(self):
780 super(StringTest, self).test_setitem()
781 a = array.array(self.typecode, self.example)
782 self.assertRaises(TypeError, a.__setitem__, 0, self.example[:2])
783
784class CharacterTest(StringTest):
785 typecode = 'c'
786 example = '\x01azAZ\x00\xfe'
787 smallerexample = '\x01azAY\x00\xfe'
788 biggerexample = '\x01azAZ\x00\xff'
789 outside = '\x33'
790 minitemsize = 1
791
792 def test_subbclassing(self):
793 class EditableString(array.array):
794 def __new__(cls, s, *args, **kwargs):
795 return array.array.__new__(cls, 'c', s)
796
797 def __init__(self, s, color='blue'):
Walter Dörwald7fd94242003-05-18 00:47:47 +0000798 self.color = color
799
800 def strip(self):
801 self[:] = array.array('c', self.tostring().strip())
802
803 def __repr__(self):
804 return 'EditableString(%r)' % self.tostring()
805
806 s = EditableString("\ttest\r\n")
807 s.strip()
808 self.assertEqual(s.tostring(), "test")
809
810 self.assertEqual(s.color, "blue")
811 s.color = "red"
812 self.assertEqual(s.color, "red")
813 self.assertEqual(s.__dict__.keys(), ["color"])
814
815 def test_nounicode(self):
816 a = array.array(self.typecode, self.example)
817 self.assertRaises(ValueError, a.fromunicode, unicode(''))
818 self.assertRaises(ValueError, a.tounicode)
819
820tests.append(CharacterTest)
821
822if test_support.have_unicode:
823 class UnicodeTest(StringTest):
824 typecode = 'u'
825 example = unicode(r'\x01\u263a\x00\ufeff', 'unicode-escape')
826 smallerexample = unicode(r'\x01\u263a\x00\ufefe', 'unicode-escape')
827 biggerexample = unicode(r'\x01\u263a\x01\ufeff', 'unicode-escape')
828 outside = unicode('\x33')
829 minitemsize = 2
830
831 def test_unicode(self):
832 self.assertRaises(TypeError, array.array, 'b', unicode('foo', 'ascii'))
833
834 a = array.array('u', unicode(r'\xa0\xc2\u1234', 'unicode-escape'))
835 a.fromunicode(unicode(' ', 'ascii'))
836 a.fromunicode(unicode('', 'ascii'))
837 a.fromunicode(unicode('', 'ascii'))
838 a.fromunicode(unicode(r'\x11abc\xff\u1234', 'unicode-escape'))
839 s = a.tounicode()
840 self.assertEqual(
841 s,
842 unicode(r'\xa0\xc2\u1234 \x11abc\xff\u1234', 'unicode-escape')
843 )
844
845 s = unicode(r'\x00="\'a\\b\x80\xff\u0000\u0001\u1234', 'unicode-escape')
846 a = array.array('u', s)
847 self.assertEqual(
848 repr(a),
849 r"""array('u', u'\x00="\'a\\b\x80\xff\x00\x01\u1234')"""
850 )
851
852 self.assertRaises(TypeError, a.fromunicode)
853
854 tests.append(UnicodeTest)
855
856class NumberTest(BaseTest):
857
858 def test_extslice(self):
859 a = array.array(self.typecode, range(5))
860 self.assertEqual(a[::], a)
861 self.assertEqual(a[::2], array.array(self.typecode, [0,2,4]))
862 self.assertEqual(a[1::2], array.array(self.typecode, [1,3]))
863 self.assertEqual(a[::-1], array.array(self.typecode, [4,3,2,1,0]))
864 self.assertEqual(a[::-2], array.array(self.typecode, [4,2,0]))
865 self.assertEqual(a[3::-2], array.array(self.typecode, [3,1]))
866 self.assertEqual(a[-100:100:], a)
867 self.assertEqual(a[100:-100:-1], a[::-1])
868 self.assertEqual(a[-100L:100L:2L], array.array(self.typecode, [0,2,4]))
869 self.assertEqual(a[1000:2000:2], array.array(self.typecode, []))
870 self.assertEqual(a[-1000:-2000:-2], array.array(self.typecode, []))
871
872 def test_delslice(self):
873 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000874 del a[::2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000875 self.assertEqual(a, array.array(self.typecode, [1,3]))
876 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000877 del a[1::2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000878 self.assertEqual(a, array.array(self.typecode, [0,2,4]))
879 a = array.array(self.typecode, range(5))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000880 del a[1::-2]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000881 self.assertEqual(a, array.array(self.typecode, [0,2,3,4]))
882 a = array.array(self.typecode, range(10))
Michael W. Hudson56796f62002-07-29 14:35:04 +0000883 del a[::1000]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000884 self.assertEqual(a, array.array(self.typecode, [1,2,3,4,5,6,7,8,9]))
Mark Dickinson36ecd672010-01-29 17:11:39 +0000885 # test issue7788
886 a = array.array(self.typecode, range(10))
887 del a[9::1<<333]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000888
889 def test_assignment(self):
890 a = array.array(self.typecode, range(10))
891 a[::2] = array.array(self.typecode, [42]*5)
892 self.assertEqual(a, array.array(self.typecode, [42, 1, 42, 3, 42, 5, 42, 7, 42, 9]))
893 a = array.array(self.typecode, range(10))
894 a[::-4] = array.array(self.typecode, [10]*3)
895 self.assertEqual(a, array.array(self.typecode, [0, 10, 2, 3, 4, 10, 6, 7, 8 ,10]))
896 a = array.array(self.typecode, range(4))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000897 a[::-1] = a
Walter Dörwald7fd94242003-05-18 00:47:47 +0000898 self.assertEqual(a, array.array(self.typecode, [3, 2, 1, 0]))
899 a = array.array(self.typecode, range(10))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000900 b = a[:]
901 c = a[:]
Walter Dörwald7fd94242003-05-18 00:47:47 +0000902 ins = array.array(self.typecode, range(2))
Michael W. Hudson9c14bad2002-06-19 15:44:15 +0000903 a[2:3] = ins
904 b[slice(2,3)] = ins
905 c[2:3:] = ins
Fred Drake004d5e62000-10-23 17:22:08 +0000906
Walter Dörwald7fd94242003-05-18 00:47:47 +0000907 def test_iterationcontains(self):
908 a = array.array(self.typecode, range(10))
909 self.assertEqual(list(a), range(10))
910 b = array.array(self.typecode, [20])
911 self.assertEqual(a[-1] in a, True)
912 self.assertEqual(b[0] not in a, True)
913
914 def check_overflow(self, lower, upper):
915 # method to be used by subclasses
916
917 # should not overflow assigning lower limit
918 a = array.array(self.typecode, [lower])
919 a[0] = lower
920 # should overflow assigning less than lower limit
921 self.assertRaises(OverflowError, array.array, self.typecode, [lower-1])
922 self.assertRaises(OverflowError, a.__setitem__, 0, lower-1)
923 # should not overflow assigning upper limit
924 a = array.array(self.typecode, [upper])
925 a[0] = upper
926 # should overflow assigning more than upper limit
927 self.assertRaises(OverflowError, array.array, self.typecode, [upper+1])
928 self.assertRaises(OverflowError, a.__setitem__, 0, upper+1)
929
930 def test_subclassing(self):
931 typecode = self.typecode
932 class ExaggeratingArray(array.array):
933 __slots__ = ['offset']
934
935 def __new__(cls, typecode, data, offset):
936 return array.array.__new__(cls, typecode, data)
937
938 def __init__(self, typecode, data, offset):
939 self.offset = offset
940
941 def __getitem__(self, i):
942 return array.array.__getitem__(self, i) + self.offset
943
944 a = ExaggeratingArray(self.typecode, [3, 6, 7, 11], 4)
945 self.assertEntryEqual(a[0], 7)
946
947 self.assertRaises(AttributeError, setattr, a, "color", "blue")
948
949class SignedNumberTest(NumberTest):
950 example = [-1, 0, 1, 42, 0x7f]
951 smallerexample = [-1, 0, 1, 42, 0x7e]
952 biggerexample = [-1, 0, 1, 43, 0x7f]
953 outside = 23
954
955 def test_overflow(self):
956 a = array.array(self.typecode)
957 lower = -1 * long(pow(2, a.itemsize * 8 - 1))
958 upper = long(pow(2, a.itemsize * 8 - 1)) - 1L
959 self.check_overflow(lower, upper)
960
961class UnsignedNumberTest(NumberTest):
962 example = [0, 1, 17, 23, 42, 0xff]
963 smallerexample = [0, 1, 17, 23, 42, 0xfe]
964 biggerexample = [0, 1, 17, 23, 43, 0xff]
965 outside = 0xaa
966
967 def test_overflow(self):
968 a = array.array(self.typecode)
969 lower = 0
970 upper = long(pow(2, a.itemsize * 8)) - 1L
971 self.check_overflow(lower, upper)
Fred Drake004d5e62000-10-23 17:22:08 +0000972
973
Walter Dörwald7fd94242003-05-18 00:47:47 +0000974class ByteTest(SignedNumberTest):
975 typecode = 'b'
976 minitemsize = 1
977tests.append(ByteTest)
Fred Drake004d5e62000-10-23 17:22:08 +0000978
Walter Dörwald7fd94242003-05-18 00:47:47 +0000979class UnsignedByteTest(UnsignedNumberTest):
980 typecode = 'B'
981 minitemsize = 1
982tests.append(UnsignedByteTest)
983
984class ShortTest(SignedNumberTest):
985 typecode = 'h'
986 minitemsize = 2
987tests.append(ShortTest)
988
989class UnsignedShortTest(UnsignedNumberTest):
990 typecode = 'H'
991 minitemsize = 2
992tests.append(UnsignedShortTest)
993
994class IntTest(SignedNumberTest):
995 typecode = 'i'
996 minitemsize = 2
997tests.append(IntTest)
998
999class UnsignedIntTest(UnsignedNumberTest):
1000 typecode = 'I'
1001 minitemsize = 2
1002tests.append(UnsignedIntTest)
1003
1004class LongTest(SignedNumberTest):
1005 typecode = 'l'
1006 minitemsize = 4
1007tests.append(LongTest)
1008
1009class UnsignedLongTest(UnsignedNumberTest):
1010 typecode = 'L'
1011 minitemsize = 4
1012tests.append(UnsignedLongTest)
1013
1014class FPTest(NumberTest):
1015 example = [-42.0, 0, 42, 1e5, -1e10]
1016 smallerexample = [-42.0, 0, 42, 1e5, -2e10]
1017 biggerexample = [-42.0, 0, 42, 1e5, 1e10]
1018 outside = 23
1019
1020 def assertEntryEqual(self, entry1, entry2):
1021 self.assertAlmostEqual(entry1, entry2)
1022
Walter Dörwaldcf99b0a2003-05-22 13:15:31 +00001023 def test_byteswap(self):
1024 a = array.array(self.typecode, self.example)
1025 self.assertRaises(TypeError, a.byteswap, 42)
1026 if a.itemsize in (1, 2, 4, 8):
1027 b = array.array(self.typecode, self.example)
1028 b.byteswap()
1029 if a.itemsize==1:
1030 self.assertEqual(a, b)
1031 else:
1032 # On alphas treating the byte swapped bit patters as
1033 # floats/doubles results in floating point exceptions
1034 # => compare the 8bit string values instead
1035 self.assertNotEqual(a.tostring(), b.tostring())
1036 b.byteswap()
1037 self.assertEqual(a, b)
1038
Neal Norwitz35c6cd02003-05-22 13:29:15 +00001039class FloatTest(FPTest):
1040 typecode = 'f'
1041 minitemsize = 4
Walter Dörwald7fd94242003-05-18 00:47:47 +00001042tests.append(FloatTest)
1043
1044class DoubleTest(FPTest):
1045 typecode = 'd'
1046 minitemsize = 8
Gregory P. Smith9d534572008-06-11 07:41:16 +00001047
1048 def test_alloc_overflow(self):
Andrew MacIntyrebf244012008-10-01 03:25:25 +00001049 from sys import maxsize
Gregory P. Smith9d534572008-06-11 07:41:16 +00001050 a = array.array('d', [-1]*65536)
1051 try:
Andrew MacIntyrebf244012008-10-01 03:25:25 +00001052 a *= maxsize//65536 + 1
Gregory P. Smith9d534572008-06-11 07:41:16 +00001053 except MemoryError:
1054 pass
1055 else:
Andrew MacIntyrebf244012008-10-01 03:25:25 +00001056 self.fail("Array of size > maxsize created - MemoryError expected")
Gregory P. Smith9d534572008-06-11 07:41:16 +00001057 b = array.array('d', [ 2.71828183, 3.14159265, -1])
1058 try:
Andrew MacIntyrebf244012008-10-01 03:25:25 +00001059 b * (maxsize//3 + 1)
Gregory P. Smith9d534572008-06-11 07:41:16 +00001060 except MemoryError:
1061 pass
1062 else:
Andrew MacIntyrebf244012008-10-01 03:25:25 +00001063 self.fail("Array of size > maxsize created - MemoryError expected")
Gregory P. Smith9d534572008-06-11 07:41:16 +00001064
Walter Dörwald7fd94242003-05-18 00:47:47 +00001065tests.append(DoubleTest)
1066
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +00001067def test_main(verbose=None):
1068 import sys
1069
Walter Dörwald7fd94242003-05-18 00:47:47 +00001070 test_support.run_unittest(*tests)
1071
Raymond Hettinger6ab78cd2004-08-29 07:50:43 +00001072 # verify reference counting
1073 if verbose and hasattr(sys, "gettotalrefcount"):
1074 import gc
1075 counts = [None] * 5
1076 for i in xrange(len(counts)):
1077 test_support.run_unittest(*tests)
1078 gc.collect()
1079 counts[i] = sys.gettotalrefcount()
1080 print counts
1081
1082if __name__ == "__main__":
1083 test_main(verbose=True)