blob: 230dbf46bed58aca75738bdb8e2ccae787cfae0b [file] [log] [blame]
Guido van Rossum254348e2007-11-21 19:29:53 +00001"""Unit tests for the bytes and bytearray types.
Guido van Rossum98297ee2007-11-06 21:34:58 +00002
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"""
Guido van Rossum4dfe8a12006-04-22 23:28:04 +00007
Guido van Rossumd624f182006-04-24 13:47:05 +00008import os
9import re
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000010import sys
Guido van Rossuma6c04be2007-11-03 00:24:24 +000011import copy
Guido van Rossum0ad08122007-04-11 04:37:43 +000012import pickle
Guido van Rossumd624f182006-04-24 13:47:05 +000013import tempfile
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000014import unittest
Guido van Rossum98297ee2007-11-06 21:34:58 +000015import warnings
Benjamin Petersonee8712c2008-05-20 21:35:26 +000016import test.support
Georg Brandlc7885542007-03-06 19:16:20 +000017import test.string_tests
Gregory P. Smith60d241f2007-10-16 06:31:30 +000018import test.buffer_tests
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000019
Georg Brandl9a54d7c2008-07-16 23:15:30 +000020class Indexable:
21 def __init__(self, value=0):
22 self.value = value
23 def __index__(self):
24 return self.value
25
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000026
Christian Heimes510711d2008-01-30 11:57:58 +000027class BaseBytesTest(unittest.TestCase):
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000028
Guido van Rossum98297ee2007-11-06 21:34:58 +000029 def setUp(self):
30 self.warning_filters = warnings.filters[:]
31
32 def tearDown(self):
33 warnings.filters = self.warning_filters
34
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000035 def test_basics(self):
Christian Heimes510711d2008-01-30 11:57:58 +000036 b = self.type2test()
37 self.assertEqual(type(b), self.type2test)
38 self.assertEqual(b.__class__, self.type2test)
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000039
40 def test_empty_sequence(self):
Christian Heimes510711d2008-01-30 11:57:58 +000041 b = self.type2test()
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000042 self.assertEqual(len(b), 0)
43 self.assertRaises(IndexError, lambda: b[0])
44 self.assertRaises(IndexError, lambda: b[1])
Christian Heimesa37d4c62007-12-04 23:02:19 +000045 self.assertRaises(IndexError, lambda: b[sys.maxsize])
46 self.assertRaises(IndexError, lambda: b[sys.maxsize+1])
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000047 self.assertRaises(IndexError, lambda: b[10**100])
48 self.assertRaises(IndexError, lambda: b[-1])
49 self.assertRaises(IndexError, lambda: b[-2])
Christian Heimesa37d4c62007-12-04 23:02:19 +000050 self.assertRaises(IndexError, lambda: b[-sys.maxsize])
51 self.assertRaises(IndexError, lambda: b[-sys.maxsize-1])
52 self.assertRaises(IndexError, lambda: b[-sys.maxsize-2])
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000053 self.assertRaises(IndexError, lambda: b[-10**100])
54
55 def test_from_list(self):
56 ints = list(range(256))
Christian Heimes510711d2008-01-30 11:57:58 +000057 b = self.type2test(i for i in ints)
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000058 self.assertEqual(len(b), 256)
59 self.assertEqual(list(b), ints)
60
61 def test_from_index(self):
Georg Brandl9a54d7c2008-07-16 23:15:30 +000062 b = self.type2test([Indexable(), Indexable(1), Indexable(254),
63 Indexable(255)])
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000064 self.assertEqual(list(b), [0, 1, 254, 255])
Georg Brandl9a54d7c2008-07-16 23:15:30 +000065 self.assertRaises(ValueError, bytearray, [Indexable(-1)])
66 self.assertRaises(ValueError, bytearray, [Indexable(256)])
Guido van Rossum98297ee2007-11-06 21:34:58 +000067
68 def test_from_ssize(self):
Guido van Rossum254348e2007-11-21 19:29:53 +000069 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)
Guido van Rossum98297ee2007-11-06 21:34:58 +000073
Guido van Rossum254348e2007-11-21 19:29:53 +000074 self.assertEqual(bytearray('0', 'ascii'), b'0')
75 self.assertEqual(bytearray(b'0'), b'0')
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000076
77 def test_constructor_type_errors(self):
Christian Heimes510711d2008-01-30 11:57:58 +000078 self.assertRaises(TypeError, self.type2test, 0.0)
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000079 class C:
80 pass
Christian Heimes510711d2008-01-30 11:57:58 +000081 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()])
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000085
86 def test_constructor_value_errors(self):
Christian Heimes510711d2008-01-30 11:57:58 +000087 self.assertRaises(ValueError, self.type2test, [-1])
88 self.assertRaises(ValueError, self.type2test, [-sys.maxsize])
89 self.assertRaises(ValueError, self.type2test, [-sys.maxsize-1])
90 self.assertRaises(ValueError, self.type2test, [-sys.maxsize-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.maxsize])
95 self.assertRaises(ValueError, self.type2test, [sys.maxsize+1])
96 self.assertRaises(ValueError, self.type2test, [10**100])
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000097
98 def test_compare(self):
Christian Heimes510711d2008-01-30 11:57:58 +000099 b1 = self.type2test([1, 2, 3])
100 b2 = self.type2test([1, 2, 3])
101 b3 = self.type2test([1, 3])
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000102
Guido van Rossume61fd5b2007-07-11 12:20:59 +0000103 self.assertEqual(b1, b2)
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000104 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
Guido van Rossum343e97f2007-04-09 00:43:24 +0000121 def test_compare_to_str(self):
Guido van Rossum98297ee2007-11-06 21:34:58 +0000122 warnings.simplefilter('ignore', BytesWarning)
Guido van Rossum1e35e762007-10-09 17:21:10 +0000123 # Byte comparisons with unicode should always fail!
Guido van Rossumebea9be2007-04-09 00:49:13 +0000124 # Test this for all expected byte orders and Unicode character sizes
Christian Heimes510711d2008-01-30 11:57:58 +0000125 self.assertEqual(self.type2test(b"\0a\0b\0c") == "abc", False)
126 self.assertEqual(self.type2test(b"\0\0\0a\0\0\0b\0\0\0c") == "abc", False)
127 self.assertEqual(self.type2test(b"a\0b\0c\0") == "abc", False)
128 self.assertEqual(self.type2test(b"a\0\0\0b\0\0\0c\0\0\0") == "abc", False)
129 self.assertEqual(self.type2test() == str(), False)
130 self.assertEqual(self.type2test() != str(), 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 = "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 = "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 = "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 + "def")
204 self.assertRaises(TypeError, lambda: "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.maxsize)
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: "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)
Christian Heimes4f066122008-01-30 15:02:52 +0000247 self.assertEquals(self.type2test.fromhex(''), self.type2test())
Christian Heimes510711d2008-01-30 11:57:58 +0000248 b = bytearray([0x1a, 0x2b, 0x30])
249 self.assertEquals(self.type2test.fromhex('1a2B30'), b)
250 self.assertEquals(self.type2test.fromhex(' 1A 2B 30 '), b)
251 self.assertEquals(self.type2test.fromhex('0000'), b'\0\0')
252 self.assertRaises(TypeError, self.type2test.fromhex, b'1B')
253 self.assertRaises(ValueError, self.type2test.fromhex, 'a')
254 self.assertRaises(ValueError, self.type2test.fromhex, 'rt')
255 self.assertRaises(ValueError, self.type2test.fromhex, '1a b cd')
256 self.assertRaises(ValueError, self.type2test.fromhex, '\x00')
257 self.assertRaises(ValueError, self.type2test.fromhex, '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, ' ')
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, ' ')
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 test_strip_bytearray(self):
438 self.assertEqual(self.type2test(b'abc').strip(memoryview(b'ac')), b'b')
439 self.assertEqual(self.type2test(b'abc').lstrip(memoryview(b'ac')), b'bc')
440 self.assertEqual(self.type2test(b'abc').rstrip(memoryview(b'ac')), b'ab')
441
442 def test_strip_string_error(self):
443 self.assertRaises(TypeError, self.type2test(b'abc').strip, 'b')
444 self.assertRaises(TypeError, self.type2test(b'abc').lstrip, 'b')
445 self.assertRaises(TypeError, self.type2test(b'abc').rstrip, 'b')
446
447 def test_ord(self):
448 b = self.type2test(b'\0A\x7f\x80\xff')
449 self.assertEqual([ord(b[i:i+1]) for i in range(len(b))],
450 [0, 65, 127, 128, 255])
451
452
453class BytesTest(BaseBytesTest):
454 type2test = bytes
455
Antoine Pitrou2f89aa62008-08-02 21:02:48 +0000456 def test_buffer_is_readonly(self):
457 with open(sys.stdin.fileno(), "rb", buffering=0) as f:
458 self.assertRaises(TypeError, f.readinto, b"")
459
460
Christian Heimes510711d2008-01-30 11:57:58 +0000461class ByteArrayTest(BaseBytesTest):
462 type2test = bytearray
Guido van Rossumebea9be2007-04-09 00:49:13 +0000463
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000464 def test_nohash(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000465 self.assertRaises(TypeError, hash, bytearray())
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000466
Guido van Rossum254348e2007-11-21 19:29:53 +0000467 def test_bytearray_api(self):
Guido van Rossum75d6f1a2007-05-24 17:52:00 +0000468 short_sample = b"Hello world\n"
Guido van Rossum98297ee2007-11-06 21:34:58 +0000469 sample = short_sample + b"\0"*(20 - len(short_sample))
Guido van Rossumd624f182006-04-24 13:47:05 +0000470 tfn = tempfile.mktemp()
471 try:
472 # Prepare
473 with open(tfn, "wb") as f:
474 f.write(short_sample)
475 # Test readinto
476 with open(tfn, "rb") as f:
Guido van Rossum254348e2007-11-21 19:29:53 +0000477 b = bytearray(20)
Guido van Rossumd624f182006-04-24 13:47:05 +0000478 n = f.readinto(b)
479 self.assertEqual(n, len(short_sample))
Guido van Rossumc1f779c2007-07-03 08:25:58 +0000480 self.assertEqual(list(b), list(sample))
Guido van Rossumd624f182006-04-24 13:47:05 +0000481 # Test writing in binary mode
482 with open(tfn, "wb") as f:
483 f.write(b)
484 with open(tfn, "rb") as f:
485 self.assertEqual(f.read(), sample)
Guido van Rossum13633bb2007-04-13 18:42:35 +0000486 # Text mode is ambiguous; don't test
Guido van Rossumd624f182006-04-24 13:47:05 +0000487 finally:
488 try:
489 os.remove(tfn)
490 except os.error:
491 pass
492
Neal Norwitz6968b052007-02-27 19:02:19 +0000493 def test_reverse(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000494 b = bytearray(b'hello')
Neal Norwitz6968b052007-02-27 19:02:19 +0000495 self.assertEqual(b.reverse(), None)
496 self.assertEqual(b, b'olleh')
Guido van Rossum254348e2007-11-21 19:29:53 +0000497 b = bytearray(b'hello1') # test even number of items
Neal Norwitz6968b052007-02-27 19:02:19 +0000498 b.reverse()
499 self.assertEqual(b, b'1olleh')
Guido van Rossum254348e2007-11-21 19:29:53 +0000500 b = bytearray()
Neal Norwitz6968b052007-02-27 19:02:19 +0000501 b.reverse()
502 self.assertFalse(b)
503
Guido van Rossumd624f182006-04-24 13:47:05 +0000504 def test_regexps(self):
505 def by(s):
Guido van Rossum254348e2007-11-21 19:29:53 +0000506 return bytearray(map(ord, s))
Guido van Rossumd624f182006-04-24 13:47:05 +0000507 b = by("Hello, world")
508 self.assertEqual(re.findall(r"\w+", b), [by("Hello"), by("world")])
509
510 def test_setitem(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000511 b = bytearray([1, 2, 3])
Guido van Rossumd624f182006-04-24 13:47:05 +0000512 b[1] = 100
Guido van Rossum254348e2007-11-21 19:29:53 +0000513 self.assertEqual(b, bytearray([1, 100, 3]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000514 b[-1] = 200
Guido van Rossum254348e2007-11-21 19:29:53 +0000515 self.assertEqual(b, bytearray([1, 100, 200]))
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000516 b[0] = Indexable(10)
Guido van Rossum254348e2007-11-21 19:29:53 +0000517 self.assertEqual(b, bytearray([10, 100, 200]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000518 try:
519 b[3] = 0
520 self.fail("Didn't raise IndexError")
521 except IndexError:
522 pass
523 try:
524 b[-10] = 0
525 self.fail("Didn't raise IndexError")
526 except IndexError:
527 pass
528 try:
529 b[0] = 256
530 self.fail("Didn't raise ValueError")
531 except ValueError:
532 pass
533 try:
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000534 b[0] = Indexable(-1)
Guido van Rossumd624f182006-04-24 13:47:05 +0000535 self.fail("Didn't raise ValueError")
536 except ValueError:
537 pass
538 try:
539 b[0] = None
540 self.fail("Didn't raise TypeError")
541 except TypeError:
542 pass
543
544 def test_delitem(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000545 b = bytearray(range(10))
Guido van Rossumd624f182006-04-24 13:47:05 +0000546 del b[0]
Guido van Rossum254348e2007-11-21 19:29:53 +0000547 self.assertEqual(b, bytearray(range(1, 10)))
Guido van Rossumd624f182006-04-24 13:47:05 +0000548 del b[-1]
Guido van Rossum254348e2007-11-21 19:29:53 +0000549 self.assertEqual(b, bytearray(range(1, 9)))
Guido van Rossumd624f182006-04-24 13:47:05 +0000550 del b[4]
Guido van Rossum254348e2007-11-21 19:29:53 +0000551 self.assertEqual(b, bytearray([1, 2, 3, 4, 6, 7, 8]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000552
553 def test_setslice(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000554 b = bytearray(range(10))
Guido van Rossumd624f182006-04-24 13:47:05 +0000555 self.assertEqual(list(b), list(range(10)))
556
Guido van Rossum254348e2007-11-21 19:29:53 +0000557 b[0:5] = bytearray([1, 1, 1, 1, 1])
558 self.assertEqual(b, bytearray([1, 1, 1, 1, 1, 5, 6, 7, 8, 9]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000559
560 del b[0:-5]
Guido van Rossum254348e2007-11-21 19:29:53 +0000561 self.assertEqual(b, bytearray([5, 6, 7, 8, 9]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000562
Guido van Rossum254348e2007-11-21 19:29:53 +0000563 b[0:0] = bytearray([0, 1, 2, 3, 4])
564 self.assertEqual(b, bytearray(range(10)))
Guido van Rossumd624f182006-04-24 13:47:05 +0000565
Guido van Rossum254348e2007-11-21 19:29:53 +0000566 b[-7:-3] = bytearray([100, 101])
567 self.assertEqual(b, bytearray([0, 1, 2, 100, 101, 7, 8, 9]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000568
569 b[3:5] = [3, 4, 5, 6]
Guido van Rossum254348e2007-11-21 19:29:53 +0000570 self.assertEqual(b, bytearray(range(10)))
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000571
Thomas Wouters9a6e62b2006-08-23 23:20:29 +0000572 b[3:0] = [42, 42, 42]
Guido van Rossum254348e2007-11-21 19:29:53 +0000573 self.assertEqual(b, bytearray([0, 1, 2, 42, 42, 42, 3, 4, 5, 6, 7, 8, 9]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000574
Thomas Wouters376446d2006-12-19 08:30:14 +0000575 def test_extended_set_del_slice(self):
576 indices = (0, None, 1, 3, 19, 300, -1, -2, -31, -300)
577 for start in indices:
578 for stop in indices:
579 # Skip invalid step 0
580 for step in indices[1:]:
581 L = list(range(255))
Guido van Rossum254348e2007-11-21 19:29:53 +0000582 b = bytearray(L)
Thomas Wouters376446d2006-12-19 08:30:14 +0000583 # Make sure we have a slice of exactly the right length,
584 # but with different data.
585 data = L[start:stop:step]
586 data.reverse()
587 L[start:stop:step] = data
588 b[start:stop:step] = data
Guido van Rossum254348e2007-11-21 19:29:53 +0000589 self.assertEquals(b, bytearray(L))
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000590
Thomas Wouters376446d2006-12-19 08:30:14 +0000591 del L[start:stop:step]
592 del b[start:stop:step]
Guido van Rossum254348e2007-11-21 19:29:53 +0000593 self.assertEquals(b, bytearray(L))
Thomas Wouters376446d2006-12-19 08:30:14 +0000594
Guido van Rossumd624f182006-04-24 13:47:05 +0000595 def test_setslice_trap(self):
596 # This test verifies that we correctly handle assigning self
597 # to a slice of self (the old Lambert Meertens trap).
Guido van Rossum254348e2007-11-21 19:29:53 +0000598 b = bytearray(range(256))
Guido van Rossumd624f182006-04-24 13:47:05 +0000599 b[8:] = b
Guido van Rossum254348e2007-11-21 19:29:53 +0000600 self.assertEqual(b, bytearray(list(range(8)) + list(range(256))))
Guido van Rossumd624f182006-04-24 13:47:05 +0000601
Guido van Rossum13e57212006-04-27 22:54:26 +0000602 def test_iconcat(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000603 b = bytearray(b"abc")
Guido van Rossum13e57212006-04-27 22:54:26 +0000604 b1 = b
Guido van Rossum9c627722007-08-27 18:31:48 +0000605 b += b"def"
606 self.assertEqual(b, b"abcdef")
Guido van Rossum13e57212006-04-27 22:54:26 +0000607 self.assertEqual(b, b1)
608 self.failUnless(b is b1)
Guido van Rossum98297ee2007-11-06 21:34:58 +0000609 b += b"xyz"
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000610 self.assertEqual(b, b"abcdefxyz")
611 try:
Guido van Rossumef87d6e2007-05-02 19:09:54 +0000612 b += ""
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000613 except TypeError:
614 pass
615 else:
616 self.fail("bytes += unicode didn't raise TypeError")
Guido van Rossum13e57212006-04-27 22:54:26 +0000617
618 def test_irepeat(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000619 b = bytearray(b"abc")
Guido van Rossum13e57212006-04-27 22:54:26 +0000620 b1 = b
621 b *= 3
Guido van Rossum9c627722007-08-27 18:31:48 +0000622 self.assertEqual(b, b"abcabcabc")
Guido van Rossum13e57212006-04-27 22:54:26 +0000623 self.assertEqual(b, b1)
624 self.failUnless(b is b1)
625
626 def test_irepeat_1char(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000627 b = bytearray(b"x")
Guido van Rossum13e57212006-04-27 22:54:26 +0000628 b1 = b
629 b *= 100
Guido van Rossum98297ee2007-11-06 21:34:58 +0000630 self.assertEqual(b, b"x"*100)
Guido van Rossum13e57212006-04-27 22:54:26 +0000631 self.assertEqual(b, b1)
632 self.failUnless(b is b1)
633
Guido van Rossum20188312006-05-05 15:15:40 +0000634 def test_alloc(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000635 b = bytearray()
Guido van Rossum20188312006-05-05 15:15:40 +0000636 alloc = b.__alloc__()
637 self.assert_(alloc >= 0)
638 seq = [alloc]
639 for i in range(100):
Guido van Rossum9c627722007-08-27 18:31:48 +0000640 b += b"x"
Guido van Rossum20188312006-05-05 15:15:40 +0000641 alloc = b.__alloc__()
642 self.assert_(alloc >= len(b))
643 if alloc not in seq:
644 seq.append(alloc)
Guido van Rossum20188312006-05-05 15:15:40 +0000645
Neal Norwitz6968b052007-02-27 19:02:19 +0000646 def test_extend(self):
647 orig = b'hello'
Guido van Rossum254348e2007-11-21 19:29:53 +0000648 a = bytearray(orig)
Neal Norwitz6968b052007-02-27 19:02:19 +0000649 a.extend(a)
650 self.assertEqual(a, orig + orig)
651 self.assertEqual(a[5:], orig)
Alexandre Vassalotti09121e82007-12-04 05:51:13 +0000652 a = bytearray(b'')
653 # Test iterators that don't have a __length_hint__
654 a.extend(map(int, orig * 25))
655 a.extend(int(x) for x in orig * 25)
656 self.assertEqual(a, orig * 50)
657 self.assertEqual(a[-5:], orig)
658 a = bytearray(b'')
659 a.extend(iter(map(int, orig * 50)))
660 self.assertEqual(a, orig * 50)
661 self.assertEqual(a[-5:], orig)
662 a = bytearray(b'')
663 a.extend(list(map(int, orig * 50)))
664 self.assertEqual(a, orig * 50)
665 self.assertEqual(a[-5:], orig)
666 a = bytearray(b'')
667 self.assertRaises(ValueError, a.extend, [0, 1, 2, 256])
668 self.assertRaises(ValueError, a.extend, [0, 1, 2, -1])
669 self.assertEqual(len(a), 0)
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000670 a = bytearray(b'')
671 a.extend([Indexable(ord('a'))])
672 self.assertEqual(a, b'a')
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000673
Neal Norwitz6968b052007-02-27 19:02:19 +0000674 def test_remove(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000675 b = bytearray(b'hello')
Neal Norwitz6968b052007-02-27 19:02:19 +0000676 b.remove(ord('l'))
677 self.assertEqual(b, b'helo')
678 b.remove(ord('l'))
679 self.assertEqual(b, b'heo')
680 self.assertRaises(ValueError, lambda: b.remove(ord('l')))
681 self.assertRaises(ValueError, lambda: b.remove(400))
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000682 self.assertRaises(TypeError, lambda: b.remove('e'))
Neal Norwitz6968b052007-02-27 19:02:19 +0000683 # remove first and last
684 b.remove(ord('o'))
685 b.remove(ord('h'))
686 self.assertEqual(b, b'e')
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000687 self.assertRaises(TypeError, lambda: b.remove(b'e'))
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000688 b.remove(Indexable(ord('e')))
689 self.assertEqual(b, b'')
Neal Norwitz6968b052007-02-27 19:02:19 +0000690
691 def test_pop(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000692 b = bytearray(b'world')
Neal Norwitz6968b052007-02-27 19:02:19 +0000693 self.assertEqual(b.pop(), ord('d'))
694 self.assertEqual(b.pop(0), ord('w'))
695 self.assertEqual(b.pop(-2), ord('r'))
696 self.assertRaises(IndexError, lambda: b.pop(10))
Guido van Rossum254348e2007-11-21 19:29:53 +0000697 self.assertRaises(OverflowError, lambda: bytearray().pop())
Neal Norwitz6968b052007-02-27 19:02:19 +0000698
699 def test_nosort(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000700 self.assertRaises(AttributeError, lambda: bytearray().sort())
Neal Norwitz6968b052007-02-27 19:02:19 +0000701
Neal Norwitz6968b052007-02-27 19:02:19 +0000702 def test_append(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000703 b = bytearray(b'hell')
Neal Norwitz6968b052007-02-27 19:02:19 +0000704 b.append(ord('o'))
705 self.assertEqual(b, b'hello')
706 self.assertEqual(b.append(100), None)
Guido van Rossum254348e2007-11-21 19:29:53 +0000707 b = bytearray()
Neal Norwitz6968b052007-02-27 19:02:19 +0000708 b.append(ord('A'))
709 self.assertEqual(len(b), 1)
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000710 self.assertRaises(TypeError, lambda: b.append(b'o'))
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000711 b = bytearray()
712 b.append(Indexable(ord('A')))
713 self.assertEqual(b, b'A')
Neal Norwitz6968b052007-02-27 19:02:19 +0000714
715 def test_insert(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000716 b = bytearray(b'msssspp')
Neal Norwitz6968b052007-02-27 19:02:19 +0000717 b.insert(1, ord('i'))
718 b.insert(4, ord('i'))
719 b.insert(-2, ord('i'))
720 b.insert(1000, ord('i'))
721 self.assertEqual(b, b'mississippi')
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000722 self.assertRaises(TypeError, lambda: b.insert(0, b'1'))
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000723 b = bytearray()
724 b.insert(0, Indexable(ord('A')))
725 self.assertEqual(b, b'A')
Neal Norwitz6968b052007-02-27 19:02:19 +0000726
Guido van Rossum254348e2007-11-21 19:29:53 +0000727 def test_partition_bytearray_doesnt_share_nullstring(self):
728 a, b, c = bytearray(b"x").partition(b"y")
Guido van Rossum98297ee2007-11-06 21:34:58 +0000729 self.assertEqual(b, b"")
730 self.assertEqual(c, b"")
731 self.assert_(b is not c)
732 b += b"!"
733 self.assertEqual(c, b"")
Guido van Rossum254348e2007-11-21 19:29:53 +0000734 a, b, c = bytearray(b"x").partition(b"y")
Guido van Rossum98297ee2007-11-06 21:34:58 +0000735 self.assertEqual(b, b"")
736 self.assertEqual(c, b"")
737 # Same for rpartition
Guido van Rossum254348e2007-11-21 19:29:53 +0000738 b, c, a = bytearray(b"x").rpartition(b"y")
Guido van Rossum98297ee2007-11-06 21:34:58 +0000739 self.assertEqual(b, b"")
740 self.assertEqual(c, b"")
741 self.assert_(b is not c)
742 b += b"!"
743 self.assertEqual(c, b"")
Guido van Rossum254348e2007-11-21 19:29:53 +0000744 c, b, a = bytearray(b"x").rpartition(b"y")
Guido van Rossum98297ee2007-11-06 21:34:58 +0000745 self.assertEqual(b, b"")
746 self.assertEqual(c, b"")
747
748
Christian Heimes510711d2008-01-30 11:57:58 +0000749class AssortedBytesTest(unittest.TestCase):
750 #
751 # Test various combinations of bytes and bytearray
752 #
753
754 def setUp(self):
755 self.warning_filters = warnings.filters[:]
756
757 def tearDown(self):
758 warnings.filters = self.warning_filters
759
760 def test_repr_str(self):
761 warnings.simplefilter('ignore', BytesWarning)
762 for f in str, repr:
763 self.assertEqual(f(bytearray()), "bytearray(b'')")
764 self.assertEqual(f(bytearray([0])), "bytearray(b'\\x00')")
765 self.assertEqual(f(bytearray([0, 1, 254, 255])),
766 "bytearray(b'\\x00\\x01\\xfe\\xff')")
767 self.assertEqual(f(b"abc"), "b'abc'")
768 self.assertEqual(f(b"'"), '''b"'"''') # '''
769 self.assertEqual(f(b"'\""), r"""b'\'"'""") # '
770
771 def test_compare_bytes_to_bytearray(self):
772 self.assertEqual(b"abc" == bytes(b"abc"), True)
773 self.assertEqual(b"ab" != bytes(b"abc"), True)
774 self.assertEqual(b"ab" <= bytes(b"abc"), True)
775 self.assertEqual(b"ab" < bytes(b"abc"), True)
776 self.assertEqual(b"abc" >= bytes(b"ab"), True)
777 self.assertEqual(b"abc" > bytes(b"ab"), True)
778
779 self.assertEqual(b"abc" != bytes(b"abc"), False)
780 self.assertEqual(b"ab" == bytes(b"abc"), False)
781 self.assertEqual(b"ab" > bytes(b"abc"), False)
782 self.assertEqual(b"ab" >= bytes(b"abc"), False)
783 self.assertEqual(b"abc" < bytes(b"ab"), False)
784 self.assertEqual(b"abc" <= bytes(b"ab"), False)
785
786 self.assertEqual(bytes(b"abc") == b"abc", True)
787 self.assertEqual(bytes(b"ab") != b"abc", True)
788 self.assertEqual(bytes(b"ab") <= b"abc", True)
789 self.assertEqual(bytes(b"ab") < b"abc", True)
790 self.assertEqual(bytes(b"abc") >= b"ab", True)
791 self.assertEqual(bytes(b"abc") > b"ab", True)
792
793 self.assertEqual(bytes(b"abc") != b"abc", False)
794 self.assertEqual(bytes(b"ab") == b"abc", False)
795 self.assertEqual(bytes(b"ab") > b"abc", False)
796 self.assertEqual(bytes(b"ab") >= b"abc", False)
797 self.assertEqual(bytes(b"abc") < b"ab", False)
798 self.assertEqual(bytes(b"abc") <= b"ab", False)
799
800 def test_doc(self):
801 self.failUnless(bytearray.__doc__ != None)
802 self.failUnless(bytearray.__doc__.startswith("bytearray("), bytearray.__doc__)
803 self.failUnless(bytes.__doc__ != None)
804 self.failUnless(bytes.__doc__.startswith("bytes("), bytes.__doc__)
805
806 def test_from_bytearray(self):
807 sample = bytes(b"Hello world\n\x80\x81\xfe\xff")
808 buf = memoryview(sample)
809 b = bytearray(buf)
810 self.assertEqual(b, bytearray(sample))
811
812 def test_to_str(self):
813 warnings.simplefilter('ignore', BytesWarning)
814 self.assertEqual(str(b''), "b''")
815 self.assertEqual(str(b'x'), "b'x'")
816 self.assertEqual(str(b'\x80'), "b'\\x80'")
817 self.assertEqual(str(bytearray(b'')), "bytearray(b'')")
818 self.assertEqual(str(bytearray(b'x')), "bytearray(b'x')")
819 self.assertEqual(str(bytearray(b'\x80')), "bytearray(b'\\x80')")
820
821 def test_literal(self):
822 tests = [
823 (b"Wonderful spam", "Wonderful spam"),
824 (br"Wonderful spam too", "Wonderful spam too"),
825 (b"\xaa\x00\000\200", "\xaa\x00\000\200"),
826 (br"\xaa\x00\000\200", r"\xaa\x00\000\200"),
827 ]
828 for b, s in tests:
829 self.assertEqual(b, bytearray(s, 'latin-1'))
830 for c in range(128, 256):
831 self.assertRaises(SyntaxError, eval,
832 'b"%s"' % chr(c))
833
834 def test_translate(self):
835 b = b'hello'
836 rosetta = bytearray(range(0, 256))
837 rosetta[ord('o')] = ord('e')
838 c = b.translate(rosetta, b'l')
839 self.assertEqual(b, b'hello')
840 self.assertEqual(c, b'hee')
841
842 def test_split_bytearray(self):
843 self.assertEqual(b'a b'.split(memoryview(b' ')), [b'a', b'b'])
844
845 def test_rsplit_bytearray(self):
846 self.assertEqual(b'a b'.rsplit(memoryview(b' ')), [b'a', b'b'])
847
Georg Brandleb2c9642008-05-30 12:05:02 +0000848 def test_return_self(self):
849 # bytearray.replace must always return a new bytearray
850 b = bytearray()
851 self.failIf(b.replace(b'', b'') is b)
852
Guido van Rossumd624f182006-04-24 13:47:05 +0000853 # Optimizations:
Guido van Rossume06b6b82006-04-23 07:43:54 +0000854 # __iter__? (optimization)
Guido van Rossumd624f182006-04-24 13:47:05 +0000855 # __reversed__? (optimization)
856
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000857 # XXX More string methods? (Those that don't use character properties)
858
Neal Norwitz6968b052007-02-27 19:02:19 +0000859 # There are tests in string_tests.py that are more
860 # comprehensive for things like split, partition, etc.
861 # Unfortunately they are all bundled with tests that
862 # are not appropriate for bytes
Guido van Rossume06b6b82006-04-23 07:43:54 +0000863
Guido van Rossum254348e2007-11-21 19:29:53 +0000864 # I've started porting some of those into bytearray_tests.py, we should port
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000865 # the rest that make sense (the code can be cleaned up to use modern
866 # unittest methods at the same time).
867
Guido van Rossum254348e2007-11-21 19:29:53 +0000868class BytearrayPEP3137Test(unittest.TestCase,
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000869 test.buffer_tests.MixinBytesBufferCommonTests):
870 def marshal(self, x):
Guido van Rossum254348e2007-11-21 19:29:53 +0000871 return bytearray(x)
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000872
873 def test_returns_new_copy(self):
874 val = self.marshal(b'1234')
875 # On immutable types these MAY return a reference to themselves
Guido van Rossum254348e2007-11-21 19:29:53 +0000876 # but on mutable types like bytearray they MUST return a new copy.
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000877 for methname in ('zfill', 'rjust', 'ljust', 'center'):
878 method = getattr(val, methname)
879 newval = method(3)
880 self.assertEqual(val, newval)
881 self.assertTrue(val is not newval,
882 methname+' returned self on a mutable object')
883
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000884
Christian Heimes510711d2008-01-30 11:57:58 +0000885class FixedStringTest(test.string_tests.BaseTest):
Georg Brandlc7885542007-03-06 19:16:20 +0000886
Guido van Rossum9c627722007-08-27 18:31:48 +0000887 def fixtype(self, obj):
888 if isinstance(obj, str):
889 return obj.encode("utf-8")
890 return super().fixtype(obj)
891
Georg Brandlc7885542007-03-06 19:16:20 +0000892 # Currently the bytes containment testing uses a single integer
893 # value. This may not be the final design, but until then the
894 # bytes section with in a bytes containment not valid
895 def test_contains(self):
896 pass
Guido van Rossumcd16bf62007-06-13 18:07:49 +0000897 def test_expandtabs(self):
898 pass
899 def test_upper(self):
900 pass
901 def test_lower(self):
902 pass
Georg Brandlc7885542007-03-06 19:16:20 +0000903
Christian Heimes510711d2008-01-30 11:57:58 +0000904class ByteArrayAsStringTest(FixedStringTest):
905 type2test = bytearray
906
907class BytesAsStringTest(FixedStringTest):
908 type2test = bytes
909
Georg Brandlc7885542007-03-06 19:16:20 +0000910
Guido van Rossum254348e2007-11-21 19:29:53 +0000911class ByteArraySubclass(bytearray):
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000912 pass
913
Guido van Rossum254348e2007-11-21 19:29:53 +0000914class ByteArraySubclassTest(unittest.TestCase):
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000915
916 def test_basic(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000917 self.assert_(issubclass(ByteArraySubclass, bytearray))
918 self.assert_(isinstance(ByteArraySubclass(), bytearray))
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000919
920 a, b = b"abcd", b"efgh"
Guido van Rossum254348e2007-11-21 19:29:53 +0000921 _a, _b = ByteArraySubclass(a), ByteArraySubclass(b)
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000922
923 # test comparison operators with subclass instances
924 self.assert_(_a == _a)
925 self.assert_(_a != _b)
926 self.assert_(_a < _b)
927 self.assert_(_a <= _b)
928 self.assert_(_b >= _a)
929 self.assert_(_b > _a)
930 self.assert_(_a is not a)
931
932 # test concat of subclass instances
933 self.assertEqual(a + b, _a + _b)
934 self.assertEqual(a + b, a + _b)
935 self.assertEqual(a + b, _a + b)
936
937 # test repeat
938 self.assert_(a*5 == _a*5)
939
940 def test_join(self):
941 # Make sure join returns a NEW object for single item sequences
942 # involving a subclass.
943 # Make sure that it is of the appropriate type.
Guido van Rossum254348e2007-11-21 19:29:53 +0000944 s1 = ByteArraySubclass(b"abcd")
945 s2 = bytearray().join([s1])
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000946 self.assert_(s1 is not s2)
Guido van Rossum254348e2007-11-21 19:29:53 +0000947 self.assert_(type(s2) is bytearray, type(s2))
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000948
949 # Test reverse, calling join on subclass
950 s3 = s1.join([b"abcd"])
Guido van Rossum254348e2007-11-21 19:29:53 +0000951 self.assert_(type(s3) is bytearray)
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000952
953 def test_pickle(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000954 a = ByteArraySubclass(b"abcd")
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000955 a.x = 10
Guido van Rossum254348e2007-11-21 19:29:53 +0000956 a.y = ByteArraySubclass(b"efgh")
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000957 for proto in range(pickle.HIGHEST_PROTOCOL):
958 b = pickle.loads(pickle.dumps(a, proto))
959 self.assertNotEqual(id(a), id(b))
960 self.assertEqual(a, b)
961 self.assertEqual(a.x, b.x)
962 self.assertEqual(a.y, b.y)
963 self.assertEqual(type(a), type(b))
964 self.assertEqual(type(a.y), type(b.y))
965
966 def test_copy(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000967 a = ByteArraySubclass(b"abcd")
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000968 a.x = 10
Guido van Rossum254348e2007-11-21 19:29:53 +0000969 a.y = ByteArraySubclass(b"efgh")
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000970 for copy_method in (copy.copy, copy.deepcopy):
971 b = copy_method(a)
972 self.assertNotEqual(id(a), id(b))
973 self.assertEqual(a, b)
974 self.assertEqual(a.x, b.x)
975 self.assertEqual(a.y, b.y)
976 self.assertEqual(type(a), type(b))
977 self.assertEqual(type(a.y), type(b.y))
978
979 def test_init_override(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000980 class subclass(bytearray):
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000981 def __init__(self, newarg=1, *args, **kwargs):
Guido van Rossum254348e2007-11-21 19:29:53 +0000982 bytearray.__init__(self, *args, **kwargs)
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000983 x = subclass(4, source=b"abcd")
984 self.assertEqual(x, b"abcd")
985 x = subclass(newarg=4, source=b"abcd")
986 self.assertEqual(x, b"abcd")
987
988
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000989def test_main():
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000990 test.support.run_unittest(BytesTest)
991 test.support.run_unittest(ByteArrayTest)
992 test.support.run_unittest(AssortedBytesTest)
993 test.support.run_unittest(BytesAsStringTest)
994 test.support.run_unittest(ByteArrayAsStringTest)
995 test.support.run_unittest(ByteArraySubclassTest)
996 test.support.run_unittest(BytearrayPEP3137Test)
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000997
998if __name__ == "__main__":
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000999 test_main()