blob: a33dcb5d3124939a5f27b1e5d3f2fc77ec5ab6ac [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
81 self.assertRaises(TypeError, self.type2test, ["0"])
82 self.assertRaises(TypeError, self.type2test, [0.0])
83 self.assertRaises(TypeError, self.type2test, [None])
84 self.assertRaises(TypeError, self.type2test, [C()])
85
86 def test_constructor_value_errors(self):
87 self.assertRaises(ValueError, self.type2test, [-1])
88 self.assertRaises(ValueError, self.type2test, [-sys.maxint])
89 self.assertRaises(ValueError, self.type2test, [-sys.maxint-1])
90 self.assertRaises(ValueError, self.type2test, [-sys.maxint-2])
91 self.assertRaises(ValueError, self.type2test, [-10**100])
92 self.assertRaises(ValueError, self.type2test, [256])
93 self.assertRaises(ValueError, self.type2test, [257])
94 self.assertRaises(ValueError, self.type2test, [sys.maxint])
95 self.assertRaises(ValueError, self.type2test, [sys.maxint+1])
96 self.assertRaises(ValueError, self.type2test, [10**100])
97
98 def test_compare(self):
99 b1 = self.type2test([1, 2, 3])
100 b2 = self.type2test([1, 2, 3])
101 b3 = self.type2test([1, 3])
102
103 self.assertEqual(b1, b2)
104 self.failUnless(b2 != b3)
105 self.failUnless(b1 <= b2)
106 self.failUnless(b1 <= b3)
107 self.failUnless(b1 < b3)
108 self.failUnless(b1 >= b2)
109 self.failUnless(b3 >= b2)
110 self.failUnless(b3 > b2)
111
112 self.failIf(b1 != b2)
113 self.failIf(b2 == b3)
114 self.failIf(b1 > b2)
115 self.failIf(b1 > b3)
116 self.failIf(b1 >= b3)
117 self.failIf(b1 < b2)
118 self.failIf(b3 < b2)
119 self.failIf(b3 <= b2)
120
121 def test_compare_to_str(self):
122 warnings.simplefilter('ignore', BytesWarning)
123 # Byte comparisons with unicode should always fail!
124 # Test this for all expected byte orders and Unicode character sizes
125 self.assertEqual(self.type2test(b"\0a\0b\0c") == u"abc", False)
126 self.assertEqual(self.type2test(b"\0\0\0a\0\0\0b\0\0\0c") == u"abc", False)
127 self.assertEqual(self.type2test(b"a\0b\0c\0") == u"abc", False)
128 self.assertEqual(self.type2test(b"a\0\0\0b\0\0\0c\0\0\0") == u"abc", False)
129 self.assertEqual(self.type2test() == unicode(), False)
130 self.assertEqual(self.type2test() != unicode(), True)
131
132 def test_reversed(self):
133 input = list(map(ord, "Hello"))
134 b = self.type2test(input)
135 output = list(reversed(b))
136 input.reverse()
137 self.assertEqual(output, input)
138
139 def test_getslice(self):
140 def by(s):
141 return self.type2test(map(ord, s))
142 b = by("Hello, world")
143
144 self.assertEqual(b[:5], by("Hello"))
145 self.assertEqual(b[1:5], by("ello"))
146 self.assertEqual(b[5:7], by(", "))
147 self.assertEqual(b[7:], by("world"))
148 self.assertEqual(b[7:12], by("world"))
149 self.assertEqual(b[7:100], by("world"))
150
151 self.assertEqual(b[:-7], by("Hello"))
152 self.assertEqual(b[-11:-7], by("ello"))
153 self.assertEqual(b[-7:-5], by(", "))
154 self.assertEqual(b[-5:], by("world"))
155 self.assertEqual(b[-5:12], by("world"))
156 self.assertEqual(b[-5:100], by("world"))
157 self.assertEqual(b[-100:5], by("Hello"))
158
159 def test_extended_getslice(self):
160 # Test extended slicing by comparing with list slicing.
161 L = list(range(255))
162 b = self.type2test(L)
163 indices = (0, None, 1, 3, 19, 100, -1, -2, -31, -100)
164 for start in indices:
165 for stop in indices:
166 # Skip step 0 (invalid)
167 for step in indices[1:]:
168 self.assertEqual(b[start:stop:step], self.type2test(L[start:stop:step]))
169
170 def test_encoding(self):
171 sample = u"Hello world\n\u1234\u5678\u9abc\udef0"
172 for enc in ("utf8", "utf16"):
173 b = self.type2test(sample, enc)
174 self.assertEqual(b, self.type2test(sample.encode(enc)))
175 self.assertRaises(UnicodeEncodeError, self.type2test, sample, "latin1")
176 b = self.type2test(sample, "latin1", "ignore")
177 self.assertEqual(b, self.type2test(sample[:-4], "utf-8"))
178
179 def test_decode(self):
180 sample = u"Hello world\n\u1234\u5678\u9abc\def0\def0"
181 for enc in ("utf8", "utf16"):
182 b = self.type2test(sample, enc)
183 self.assertEqual(b.decode(enc), sample)
184 sample = u"Hello world\n\x80\x81\xfe\xff"
185 b = self.type2test(sample, "latin1")
186 self.assertRaises(UnicodeDecodeError, b.decode, "utf8")
187 self.assertEqual(b.decode("utf8", "ignore"), "Hello world\n")
188
189 def test_from_int(self):
190 b = self.type2test(0)
191 self.assertEqual(b, self.type2test())
192 b = self.type2test(10)
193 self.assertEqual(b, self.type2test([0]*10))
194 b = self.type2test(10000)
195 self.assertEqual(b, self.type2test([0]*10000))
196
197 def test_concat(self):
198 b1 = self.type2test(b"abc")
199 b2 = self.type2test(b"def")
200 self.assertEqual(b1 + b2, b"abcdef")
201 self.assertEqual(b1 + bytes(b"def"), b"abcdef")
202 self.assertEqual(bytes(b"def") + b1, b"defabc")
203 self.assertRaises(TypeError, lambda: b1 + u"def")
204 self.assertRaises(TypeError, lambda: u"abc" + b2)
205
206 def test_repeat(self):
207 for b in b"abc", self.type2test(b"abc"):
208 self.assertEqual(b * 3, b"abcabcabc")
209 self.assertEqual(b * 0, b"")
210 self.assertEqual(b * -1, b"")
211 self.assertRaises(TypeError, lambda: b * 3.14)
212 self.assertRaises(TypeError, lambda: 3.14 * b)
213 # XXX Shouldn't bytes and bytearray agree on what to raise?
214 self.assertRaises((OverflowError, MemoryError),
215 lambda: b * sys.maxint)
216
217 def test_repeat_1char(self):
218 self.assertEqual(self.type2test(b'x')*100, self.type2test([ord('x')]*100))
219
220 def test_contains(self):
221 b = self.type2test(b"abc")
222 self.failUnless(ord('a') in b)
223 self.failUnless(int(ord('a')) in b)
224 self.failIf(200 in b)
225 self.failIf(200 in b)
226 self.assertRaises(ValueError, lambda: 300 in b)
227 self.assertRaises(ValueError, lambda: -1 in b)
228 self.assertRaises(TypeError, lambda: None in b)
229 self.assertRaises(TypeError, lambda: float(ord('a')) in b)
230 self.assertRaises(TypeError, lambda: u"a" in b)
231 for f in bytes, bytearray:
232 self.failUnless(f(b"") in b)
233 self.failUnless(f(b"a") in b)
234 self.failUnless(f(b"b") in b)
235 self.failUnless(f(b"c") in b)
236 self.failUnless(f(b"ab") in b)
237 self.failUnless(f(b"bc") in b)
238 self.failUnless(f(b"abc") in b)
239 self.failIf(f(b"ac") in b)
240 self.failIf(f(b"d") in b)
241 self.failIf(f(b"dab") in b)
242 self.failIf(f(b"abd") in b)
243
244 def test_fromhex(self):
245 self.assertRaises(TypeError, self.type2test.fromhex)
246 self.assertRaises(TypeError, self.type2test.fromhex, 1)
247 self.assertEquals(self.type2test.fromhex(u''), self.type2test())
248 b = bytearray([0x1a, 0x2b, 0x30])
249 self.assertEquals(self.type2test.fromhex(u'1a2B30'), b)
250 self.assertEquals(self.type2test.fromhex(u' 1A 2B 30 '), b)
251 self.assertEquals(self.type2test.fromhex(u'0000'), b'\0\0')
252 self.assertRaises(TypeError, self.type2test.fromhex, b'1B')
253 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):
399 for proto in range(pickle.HIGHEST_PROTOCOL):
400 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
723 def test_partition_bytearray_doesnt_share_nullstring(self):
724 a, b, c = bytearray(b"x").partition(b"y")
725 self.assertEqual(b, b"")
726 self.assertEqual(c, b"")
727 self.assert_(b is not c)
728 b += b"!"
729 self.assertEqual(c, b"")
730 a, b, c = bytearray(b"x").partition(b"y")
731 self.assertEqual(b, b"")
732 self.assertEqual(c, b"")
733 # Same for rpartition
734 b, c, a = bytearray(b"x").rpartition(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 c, b, a = bytearray(b"x").rpartition(b"y")
741 self.assertEqual(b, b"")
742 self.assertEqual(c, b"")
743
744
745class AssortedBytesTest(unittest.TestCase):
746 #
747 # Test various combinations of bytes and bytearray
748 #
749
750 def setUp(self):
751 self.warning_filters = warnings.filters[:]
752
753 def tearDown(self):
754 warnings.filters = self.warning_filters
755
756 def test_repr_str(self):
757 warnings.simplefilter('ignore', BytesWarning)
758 for f in str, repr:
759 self.assertEqual(f(bytearray()), "bytearray(b'')")
760 self.assertEqual(f(bytearray([0])), "bytearray(b'\\x00')")
761 self.assertEqual(f(bytearray([0, 1, 254, 255])),
762 "bytearray(b'\\x00\\x01\\xfe\\xff')")
763 self.assertEqual(f(b"abc"), "b'abc'")
764 self.assertEqual(f(b"'"), '''b"'"''') # '''
765 self.assertEqual(f(b"'\""), r"""b'\'"'""") # '
766
767 def test_compare_bytes_to_bytearray(self):
768 self.assertEqual(b"abc" == bytes(b"abc"), True)
769 self.assertEqual(b"ab" != bytes(b"abc"), True)
770 self.assertEqual(b"ab" <= bytes(b"abc"), True)
771 self.assertEqual(b"ab" < bytes(b"abc"), True)
772 self.assertEqual(b"abc" >= bytes(b"ab"), True)
773 self.assertEqual(b"abc" > bytes(b"ab"), True)
774
775 self.assertEqual(b"abc" != bytes(b"abc"), False)
776 self.assertEqual(b"ab" == bytes(b"abc"), False)
777 self.assertEqual(b"ab" > bytes(b"abc"), False)
778 self.assertEqual(b"ab" >= bytes(b"abc"), False)
779 self.assertEqual(b"abc" < bytes(b"ab"), False)
780 self.assertEqual(b"abc" <= bytes(b"ab"), False)
781
782 self.assertEqual(bytes(b"abc") == b"abc", True)
783 self.assertEqual(bytes(b"ab") != b"abc", True)
784 self.assertEqual(bytes(b"ab") <= b"abc", True)
785 self.assertEqual(bytes(b"ab") < b"abc", True)
786 self.assertEqual(bytes(b"abc") >= b"ab", True)
787 self.assertEqual(bytes(b"abc") > b"ab", True)
788
789 self.assertEqual(bytes(b"abc") != b"abc", False)
790 self.assertEqual(bytes(b"ab") == b"abc", False)
791 self.assertEqual(bytes(b"ab") > b"abc", False)
792 self.assertEqual(bytes(b"ab") >= b"abc", False)
793 self.assertEqual(bytes(b"abc") < b"ab", False)
794 self.assertEqual(bytes(b"abc") <= b"ab", False)
795
796 def test_doc(self):
797 self.failUnless(bytearray.__doc__ != None)
798 self.failUnless(bytearray.__doc__.startswith("bytearray("), bytearray.__doc__)
799 self.failUnless(bytes.__doc__ != None)
800 self.failUnless(bytes.__doc__.startswith("bytes("), bytes.__doc__)
801
802 def test_from_bytearray(self):
803 sample = bytes(b"Hello world\n\x80\x81\xfe\xff")
804 buf = memoryview(sample)
805 b = bytearray(buf)
806 self.assertEqual(b, bytearray(sample))
807
808 def test_to_str(self):
809 warnings.simplefilter('ignore', BytesWarning)
810 self.assertEqual(str(b''), "b''")
811 self.assertEqual(str(b'x'), "b'x'")
812 self.assertEqual(str(b'\x80'), "b'\\x80'")
813 self.assertEqual(str(bytearray(b'')), "bytearray(b'')")
814 self.assertEqual(str(bytearray(b'x')), "bytearray(b'x')")
815 self.assertEqual(str(bytearray(b'\x80')), "bytearray(b'\\x80')")
816
817 def test_literal(self):
818 tests = [
819 (b"Wonderful spam", "Wonderful spam"),
820 (br"Wonderful spam too", "Wonderful spam too"),
821 (b"\xaa\x00\000\200", "\xaa\x00\000\200"),
822 (br"\xaa\x00\000\200", r"\xaa\x00\000\200"),
823 ]
824 for b, s in tests:
825 self.assertEqual(b, bytearray(s, 'latin-1'))
826 for c in range(128, 256):
827 self.assertRaises(SyntaxError, eval,
828 'b"%s"' % chr(c))
829
830 def test_translate(self):
831 b = b'hello'
832 rosetta = bytearray(range(0, 256))
833 rosetta[ord('o')] = ord('e')
834 c = b.translate(rosetta, b'l')
835 self.assertEqual(b, b'hello')
836 self.assertEqual(c, b'hee')
837
838 def test_split_bytearray(self):
839 self.assertEqual(b'a b'.split(memoryview(b' ')), [b'a', b'b'])
840
841 def test_rsplit_bytearray(self):
842 self.assertEqual(b'a b'.rsplit(memoryview(b' ')), [b'a', b'b'])
843
844 # Optimizations:
845 # __iter__? (optimization)
846 # __reversed__? (optimization)
847
848 # XXX More string methods? (Those that don't use character properties)
849
850 # There are tests in string_tests.py that are more
851 # comprehensive for things like split, partition, etc.
852 # Unfortunately they are all bundled with tests that
853 # are not appropriate for bytes
854
855 # I've started porting some of those into bytearray_tests.py, we should port
856 # the rest that make sense (the code can be cleaned up to use modern
857 # unittest methods at the same time).
858
859class BytearrayPEP3137Test(unittest.TestCase,
860 test.buffer_tests.MixinBytesBufferCommonTests):
861 def marshal(self, x):
862 return bytearray(x)
863
864 def test_returns_new_copy(self):
865 val = self.marshal(b'1234')
866 # On immutable types these MAY return a reference to themselves
867 # but on mutable types like bytearray they MUST return a new copy.
868 for methname in ('zfill', 'rjust', 'ljust', 'center'):
869 method = getattr(val, methname)
870 newval = method(3)
871 self.assertEqual(val, newval)
872 self.assertTrue(val is not newval,
873 methname+' returned self on a mutable object')
874
875
876class FixedStringTest(test.string_tests.BaseTest):
877
878 def fixtype(self, obj):
879 if isinstance(obj, str):
880 return obj.encode("utf-8")
881 return super(FixedStringTest, self).fixtype(obj)
882
883 # Currently the bytes containment testing uses a single integer
884 # value. This may not be the final design, but until then the
885 # bytes section with in a bytes containment not valid
886 def test_contains(self):
887 pass
888 def test_expandtabs(self):
889 pass
890 def test_upper(self):
891 pass
892 def test_lower(self):
893 pass
894 def test_hash(self):
895 # XXX check this out
896 pass
897
898
899class ByteArrayAsStringTest(FixedStringTest):
900 type2test = bytearray
901
902
903class ByteArraySubclass(bytearray):
904 pass
905
906class ByteArraySubclassTest(unittest.TestCase):
907
908 def test_basic(self):
909 self.assert_(issubclass(ByteArraySubclass, bytearray))
910 self.assert_(isinstance(ByteArraySubclass(), bytearray))
911
912 a, b = b"abcd", b"efgh"
913 _a, _b = ByteArraySubclass(a), ByteArraySubclass(b)
914
915 # test comparison operators with subclass instances
916 self.assert_(_a == _a)
917 self.assert_(_a != _b)
918 self.assert_(_a < _b)
919 self.assert_(_a <= _b)
920 self.assert_(_b >= _a)
921 self.assert_(_b > _a)
922 self.assert_(_a is not a)
923
924 # test concat of subclass instances
925 self.assertEqual(a + b, _a + _b)
926 self.assertEqual(a + b, a + _b)
927 self.assertEqual(a + b, _a + b)
928
929 # test repeat
930 self.assert_(a*5 == _a*5)
931
932 def test_join(self):
933 # Make sure join returns a NEW object for single item sequences
934 # involving a subclass.
935 # Make sure that it is of the appropriate type.
936 s1 = ByteArraySubclass(b"abcd")
937 s2 = bytearray().join([s1])
938 self.assert_(s1 is not s2)
939 self.assert_(type(s2) is bytearray, type(s2))
940
941 # Test reverse, calling join on subclass
942 s3 = s1.join([b"abcd"])
943 self.assert_(type(s3) is bytearray)
944
945 def test_pickle(self):
946 a = ByteArraySubclass(b"abcd")
947 a.x = 10
948 a.y = ByteArraySubclass(b"efgh")
949 for proto in range(pickle.HIGHEST_PROTOCOL):
950 b = pickle.loads(pickle.dumps(a, proto))
951 self.assertNotEqual(id(a), id(b))
952 self.assertEqual(a, b)
953 self.assertEqual(a.x, b.x)
954 self.assertEqual(a.y, b.y)
955 self.assertEqual(type(a), type(b))
956 self.assertEqual(type(a.y), type(b.y))
957
958 def test_copy(self):
959 a = ByteArraySubclass(b"abcd")
960 a.x = 10
961 a.y = ByteArraySubclass(b"efgh")
962 for copy_method in (copy.copy, copy.deepcopy):
963 b = copy_method(a)
964 self.assertNotEqual(id(a), id(b))
965 self.assertEqual(a, b)
966 self.assertEqual(a.x, b.x)
967 self.assertEqual(a.y, b.y)
968 self.assertEqual(type(a), type(b))
969 self.assertEqual(type(a.y), type(b.y))
970
971 def test_init_override(self):
972 class subclass(bytearray):
973 def __init__(self, newarg=1, *args, **kwargs):
974 bytearray.__init__(self, *args, **kwargs)
975 x = subclass(4, source=b"abcd")
976 self.assertEqual(x, b"abcd")
977 x = subclass(newarg=4, source=b"abcd")
978 self.assertEqual(x, b"abcd")
979
980def test_main():
981 #test.test_support.run_unittest(BytesTest)
982 #test.test_support.run_unittest(AssortedBytesTest)
983 #test.test_support.run_unittest(BytesAsStringTest)
984 test.test_support.run_unittest(
985 ByteArrayTest,
986 ByteArrayAsStringTest,
987 ByteArraySubclassTest,
988 BytearrayPEP3137Test)
989
990if __name__ == "__main__":
991 test_main()