blob: 09b497bab0a2fed5071653afffb13a11549d16a3 [file] [log] [blame]
Christian Heimes1a6387e2008-03-26 12:49:49 +00001"""Unit tests for the bytes and bytearray types.
2
3XXX This is a mess. Common tests should be moved to buffer_tests.py,
4which itself ought to be unified with string_tests.py (and the latter
5should be modernized).
6"""
7
8import os
9import re
10import sys
11import copy
12import pickle
13import tempfile
14import unittest
15import warnings
16import test.test_support
17import test.string_tests
18import test.buffer_tests
19
Georg Brandl3e483f62008-07-16 22:57:41 +000020class Indexable:
21 def __init__(self, value=0):
22 self.value = value
23 def __index__(self):
24 return self.value
25
Christian Heimes1a6387e2008-03-26 12:49:49 +000026
27class BaseBytesTest(unittest.TestCase):
28
29 def setUp(self):
30 self.warning_filters = warnings.filters[:]
31
32 def tearDown(self):
33 warnings.filters = self.warning_filters
34
35 def test_basics(self):
36 b = self.type2test()
37 self.assertEqual(type(b), self.type2test)
38 self.assertEqual(b.__class__, self.type2test)
39
40 def test_empty_sequence(self):
41 b = self.type2test()
42 self.assertEqual(len(b), 0)
43 self.assertRaises(IndexError, lambda: b[0])
44 self.assertRaises(IndexError, lambda: b[1])
45 self.assertRaises(IndexError, lambda: b[sys.maxint])
46 self.assertRaises(IndexError, lambda: b[sys.maxint+1])
47 self.assertRaises(IndexError, lambda: b[10**100])
48 self.assertRaises(IndexError, lambda: b[-1])
49 self.assertRaises(IndexError, lambda: b[-2])
50 self.assertRaises(IndexError, lambda: b[-sys.maxint])
51 self.assertRaises(IndexError, lambda: b[-sys.maxint-1])
52 self.assertRaises(IndexError, lambda: b[-sys.maxint-2])
53 self.assertRaises(IndexError, lambda: b[-10**100])
54
55 def test_from_list(self):
56 ints = list(range(256))
57 b = self.type2test(i for i in ints)
58 self.assertEqual(len(b), 256)
59 self.assertEqual(list(b), ints)
60
61 def test_from_index(self):
Georg Brandl3e483f62008-07-16 22:57:41 +000062 b = self.type2test([Indexable(), Indexable(1), Indexable(254),
63 Indexable(255)])
Christian Heimes1a6387e2008-03-26 12:49:49 +000064 self.assertEqual(list(b), [0, 1, 254, 255])
Georg Brandl3e483f62008-07-16 22:57:41 +000065 self.assertRaises(ValueError, bytearray, [Indexable(-1)])
66 self.assertRaises(ValueError, bytearray, [Indexable(256)])
Christian Heimes1a6387e2008-03-26 12:49:49 +000067
68 def test_from_ssize(self):
69 self.assertEqual(bytearray(0), b'')
70 self.assertEqual(bytearray(1), b'\x00')
71 self.assertEqual(bytearray(5), b'\x00\x00\x00\x00\x00')
72 self.assertRaises(ValueError, bytearray, -1)
73
74 self.assertEqual(bytearray('0', 'ascii'), b'0')
75 self.assertEqual(bytearray(b'0'), b'0')
76
77 def test_constructor_type_errors(self):
78 self.assertRaises(TypeError, self.type2test, 0.0)
79 class C:
80 pass
Georg Brandl0a34baf2008-07-16 23:18:51 +000081 # allowed in 2.6
82 #self.assertRaises(TypeError, self.type2test, ["0"])
Christian Heimes1a6387e2008-03-26 12:49:49 +000083 self.assertRaises(TypeError, self.type2test, [0.0])
84 self.assertRaises(TypeError, self.type2test, [None])
85 self.assertRaises(TypeError, self.type2test, [C()])
86
87 def test_constructor_value_errors(self):
88 self.assertRaises(ValueError, self.type2test, [-1])
89 self.assertRaises(ValueError, self.type2test, [-sys.maxint])
90 self.assertRaises(ValueError, self.type2test, [-sys.maxint-1])
91 self.assertRaises(ValueError, self.type2test, [-sys.maxint-2])
92 self.assertRaises(ValueError, self.type2test, [-10**100])
93 self.assertRaises(ValueError, self.type2test, [256])
94 self.assertRaises(ValueError, self.type2test, [257])
95 self.assertRaises(ValueError, self.type2test, [sys.maxint])
96 self.assertRaises(ValueError, self.type2test, [sys.maxint+1])
97 self.assertRaises(ValueError, self.type2test, [10**100])
98
99 def test_compare(self):
100 b1 = self.type2test([1, 2, 3])
101 b2 = self.type2test([1, 2, 3])
102 b3 = self.type2test([1, 3])
103
104 self.assertEqual(b1, b2)
105 self.failUnless(b2 != b3)
106 self.failUnless(b1 <= b2)
107 self.failUnless(b1 <= b3)
108 self.failUnless(b1 < b3)
109 self.failUnless(b1 >= b2)
110 self.failUnless(b3 >= b2)
111 self.failUnless(b3 > b2)
112
113 self.failIf(b1 != b2)
114 self.failIf(b2 == b3)
115 self.failIf(b1 > b2)
116 self.failIf(b1 > b3)
117 self.failIf(b1 >= b3)
118 self.failIf(b1 < b2)
119 self.failIf(b3 < b2)
120 self.failIf(b3 <= b2)
121
122 def test_compare_to_str(self):
123 warnings.simplefilter('ignore', BytesWarning)
124 # Byte comparisons with unicode should always fail!
125 # Test this for all expected byte orders and Unicode character sizes
126 self.assertEqual(self.type2test(b"\0a\0b\0c") == u"abc", False)
127 self.assertEqual(self.type2test(b"\0\0\0a\0\0\0b\0\0\0c") == u"abc", False)
128 self.assertEqual(self.type2test(b"a\0b\0c\0") == u"abc", False)
129 self.assertEqual(self.type2test(b"a\0\0\0b\0\0\0c\0\0\0") == u"abc", False)
130 self.assertEqual(self.type2test() == unicode(), False)
131 self.assertEqual(self.type2test() != unicode(), True)
132
133 def test_reversed(self):
134 input = list(map(ord, "Hello"))
135 b = self.type2test(input)
136 output = list(reversed(b))
137 input.reverse()
138 self.assertEqual(output, input)
139
140 def test_getslice(self):
141 def by(s):
142 return self.type2test(map(ord, s))
143 b = by("Hello, world")
144
145 self.assertEqual(b[:5], by("Hello"))
146 self.assertEqual(b[1:5], by("ello"))
147 self.assertEqual(b[5:7], by(", "))
148 self.assertEqual(b[7:], by("world"))
149 self.assertEqual(b[7:12], by("world"))
150 self.assertEqual(b[7:100], by("world"))
151
152 self.assertEqual(b[:-7], by("Hello"))
153 self.assertEqual(b[-11:-7], by("ello"))
154 self.assertEqual(b[-7:-5], by(", "))
155 self.assertEqual(b[-5:], by("world"))
156 self.assertEqual(b[-5:12], by("world"))
157 self.assertEqual(b[-5:100], by("world"))
158 self.assertEqual(b[-100:5], by("Hello"))
159
160 def test_extended_getslice(self):
161 # Test extended slicing by comparing with list slicing.
162 L = list(range(255))
163 b = self.type2test(L)
164 indices = (0, None, 1, 3, 19, 100, -1, -2, -31, -100)
165 for start in indices:
166 for stop in indices:
167 # Skip step 0 (invalid)
168 for step in indices[1:]:
169 self.assertEqual(b[start:stop:step], self.type2test(L[start:stop:step]))
170
171 def test_encoding(self):
172 sample = u"Hello world\n\u1234\u5678\u9abc\udef0"
173 for enc in ("utf8", "utf16"):
174 b = self.type2test(sample, enc)
175 self.assertEqual(b, self.type2test(sample.encode(enc)))
176 self.assertRaises(UnicodeEncodeError, self.type2test, sample, "latin1")
177 b = self.type2test(sample, "latin1", "ignore")
178 self.assertEqual(b, self.type2test(sample[:-4], "utf-8"))
179
180 def test_decode(self):
181 sample = u"Hello world\n\u1234\u5678\u9abc\def0\def0"
182 for enc in ("utf8", "utf16"):
183 b = self.type2test(sample, enc)
184 self.assertEqual(b.decode(enc), sample)
185 sample = u"Hello world\n\x80\x81\xfe\xff"
186 b = self.type2test(sample, "latin1")
187 self.assertRaises(UnicodeDecodeError, b.decode, "utf8")
188 self.assertEqual(b.decode("utf8", "ignore"), "Hello world\n")
189
190 def test_from_int(self):
191 b = self.type2test(0)
192 self.assertEqual(b, self.type2test())
193 b = self.type2test(10)
194 self.assertEqual(b, self.type2test([0]*10))
195 b = self.type2test(10000)
196 self.assertEqual(b, self.type2test([0]*10000))
197
198 def test_concat(self):
199 b1 = self.type2test(b"abc")
200 b2 = self.type2test(b"def")
201 self.assertEqual(b1 + b2, b"abcdef")
202 self.assertEqual(b1 + bytes(b"def"), b"abcdef")
203 self.assertEqual(bytes(b"def") + b1, b"defabc")
204 self.assertRaises(TypeError, lambda: b1 + u"def")
205 self.assertRaises(TypeError, lambda: u"abc" + b2)
206
207 def test_repeat(self):
208 for b in b"abc", self.type2test(b"abc"):
209 self.assertEqual(b * 3, b"abcabcabc")
210 self.assertEqual(b * 0, b"")
211 self.assertEqual(b * -1, b"")
212 self.assertRaises(TypeError, lambda: b * 3.14)
213 self.assertRaises(TypeError, lambda: 3.14 * b)
214 # XXX Shouldn't bytes and bytearray agree on what to raise?
215 self.assertRaises((OverflowError, MemoryError),
Mark Hammond69ed5242008-08-23 00:59:14 +0000216 lambda: b * sys.maxsize)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000217
218 def test_repeat_1char(self):
219 self.assertEqual(self.type2test(b'x')*100, self.type2test([ord('x')]*100))
220
221 def test_contains(self):
222 b = self.type2test(b"abc")
223 self.failUnless(ord('a') in b)
224 self.failUnless(int(ord('a')) in b)
225 self.failIf(200 in b)
226 self.failIf(200 in b)
227 self.assertRaises(ValueError, lambda: 300 in b)
228 self.assertRaises(ValueError, lambda: -1 in b)
229 self.assertRaises(TypeError, lambda: None in b)
230 self.assertRaises(TypeError, lambda: float(ord('a')) in b)
231 self.assertRaises(TypeError, lambda: u"a" in b)
232 for f in bytes, bytearray:
233 self.failUnless(f(b"") in b)
234 self.failUnless(f(b"a") in b)
235 self.failUnless(f(b"b") in b)
236 self.failUnless(f(b"c") in b)
237 self.failUnless(f(b"ab") in b)
238 self.failUnless(f(b"bc") in b)
239 self.failUnless(f(b"abc") in b)
240 self.failIf(f(b"ac") in b)
241 self.failIf(f(b"d") in b)
242 self.failIf(f(b"dab") in b)
243 self.failIf(f(b"abd") in b)
244
245 def test_fromhex(self):
246 self.assertRaises(TypeError, self.type2test.fromhex)
247 self.assertRaises(TypeError, self.type2test.fromhex, 1)
248 self.assertEquals(self.type2test.fromhex(u''), self.type2test())
249 b = bytearray([0x1a, 0x2b, 0x30])
250 self.assertEquals(self.type2test.fromhex(u'1a2B30'), b)
251 self.assertEquals(self.type2test.fromhex(u' 1A 2B 30 '), b)
252 self.assertEquals(self.type2test.fromhex(u'0000'), b'\0\0')
Christian Heimes1a6387e2008-03-26 12:49:49 +0000253 self.assertRaises(ValueError, self.type2test.fromhex, u'a')
254 self.assertRaises(ValueError, self.type2test.fromhex, u'rt')
255 self.assertRaises(ValueError, self.type2test.fromhex, u'1a b cd')
256 self.assertRaises(ValueError, self.type2test.fromhex, u'\x00')
257 self.assertRaises(ValueError, self.type2test.fromhex, u'12 \x00 34')
258
259 def test_join(self):
260 self.assertEqual(self.type2test(b"").join([]), b"")
261 self.assertEqual(self.type2test(b"").join([b""]), b"")
262 for lst in [[b"abc"], [b"a", b"bc"], [b"ab", b"c"], [b"a", b"b", b"c"]]:
263 lst = list(map(self.type2test, lst))
264 self.assertEqual(self.type2test(b"").join(lst), b"abc")
265 self.assertEqual(self.type2test(b"").join(tuple(lst)), b"abc")
266 self.assertEqual(self.type2test(b"").join(iter(lst)), b"abc")
267 self.assertEqual(self.type2test(b".").join([b"ab", b"cd"]), b"ab.cd")
268 # XXX more...
269
270 def test_index(self):
271 b = self.type2test(b'parrot')
272 self.assertEqual(b.index('p'), 0)
273 self.assertEqual(b.index('rr'), 2)
274 self.assertEqual(b.index('t'), 5)
275 self.assertRaises(ValueError, lambda: b.index('w'))
276
277 def test_count(self):
278 b = self.type2test(b'mississippi')
279 self.assertEqual(b.count(b'i'), 4)
280 self.assertEqual(b.count(b'ss'), 2)
281 self.assertEqual(b.count(b'w'), 0)
282
283 def test_startswith(self):
284 b = self.type2test(b'hello')
285 self.assertFalse(self.type2test().startswith(b"anything"))
286 self.assertTrue(b.startswith(b"hello"))
287 self.assertTrue(b.startswith(b"hel"))
288 self.assertTrue(b.startswith(b"h"))
289 self.assertFalse(b.startswith(b"hellow"))
290 self.assertFalse(b.startswith(b"ha"))
291
292 def test_endswith(self):
293 b = self.type2test(b'hello')
294 self.assertFalse(bytearray().endswith(b"anything"))
295 self.assertTrue(b.endswith(b"hello"))
296 self.assertTrue(b.endswith(b"llo"))
297 self.assertTrue(b.endswith(b"o"))
298 self.assertFalse(b.endswith(b"whello"))
299 self.assertFalse(b.endswith(b"no"))
300
301 def test_find(self):
302 b = self.type2test(b'mississippi')
303 self.assertEqual(b.find(b'ss'), 2)
304 self.assertEqual(b.find(b'ss', 3), 5)
305 self.assertEqual(b.find(b'ss', 1, 7), 2)
306 self.assertEqual(b.find(b'ss', 1, 3), -1)
307 self.assertEqual(b.find(b'w'), -1)
308 self.assertEqual(b.find(b'mississippian'), -1)
309
310 def test_rfind(self):
311 b = self.type2test(b'mississippi')
312 self.assertEqual(b.rfind(b'ss'), 5)
313 self.assertEqual(b.rfind(b'ss', 3), 5)
314 self.assertEqual(b.rfind(b'ss', 0, 6), 2)
315 self.assertEqual(b.rfind(b'w'), -1)
316 self.assertEqual(b.rfind(b'mississippian'), -1)
317
318 def test_index(self):
319 b = self.type2test(b'world')
320 self.assertEqual(b.index(b'w'), 0)
321 self.assertEqual(b.index(b'orl'), 1)
322 self.assertRaises(ValueError, b.index, b'worm')
323 self.assertRaises(ValueError, b.index, b'ldo')
324
325 def test_rindex(self):
326 # XXX could be more rigorous
327 b = self.type2test(b'world')
328 self.assertEqual(b.rindex(b'w'), 0)
329 self.assertEqual(b.rindex(b'orl'), 1)
330 self.assertRaises(ValueError, b.rindex, b'worm')
331 self.assertRaises(ValueError, b.rindex, b'ldo')
332
333 def test_replace(self):
334 b = self.type2test(b'mississippi')
335 self.assertEqual(b.replace(b'i', b'a'), b'massassappa')
336 self.assertEqual(b.replace(b'ss', b'x'), b'mixixippi')
337
338 def test_split(self):
339 b = self.type2test(b'mississippi')
340 self.assertEqual(b.split(b'i'), [b'm', b'ss', b'ss', b'pp', b''])
341 self.assertEqual(b.split(b'ss'), [b'mi', b'i', b'ippi'])
342 self.assertEqual(b.split(b'w'), [b])
343
344 def test_split_whitespace(self):
345 for b in (b' arf barf ', b'arf\tbarf', b'arf\nbarf', b'arf\rbarf',
346 b'arf\fbarf', b'arf\vbarf'):
347 b = self.type2test(b)
348 self.assertEqual(b.split(), [b'arf', b'barf'])
349 self.assertEqual(b.split(None), [b'arf', b'barf'])
350 self.assertEqual(b.split(None, 2), [b'arf', b'barf'])
351 for b in (b'a\x1Cb', b'a\x1Db', b'a\x1Eb', b'a\x1Fb'):
352 b = self.type2test(b)
353 self.assertEqual(b.split(), [b])
354 self.assertEqual(self.type2test(b' a bb c ').split(None, 0), [b'a bb c '])
355 self.assertEqual(self.type2test(b' a bb c ').split(None, 1), [b'a', b'bb c '])
356 self.assertEqual(self.type2test(b' a bb c ').split(None, 2), [b'a', b'bb', b'c '])
357 self.assertEqual(self.type2test(b' a bb c ').split(None, 3), [b'a', b'bb', b'c'])
358
359 def test_split_string_error(self):
360 self.assertRaises(TypeError, self.type2test(b'a b').split, u' ')
361
362 def test_rsplit(self):
363 b = self.type2test(b'mississippi')
364 self.assertEqual(b.rsplit(b'i'), [b'm', b'ss', b'ss', b'pp', b''])
365 self.assertEqual(b.rsplit(b'ss'), [b'mi', b'i', b'ippi'])
366 self.assertEqual(b.rsplit(b'w'), [b])
367
368 def test_rsplit_whitespace(self):
369 for b in (b' arf barf ', b'arf\tbarf', b'arf\nbarf', b'arf\rbarf',
370 b'arf\fbarf', b'arf\vbarf'):
371 b = self.type2test(b)
372 self.assertEqual(b.rsplit(), [b'arf', b'barf'])
373 self.assertEqual(b.rsplit(None), [b'arf', b'barf'])
374 self.assertEqual(b.rsplit(None, 2), [b'arf', b'barf'])
375 self.assertEqual(self.type2test(b' a bb c ').rsplit(None, 0), [b' a bb c'])
376 self.assertEqual(self.type2test(b' a bb c ').rsplit(None, 1), [b' a bb', b'c'])
377 self.assertEqual(self.type2test(b' a bb c ').rsplit(None, 2), [b' a', b'bb', b'c'])
378 self.assertEqual(self.type2test(b' a bb c ').rsplit(None, 3), [b'a', b'bb', b'c'])
379
380 def test_rsplit_string_error(self):
381 self.assertRaises(TypeError, self.type2test(b'a b').rsplit, u' ')
382
383 def test_rsplit_unicodewhitespace(self):
384 b = self.type2test(b"\x09\x0A\x0B\x0C\x0D\x1C\x1D\x1E\x1F")
385 self.assertEqual(b.split(), [b'\x1c\x1d\x1e\x1f'])
386 self.assertEqual(b.rsplit(), [b'\x1c\x1d\x1e\x1f'])
387
388 def test_partition(self):
389 b = self.type2test(b'mississippi')
390 self.assertEqual(b.partition(b'ss'), (b'mi', b'ss', b'issippi'))
391 self.assertEqual(b.rpartition(b'w'), (b'', b'', b'mississippi'))
392
393 def test_rpartition(self):
394 b = self.type2test(b'mississippi')
395 self.assertEqual(b.rpartition(b'ss'), (b'missi', b'ss', b'ippi'))
396 self.assertEqual(b.rpartition(b'i'), (b'mississipp', b'i', b''))
397
398 def test_pickling(self):
Hirokazu Yamamoto592c2752008-10-23 00:37:33 +0000399 for proto in range(pickle.HIGHEST_PROTOCOL + 1):
Christian Heimes1a6387e2008-03-26 12:49:49 +0000400 for b in b"", b"a", b"abc", b"\xffab\x80", b"\0\0\377\0\0":
401 b = self.type2test(b)
402 ps = pickle.dumps(b, proto)
403 q = pickle.loads(ps)
404 self.assertEqual(b, q)
405
406 def test_strip(self):
407 b = self.type2test(b'mississippi')
408 self.assertEqual(b.strip(b'i'), b'mississipp')
409 self.assertEqual(b.strip(b'm'), b'ississippi')
410 self.assertEqual(b.strip(b'pi'), b'mississ')
411 self.assertEqual(b.strip(b'im'), b'ssissipp')
412 self.assertEqual(b.strip(b'pim'), b'ssiss')
413 self.assertEqual(b.strip(b), b'')
414
415 def test_lstrip(self):
416 b = self.type2test(b'mississippi')
417 self.assertEqual(b.lstrip(b'i'), b'mississippi')
418 self.assertEqual(b.lstrip(b'm'), b'ississippi')
419 self.assertEqual(b.lstrip(b'pi'), b'mississippi')
420 self.assertEqual(b.lstrip(b'im'), b'ssissippi')
421 self.assertEqual(b.lstrip(b'pim'), b'ssissippi')
422
423 def test_rstrip(self):
424 b = self.type2test(b'mississippi')
425 self.assertEqual(b.rstrip(b'i'), b'mississipp')
426 self.assertEqual(b.rstrip(b'm'), b'mississippi')
427 self.assertEqual(b.rstrip(b'pi'), b'mississ')
428 self.assertEqual(b.rstrip(b'im'), b'mississipp')
429 self.assertEqual(b.rstrip(b'pim'), b'mississ')
430
431 def test_strip_whitespace(self):
432 b = self.type2test(b' \t\n\r\f\vabc \t\n\r\f\v')
433 self.assertEqual(b.strip(), b'abc')
434 self.assertEqual(b.lstrip(), b'abc \t\n\r\f\v')
435 self.assertEqual(b.rstrip(), b' \t\n\r\f\vabc')
436
437 def XXXtest_strip_bytearray(self):
438 # XXX memoryview not available
439 self.assertEqual(self.type2test(b'abc').strip(memoryview(b'ac')), b'b')
440 self.assertEqual(self.type2test(b'abc').lstrip(memoryview(b'ac')), b'bc')
441 self.assertEqual(self.type2test(b'abc').rstrip(memoryview(b'ac')), b'ab')
442
443 def test_strip_string_error(self):
444 self.assertRaises(TypeError, self.type2test(b'abc').strip, u'b')
445 self.assertRaises(TypeError, self.type2test(b'abc').lstrip, u'b')
446 self.assertRaises(TypeError, self.type2test(b'abc').rstrip, u'b')
447
448 def test_ord(self):
449 b = self.type2test(b'\0A\x7f\x80\xff')
450 self.assertEqual([ord(b[i:i+1]) for i in range(len(b))],
451 [0, 65, 127, 128, 255])
452
453
454class ByteArrayTest(BaseBytesTest):
455 type2test = bytearray
456
457 def test_nohash(self):
458 self.assertRaises(TypeError, hash, bytearray())
459
460 def test_bytearray_api(self):
461 short_sample = b"Hello world\n"
462 sample = short_sample + b"\0"*(20 - len(short_sample))
463 tfn = tempfile.mktemp()
464 try:
465 # Prepare
466 with open(tfn, "wb") as f:
467 f.write(short_sample)
468 # Test readinto
469 with open(tfn, "rb") as f:
470 b = bytearray(20)
471 n = f.readinto(b)
472 self.assertEqual(n, len(short_sample))
473 # Python 2.x
474 b_sample = (ord(s) for s in sample)
475 self.assertEqual(list(b), list(b_sample))
476 # Test writing in binary mode
477 with open(tfn, "wb") as f:
478 f.write(b)
479 with open(tfn, "rb") as f:
480 self.assertEqual(f.read(), sample)
481 # Text mode is ambiguous; don't test
482 finally:
483 try:
484 os.remove(tfn)
485 except os.error:
486 pass
487
488 def test_reverse(self):
489 b = bytearray(b'hello')
490 self.assertEqual(b.reverse(), None)
491 self.assertEqual(b, b'olleh')
492 b = bytearray(b'hello1') # test even number of items
493 b.reverse()
494 self.assertEqual(b, b'1olleh')
495 b = bytearray()
496 b.reverse()
497 self.assertFalse(b)
498
499 def test_regexps(self):
500 def by(s):
501 return bytearray(map(ord, s))
502 b = by("Hello, world")
503 self.assertEqual(re.findall(r"\w+", b), [by("Hello"), by("world")])
504
505 def test_setitem(self):
506 b = bytearray([1, 2, 3])
507 b[1] = 100
508 self.assertEqual(b, bytearray([1, 100, 3]))
509 b[-1] = 200
510 self.assertEqual(b, bytearray([1, 100, 200]))
Georg Brandl3e483f62008-07-16 22:57:41 +0000511 b[0] = Indexable(10)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000512 self.assertEqual(b, bytearray([10, 100, 200]))
513 try:
514 b[3] = 0
515 self.fail("Didn't raise IndexError")
516 except IndexError:
517 pass
518 try:
519 b[-10] = 0
520 self.fail("Didn't raise IndexError")
521 except IndexError:
522 pass
523 try:
524 b[0] = 256
525 self.fail("Didn't raise ValueError")
526 except ValueError:
527 pass
528 try:
Georg Brandl3e483f62008-07-16 22:57:41 +0000529 b[0] = Indexable(-1)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000530 self.fail("Didn't raise ValueError")
531 except ValueError:
532 pass
533 try:
534 b[0] = None
535 self.fail("Didn't raise TypeError")
536 except TypeError:
537 pass
538
539 def test_delitem(self):
540 b = bytearray(range(10))
541 del b[0]
542 self.assertEqual(b, bytearray(range(1, 10)))
543 del b[-1]
544 self.assertEqual(b, bytearray(range(1, 9)))
545 del b[4]
546 self.assertEqual(b, bytearray([1, 2, 3, 4, 6, 7, 8]))
547
548 def test_setslice(self):
549 b = bytearray(range(10))
550 self.assertEqual(list(b), list(range(10)))
551
552 b[0:5] = bytearray([1, 1, 1, 1, 1])
553 self.assertEqual(b, bytearray([1, 1, 1, 1, 1, 5, 6, 7, 8, 9]))
554
555 del b[0:-5]
556 self.assertEqual(b, bytearray([5, 6, 7, 8, 9]))
557
558 b[0:0] = bytearray([0, 1, 2, 3, 4])
559 self.assertEqual(b, bytearray(range(10)))
560
561 b[-7:-3] = bytearray([100, 101])
562 self.assertEqual(b, bytearray([0, 1, 2, 100, 101, 7, 8, 9]))
563
564 b[3:5] = [3, 4, 5, 6]
565 self.assertEqual(b, bytearray(range(10)))
566
567 b[3:0] = [42, 42, 42]
568 self.assertEqual(b, bytearray([0, 1, 2, 42, 42, 42, 3, 4, 5, 6, 7, 8, 9]))
569
570 def test_extended_set_del_slice(self):
571 indices = (0, None, 1, 3, 19, 300, -1, -2, -31, -300)
572 for start in indices:
573 for stop in indices:
574 # Skip invalid step 0
575 for step in indices[1:]:
576 L = list(range(255))
577 b = bytearray(L)
578 # Make sure we have a slice of exactly the right length,
579 # but with different data.
580 data = L[start:stop:step]
581 data.reverse()
582 L[start:stop:step] = data
583 b[start:stop:step] = data
584 self.assertEquals(b, bytearray(L))
585
586 del L[start:stop:step]
587 del b[start:stop:step]
588 self.assertEquals(b, bytearray(L))
589
590 def test_setslice_trap(self):
591 # This test verifies that we correctly handle assigning self
592 # to a slice of self (the old Lambert Meertens trap).
593 b = bytearray(range(256))
594 b[8:] = b
595 self.assertEqual(b, bytearray(list(range(8)) + list(range(256))))
596
597 def test_iconcat(self):
598 b = bytearray(b"abc")
599 b1 = b
600 b += b"def"
601 self.assertEqual(b, b"abcdef")
602 self.assertEqual(b, b1)
603 self.failUnless(b is b1)
604 b += b"xyz"
605 self.assertEqual(b, b"abcdefxyz")
606 try:
607 b += u""
608 except TypeError:
609 pass
610 else:
611 self.fail("bytes += unicode didn't raise TypeError")
612
613 def test_irepeat(self):
614 b = bytearray(b"abc")
615 b1 = b
616 b *= 3
617 self.assertEqual(b, b"abcabcabc")
618 self.assertEqual(b, b1)
619 self.failUnless(b is b1)
620
621 def test_irepeat_1char(self):
622 b = bytearray(b"x")
623 b1 = b
624 b *= 100
625 self.assertEqual(b, b"x"*100)
626 self.assertEqual(b, b1)
627 self.failUnless(b is b1)
628
629 def test_alloc(self):
630 b = bytearray()
631 alloc = b.__alloc__()
632 self.assert_(alloc >= 0)
633 seq = [alloc]
634 for i in range(100):
635 b += b"x"
636 alloc = b.__alloc__()
637 self.assert_(alloc >= len(b))
638 if alloc not in seq:
639 seq.append(alloc)
640
641 def test_extend(self):
642 orig = b'hello'
643 a = bytearray(orig)
644 a.extend(a)
645 self.assertEqual(a, orig + orig)
646 self.assertEqual(a[5:], orig)
647 a = bytearray(b'')
648 # Test iterators that don't have a __length_hint__
649 a.extend(map(ord, orig * 25))
650 a.extend(ord(x) for x in orig * 25)
651 self.assertEqual(a, orig * 50)
652 self.assertEqual(a[-5:], orig)
653 a = bytearray(b'')
654 a.extend(iter(map(ord, orig * 50)))
655 self.assertEqual(a, orig * 50)
656 self.assertEqual(a[-5:], orig)
657 a = bytearray(b'')
658 a.extend(list(map(ord, orig * 50)))
659 self.assertEqual(a, orig * 50)
660 self.assertEqual(a[-5:], orig)
661 a = bytearray(b'')
662 self.assertRaises(ValueError, a.extend, [0, 1, 2, 256])
663 self.assertRaises(ValueError, a.extend, [0, 1, 2, -1])
664 self.assertEqual(len(a), 0)
Georg Brandl3e483f62008-07-16 22:57:41 +0000665 a = bytearray(b'')
666 a.extend([Indexable(ord('a'))])
667 self.assertEqual(a, b'a')
Christian Heimes1a6387e2008-03-26 12:49:49 +0000668
669 def test_remove(self):
670 b = bytearray(b'hello')
671 b.remove(ord('l'))
672 self.assertEqual(b, b'helo')
673 b.remove(ord('l'))
674 self.assertEqual(b, b'heo')
675 self.assertRaises(ValueError, lambda: b.remove(ord('l')))
676 self.assertRaises(ValueError, lambda: b.remove(400))
677 self.assertRaises(TypeError, lambda: b.remove(u'e'))
678 # remove first and last
679 b.remove(ord('o'))
680 b.remove(ord('h'))
681 self.assertEqual(b, b'e')
682 self.assertRaises(TypeError, lambda: b.remove(u'e'))
Georg Brandl3e483f62008-07-16 22:57:41 +0000683 b.remove(Indexable(ord('e')))
684 self.assertEqual(b, b'')
Christian Heimes1a6387e2008-03-26 12:49:49 +0000685
686 def test_pop(self):
687 b = bytearray(b'world')
688 self.assertEqual(b.pop(), ord('d'))
689 self.assertEqual(b.pop(0), ord('w'))
690 self.assertEqual(b.pop(-2), ord('r'))
691 self.assertRaises(IndexError, lambda: b.pop(10))
692 self.assertRaises(OverflowError, lambda: bytearray().pop())
693
694 def test_nosort(self):
695 self.assertRaises(AttributeError, lambda: bytearray().sort())
696
697 def test_append(self):
698 b = bytearray(b'hell')
699 b.append(ord('o'))
700 self.assertEqual(b, b'hello')
701 self.assertEqual(b.append(100), None)
702 b = bytearray()
703 b.append(ord('A'))
704 self.assertEqual(len(b), 1)
705 self.assertRaises(TypeError, lambda: b.append(u'o'))
Georg Brandl3e483f62008-07-16 22:57:41 +0000706 b = bytearray()
707 b.append(Indexable(ord('A')))
708 self.assertEqual(b, b'A')
Christian Heimes1a6387e2008-03-26 12:49:49 +0000709
710 def test_insert(self):
711 b = bytearray(b'msssspp')
712 b.insert(1, ord('i'))
713 b.insert(4, ord('i'))
714 b.insert(-2, ord('i'))
715 b.insert(1000, ord('i'))
716 self.assertEqual(b, b'mississippi')
Georg Brandl3e483f62008-07-16 22:57:41 +0000717 # allowed in 2.6
718 #self.assertRaises(TypeError, lambda: b.insert(0, b'1'))
719 b = bytearray()
720 b.insert(0, Indexable(ord('A')))
721 self.assertEqual(b, b'A')
Christian Heimes1a6387e2008-03-26 12:49:49 +0000722
Benjamin Peterson46cc6d12008-11-19 21:49:09 +0000723 def test_copied(self):
724 # Issue 4348. Make sure that operations that don't mutate the array
725 # copy the bytes.
726 b = bytearray(b'abc')
Benjamin Petersond3b5a792008-11-20 21:44:23 +0000727 self.assertFalse(b is b.replace(b'abc', b'cde', 0))
Benjamin Peterson46cc6d12008-11-19 21:49:09 +0000728
729 t = bytearray([i for i in range(256)])
730 x = bytearray(b'')
731 self.assertFalse(x is x.translate(t))
732
Christian Heimes1a6387e2008-03-26 12:49:49 +0000733 def test_partition_bytearray_doesnt_share_nullstring(self):
734 a, b, c = bytearray(b"x").partition(b"y")
735 self.assertEqual(b, b"")
736 self.assertEqual(c, b"")
737 self.assert_(b is not c)
738 b += b"!"
739 self.assertEqual(c, b"")
740 a, b, c = bytearray(b"x").partition(b"y")
741 self.assertEqual(b, b"")
742 self.assertEqual(c, b"")
743 # Same for rpartition
744 b, c, a = bytearray(b"x").rpartition(b"y")
745 self.assertEqual(b, b"")
746 self.assertEqual(c, b"")
747 self.assert_(b is not c)
748 b += b"!"
749 self.assertEqual(c, b"")
750 c, b, a = bytearray(b"x").rpartition(b"y")
751 self.assertEqual(b, b"")
752 self.assertEqual(c, b"")
753
Antoine Pitrouae5bece2008-12-06 21:29:24 +0000754 # XXX memoryview not available
755 def XXXtest_resize_forbidden(self):
756 # #4509: can't resize a bytearray when there are buffer exports, even
757 # if it wouldn't reallocate the underlying buffer.
758 # Furthermore, no destructive changes to the buffer may be applied
759 # before raising the error.
760 b = bytearray(range(10))
761 v = memoryview(b)
762 def resize(n):
763 b[1:-1] = range(n + 1, 2*n - 1)
764 resize(10)
765 orig = b[:]
766 self.assertRaises(BufferError, resize, 11)
767 self.assertEquals(b, orig)
768 self.assertRaises(BufferError, resize, 9)
769 self.assertEquals(b, orig)
770 self.assertRaises(BufferError, resize, 0)
771 self.assertEquals(b, orig)
772 # Other operations implying resize
773 self.assertRaises(BufferError, b.pop, 0)
774 self.assertEquals(b, orig)
775 self.assertRaises(BufferError, b.remove, b[1])
776 self.assertEquals(b, orig)
777 def delitem():
778 del b[1]
779 self.assertRaises(BufferError, delitem)
780 self.assertEquals(b, orig)
781 # deleting a non-contiguous slice
782 def delslice():
783 b[1:-1:2] = b""
784 self.assertRaises(BufferError, delslice)
785 self.assertEquals(b, orig)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000786
787class AssortedBytesTest(unittest.TestCase):
788 #
789 # Test various combinations of bytes and bytearray
790 #
791
792 def setUp(self):
793 self.warning_filters = warnings.filters[:]
794
795 def tearDown(self):
796 warnings.filters = self.warning_filters
797
798 def test_repr_str(self):
799 warnings.simplefilter('ignore', BytesWarning)
800 for f in str, repr:
801 self.assertEqual(f(bytearray()), "bytearray(b'')")
802 self.assertEqual(f(bytearray([0])), "bytearray(b'\\x00')")
803 self.assertEqual(f(bytearray([0, 1, 254, 255])),
804 "bytearray(b'\\x00\\x01\\xfe\\xff')")
805 self.assertEqual(f(b"abc"), "b'abc'")
806 self.assertEqual(f(b"'"), '''b"'"''') # '''
807 self.assertEqual(f(b"'\""), r"""b'\'"'""") # '
808
809 def test_compare_bytes_to_bytearray(self):
810 self.assertEqual(b"abc" == bytes(b"abc"), True)
811 self.assertEqual(b"ab" != bytes(b"abc"), True)
812 self.assertEqual(b"ab" <= bytes(b"abc"), True)
813 self.assertEqual(b"ab" < bytes(b"abc"), True)
814 self.assertEqual(b"abc" >= bytes(b"ab"), True)
815 self.assertEqual(b"abc" > bytes(b"ab"), True)
816
817 self.assertEqual(b"abc" != bytes(b"abc"), False)
818 self.assertEqual(b"ab" == bytes(b"abc"), False)
819 self.assertEqual(b"ab" > bytes(b"abc"), False)
820 self.assertEqual(b"ab" >= bytes(b"abc"), False)
821 self.assertEqual(b"abc" < bytes(b"ab"), False)
822 self.assertEqual(b"abc" <= bytes(b"ab"), False)
823
824 self.assertEqual(bytes(b"abc") == b"abc", True)
825 self.assertEqual(bytes(b"ab") != b"abc", True)
826 self.assertEqual(bytes(b"ab") <= b"abc", True)
827 self.assertEqual(bytes(b"ab") < b"abc", True)
828 self.assertEqual(bytes(b"abc") >= b"ab", True)
829 self.assertEqual(bytes(b"abc") > b"ab", True)
830
831 self.assertEqual(bytes(b"abc") != b"abc", False)
832 self.assertEqual(bytes(b"ab") == b"abc", False)
833 self.assertEqual(bytes(b"ab") > b"abc", False)
834 self.assertEqual(bytes(b"ab") >= b"abc", False)
835 self.assertEqual(bytes(b"abc") < b"ab", False)
836 self.assertEqual(bytes(b"abc") <= b"ab", False)
837
838 def test_doc(self):
839 self.failUnless(bytearray.__doc__ != None)
840 self.failUnless(bytearray.__doc__.startswith("bytearray("), bytearray.__doc__)
841 self.failUnless(bytes.__doc__ != None)
842 self.failUnless(bytes.__doc__.startswith("bytes("), bytes.__doc__)
843
844 def test_from_bytearray(self):
845 sample = bytes(b"Hello world\n\x80\x81\xfe\xff")
846 buf = memoryview(sample)
847 b = bytearray(buf)
848 self.assertEqual(b, bytearray(sample))
849
850 def test_to_str(self):
851 warnings.simplefilter('ignore', BytesWarning)
852 self.assertEqual(str(b''), "b''")
853 self.assertEqual(str(b'x'), "b'x'")
854 self.assertEqual(str(b'\x80'), "b'\\x80'")
855 self.assertEqual(str(bytearray(b'')), "bytearray(b'')")
856 self.assertEqual(str(bytearray(b'x')), "bytearray(b'x')")
857 self.assertEqual(str(bytearray(b'\x80')), "bytearray(b'\\x80')")
858
859 def test_literal(self):
860 tests = [
861 (b"Wonderful spam", "Wonderful spam"),
862 (br"Wonderful spam too", "Wonderful spam too"),
863 (b"\xaa\x00\000\200", "\xaa\x00\000\200"),
864 (br"\xaa\x00\000\200", r"\xaa\x00\000\200"),
865 ]
866 for b, s in tests:
867 self.assertEqual(b, bytearray(s, 'latin-1'))
868 for c in range(128, 256):
869 self.assertRaises(SyntaxError, eval,
870 'b"%s"' % chr(c))
871
872 def test_translate(self):
873 b = b'hello'
Georg Brandl6425a2f2008-12-28 11:54:53 +0000874 ba = bytearray(b)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000875 rosetta = bytearray(range(0, 256))
876 rosetta[ord('o')] = ord('e')
877 c = b.translate(rosetta, b'l')
878 self.assertEqual(b, b'hello')
879 self.assertEqual(c, b'hee')
Georg Brandl6425a2f2008-12-28 11:54:53 +0000880 c = ba.translate(rosetta, b'l')
881 self.assertEqual(ba, b'hello')
882 self.assertEqual(c, b'hee')
883 c = b.translate(None, b'e')
884 self.assertEqual(c, b'hllo')
885 c = ba.translate(None, b'e')
886 self.assertEqual(c, b'hllo')
887 self.assertRaises(TypeError, b.translate, None, None)
888 self.assertRaises(TypeError, ba.translate, None, None)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000889
890 def test_split_bytearray(self):
891 self.assertEqual(b'a b'.split(memoryview(b' ')), [b'a', b'b'])
892
893 def test_rsplit_bytearray(self):
894 self.assertEqual(b'a b'.rsplit(memoryview(b' ')), [b'a', b'b'])
895
896 # Optimizations:
897 # __iter__? (optimization)
898 # __reversed__? (optimization)
899
900 # XXX More string methods? (Those that don't use character properties)
901
902 # There are tests in string_tests.py that are more
903 # comprehensive for things like split, partition, etc.
904 # Unfortunately they are all bundled with tests that
905 # are not appropriate for bytes
906
907 # I've started porting some of those into bytearray_tests.py, we should port
908 # the rest that make sense (the code can be cleaned up to use modern
909 # unittest methods at the same time).
910
911class BytearrayPEP3137Test(unittest.TestCase,
912 test.buffer_tests.MixinBytesBufferCommonTests):
913 def marshal(self, x):
914 return bytearray(x)
915
916 def test_returns_new_copy(self):
917 val = self.marshal(b'1234')
918 # On immutable types these MAY return a reference to themselves
919 # but on mutable types like bytearray they MUST return a new copy.
920 for methname in ('zfill', 'rjust', 'ljust', 'center'):
921 method = getattr(val, methname)
922 newval = method(3)
923 self.assertEqual(val, newval)
924 self.assertTrue(val is not newval,
925 methname+' returned self on a mutable object')
926
927
928class FixedStringTest(test.string_tests.BaseTest):
929
930 def fixtype(self, obj):
931 if isinstance(obj, str):
932 return obj.encode("utf-8")
933 return super(FixedStringTest, self).fixtype(obj)
934
935 # Currently the bytes containment testing uses a single integer
936 # value. This may not be the final design, but until then the
937 # bytes section with in a bytes containment not valid
938 def test_contains(self):
939 pass
940 def test_expandtabs(self):
941 pass
942 def test_upper(self):
943 pass
944 def test_lower(self):
945 pass
946 def test_hash(self):
947 # XXX check this out
948 pass
949
950
951class ByteArrayAsStringTest(FixedStringTest):
952 type2test = bytearray
953
954
955class ByteArraySubclass(bytearray):
956 pass
957
958class ByteArraySubclassTest(unittest.TestCase):
959
960 def test_basic(self):
961 self.assert_(issubclass(ByteArraySubclass, bytearray))
962 self.assert_(isinstance(ByteArraySubclass(), bytearray))
963
964 a, b = b"abcd", b"efgh"
965 _a, _b = ByteArraySubclass(a), ByteArraySubclass(b)
966
967 # test comparison operators with subclass instances
968 self.assert_(_a == _a)
969 self.assert_(_a != _b)
970 self.assert_(_a < _b)
971 self.assert_(_a <= _b)
972 self.assert_(_b >= _a)
973 self.assert_(_b > _a)
974 self.assert_(_a is not a)
975
976 # test concat of subclass instances
977 self.assertEqual(a + b, _a + _b)
978 self.assertEqual(a + b, a + _b)
979 self.assertEqual(a + b, _a + b)
980
981 # test repeat
982 self.assert_(a*5 == _a*5)
983
984 def test_join(self):
985 # Make sure join returns a NEW object for single item sequences
986 # involving a subclass.
987 # Make sure that it is of the appropriate type.
988 s1 = ByteArraySubclass(b"abcd")
989 s2 = bytearray().join([s1])
990 self.assert_(s1 is not s2)
991 self.assert_(type(s2) is bytearray, type(s2))
992
993 # Test reverse, calling join on subclass
994 s3 = s1.join([b"abcd"])
995 self.assert_(type(s3) is bytearray)
996
997 def test_pickle(self):
998 a = ByteArraySubclass(b"abcd")
999 a.x = 10
1000 a.y = ByteArraySubclass(b"efgh")
Hirokazu Yamamoto592c2752008-10-23 00:37:33 +00001001 for proto in range(pickle.HIGHEST_PROTOCOL + 1):
Christian Heimes1a6387e2008-03-26 12:49:49 +00001002 b = pickle.loads(pickle.dumps(a, proto))
1003 self.assertNotEqual(id(a), id(b))
1004 self.assertEqual(a, b)
1005 self.assertEqual(a.x, b.x)
1006 self.assertEqual(a.y, b.y)
1007 self.assertEqual(type(a), type(b))
1008 self.assertEqual(type(a.y), type(b.y))
1009
1010 def test_copy(self):
1011 a = ByteArraySubclass(b"abcd")
1012 a.x = 10
1013 a.y = ByteArraySubclass(b"efgh")
1014 for copy_method in (copy.copy, copy.deepcopy):
1015 b = copy_method(a)
1016 self.assertNotEqual(id(a), id(b))
1017 self.assertEqual(a, b)
1018 self.assertEqual(a.x, b.x)
1019 self.assertEqual(a.y, b.y)
1020 self.assertEqual(type(a), type(b))
1021 self.assertEqual(type(a.y), type(b.y))
1022
1023 def test_init_override(self):
1024 class subclass(bytearray):
1025 def __init__(self, newarg=1, *args, **kwargs):
1026 bytearray.__init__(self, *args, **kwargs)
1027 x = subclass(4, source=b"abcd")
1028 self.assertEqual(x, b"abcd")
1029 x = subclass(newarg=4, source=b"abcd")
1030 self.assertEqual(x, b"abcd")
1031
1032def test_main():
1033 #test.test_support.run_unittest(BytesTest)
1034 #test.test_support.run_unittest(AssortedBytesTest)
1035 #test.test_support.run_unittest(BytesAsStringTest)
1036 test.test_support.run_unittest(
1037 ByteArrayTest,
1038 ByteArrayAsStringTest,
1039 ByteArraySubclassTest,
1040 BytearrayPEP3137Test)
1041
1042if __name__ == "__main__":
1043 test_main()