blob: 630f862a1513d07fcd20d8da1ae8ec201e40b395 [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):
Antoine Pitrou47d305d2008-08-16 23:28:44 +0000457 fd = os.dup(sys.stdin.fileno())
458 with open(fd, "rb", buffering=0) as f:
Antoine Pitrou2f89aa62008-08-02 21:02:48 +0000459 self.assertRaises(TypeError, f.readinto, b"")
460
461
Christian Heimes510711d2008-01-30 11:57:58 +0000462class ByteArrayTest(BaseBytesTest):
463 type2test = bytearray
Guido van Rossumebea9be2007-04-09 00:49:13 +0000464
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000465 def test_nohash(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000466 self.assertRaises(TypeError, hash, bytearray())
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000467
Guido van Rossum254348e2007-11-21 19:29:53 +0000468 def test_bytearray_api(self):
Guido van Rossum75d6f1a2007-05-24 17:52:00 +0000469 short_sample = b"Hello world\n"
Guido van Rossum98297ee2007-11-06 21:34:58 +0000470 sample = short_sample + b"\0"*(20 - len(short_sample))
Guido van Rossumd624f182006-04-24 13:47:05 +0000471 tfn = tempfile.mktemp()
472 try:
473 # Prepare
474 with open(tfn, "wb") as f:
475 f.write(short_sample)
476 # Test readinto
477 with open(tfn, "rb") as f:
Guido van Rossum254348e2007-11-21 19:29:53 +0000478 b = bytearray(20)
Guido van Rossumd624f182006-04-24 13:47:05 +0000479 n = f.readinto(b)
480 self.assertEqual(n, len(short_sample))
Guido van Rossumc1f779c2007-07-03 08:25:58 +0000481 self.assertEqual(list(b), list(sample))
Guido van Rossumd624f182006-04-24 13:47:05 +0000482 # Test writing in binary mode
483 with open(tfn, "wb") as f:
484 f.write(b)
485 with open(tfn, "rb") as f:
486 self.assertEqual(f.read(), sample)
Guido van Rossum13633bb2007-04-13 18:42:35 +0000487 # Text mode is ambiguous; don't test
Guido van Rossumd624f182006-04-24 13:47:05 +0000488 finally:
489 try:
490 os.remove(tfn)
491 except os.error:
492 pass
493
Neal Norwitz6968b052007-02-27 19:02:19 +0000494 def test_reverse(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000495 b = bytearray(b'hello')
Neal Norwitz6968b052007-02-27 19:02:19 +0000496 self.assertEqual(b.reverse(), None)
497 self.assertEqual(b, b'olleh')
Guido van Rossum254348e2007-11-21 19:29:53 +0000498 b = bytearray(b'hello1') # test even number of items
Neal Norwitz6968b052007-02-27 19:02:19 +0000499 b.reverse()
500 self.assertEqual(b, b'1olleh')
Guido van Rossum254348e2007-11-21 19:29:53 +0000501 b = bytearray()
Neal Norwitz6968b052007-02-27 19:02:19 +0000502 b.reverse()
503 self.assertFalse(b)
504
Guido van Rossumd624f182006-04-24 13:47:05 +0000505 def test_regexps(self):
506 def by(s):
Guido van Rossum254348e2007-11-21 19:29:53 +0000507 return bytearray(map(ord, s))
Guido van Rossumd624f182006-04-24 13:47:05 +0000508 b = by("Hello, world")
Antoine Pitroufd036452008-08-19 17:56:33 +0000509 self.assertEqual(re.findall(br"\w+", b), [by("Hello"), by("world")])
Guido van Rossumd624f182006-04-24 13:47:05 +0000510
511 def test_setitem(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000512 b = bytearray([1, 2, 3])
Guido van Rossumd624f182006-04-24 13:47:05 +0000513 b[1] = 100
Guido van Rossum254348e2007-11-21 19:29:53 +0000514 self.assertEqual(b, bytearray([1, 100, 3]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000515 b[-1] = 200
Guido van Rossum254348e2007-11-21 19:29:53 +0000516 self.assertEqual(b, bytearray([1, 100, 200]))
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000517 b[0] = Indexable(10)
Guido van Rossum254348e2007-11-21 19:29:53 +0000518 self.assertEqual(b, bytearray([10, 100, 200]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000519 try:
520 b[3] = 0
521 self.fail("Didn't raise IndexError")
522 except IndexError:
523 pass
524 try:
525 b[-10] = 0
526 self.fail("Didn't raise IndexError")
527 except IndexError:
528 pass
529 try:
530 b[0] = 256
531 self.fail("Didn't raise ValueError")
532 except ValueError:
533 pass
534 try:
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000535 b[0] = Indexable(-1)
Guido van Rossumd624f182006-04-24 13:47:05 +0000536 self.fail("Didn't raise ValueError")
537 except ValueError:
538 pass
539 try:
540 b[0] = None
541 self.fail("Didn't raise TypeError")
542 except TypeError:
543 pass
544
545 def test_delitem(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000546 b = bytearray(range(10))
Guido van Rossumd624f182006-04-24 13:47:05 +0000547 del b[0]
Guido van Rossum254348e2007-11-21 19:29:53 +0000548 self.assertEqual(b, bytearray(range(1, 10)))
Guido van Rossumd624f182006-04-24 13:47:05 +0000549 del b[-1]
Guido van Rossum254348e2007-11-21 19:29:53 +0000550 self.assertEqual(b, bytearray(range(1, 9)))
Guido van Rossumd624f182006-04-24 13:47:05 +0000551 del b[4]
Guido van Rossum254348e2007-11-21 19:29:53 +0000552 self.assertEqual(b, bytearray([1, 2, 3, 4, 6, 7, 8]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000553
554 def test_setslice(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000555 b = bytearray(range(10))
Guido van Rossumd624f182006-04-24 13:47:05 +0000556 self.assertEqual(list(b), list(range(10)))
557
Guido van Rossum254348e2007-11-21 19:29:53 +0000558 b[0:5] = bytearray([1, 1, 1, 1, 1])
559 self.assertEqual(b, bytearray([1, 1, 1, 1, 1, 5, 6, 7, 8, 9]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000560
561 del b[0:-5]
Guido van Rossum254348e2007-11-21 19:29:53 +0000562 self.assertEqual(b, bytearray([5, 6, 7, 8, 9]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000563
Guido van Rossum254348e2007-11-21 19:29:53 +0000564 b[0:0] = bytearray([0, 1, 2, 3, 4])
565 self.assertEqual(b, bytearray(range(10)))
Guido van Rossumd624f182006-04-24 13:47:05 +0000566
Guido van Rossum254348e2007-11-21 19:29:53 +0000567 b[-7:-3] = bytearray([100, 101])
568 self.assertEqual(b, bytearray([0, 1, 2, 100, 101, 7, 8, 9]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000569
570 b[3:5] = [3, 4, 5, 6]
Guido van Rossum254348e2007-11-21 19:29:53 +0000571 self.assertEqual(b, bytearray(range(10)))
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000572
Thomas Wouters9a6e62b2006-08-23 23:20:29 +0000573 b[3:0] = [42, 42, 42]
Guido van Rossum254348e2007-11-21 19:29:53 +0000574 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 +0000575
Thomas Wouters376446d2006-12-19 08:30:14 +0000576 def test_extended_set_del_slice(self):
577 indices = (0, None, 1, 3, 19, 300, -1, -2, -31, -300)
578 for start in indices:
579 for stop in indices:
580 # Skip invalid step 0
581 for step in indices[1:]:
582 L = list(range(255))
Guido van Rossum254348e2007-11-21 19:29:53 +0000583 b = bytearray(L)
Thomas Wouters376446d2006-12-19 08:30:14 +0000584 # Make sure we have a slice of exactly the right length,
585 # but with different data.
586 data = L[start:stop:step]
587 data.reverse()
588 L[start:stop:step] = data
589 b[start:stop:step] = data
Guido van Rossum254348e2007-11-21 19:29:53 +0000590 self.assertEquals(b, bytearray(L))
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000591
Thomas Wouters376446d2006-12-19 08:30:14 +0000592 del L[start:stop:step]
593 del b[start:stop:step]
Guido van Rossum254348e2007-11-21 19:29:53 +0000594 self.assertEquals(b, bytearray(L))
Thomas Wouters376446d2006-12-19 08:30:14 +0000595
Guido van Rossumd624f182006-04-24 13:47:05 +0000596 def test_setslice_trap(self):
597 # This test verifies that we correctly handle assigning self
598 # to a slice of self (the old Lambert Meertens trap).
Guido van Rossum254348e2007-11-21 19:29:53 +0000599 b = bytearray(range(256))
Guido van Rossumd624f182006-04-24 13:47:05 +0000600 b[8:] = b
Guido van Rossum254348e2007-11-21 19:29:53 +0000601 self.assertEqual(b, bytearray(list(range(8)) + list(range(256))))
Guido van Rossumd624f182006-04-24 13:47:05 +0000602
Guido van Rossum13e57212006-04-27 22:54:26 +0000603 def test_iconcat(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000604 b = bytearray(b"abc")
Guido van Rossum13e57212006-04-27 22:54:26 +0000605 b1 = b
Guido van Rossum9c627722007-08-27 18:31:48 +0000606 b += b"def"
607 self.assertEqual(b, b"abcdef")
Guido van Rossum13e57212006-04-27 22:54:26 +0000608 self.assertEqual(b, b1)
609 self.failUnless(b is b1)
Guido van Rossum98297ee2007-11-06 21:34:58 +0000610 b += b"xyz"
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000611 self.assertEqual(b, b"abcdefxyz")
612 try:
Guido van Rossumef87d6e2007-05-02 19:09:54 +0000613 b += ""
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000614 except TypeError:
615 pass
616 else:
617 self.fail("bytes += unicode didn't raise TypeError")
Guido van Rossum13e57212006-04-27 22:54:26 +0000618
619 def test_irepeat(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000620 b = bytearray(b"abc")
Guido van Rossum13e57212006-04-27 22:54:26 +0000621 b1 = b
622 b *= 3
Guido van Rossum9c627722007-08-27 18:31:48 +0000623 self.assertEqual(b, b"abcabcabc")
Guido van Rossum13e57212006-04-27 22:54:26 +0000624 self.assertEqual(b, b1)
625 self.failUnless(b is b1)
626
627 def test_irepeat_1char(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000628 b = bytearray(b"x")
Guido van Rossum13e57212006-04-27 22:54:26 +0000629 b1 = b
630 b *= 100
Guido van Rossum98297ee2007-11-06 21:34:58 +0000631 self.assertEqual(b, b"x"*100)
Guido van Rossum13e57212006-04-27 22:54:26 +0000632 self.assertEqual(b, b1)
633 self.failUnless(b is b1)
634
Guido van Rossum20188312006-05-05 15:15:40 +0000635 def test_alloc(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000636 b = bytearray()
Guido van Rossum20188312006-05-05 15:15:40 +0000637 alloc = b.__alloc__()
638 self.assert_(alloc >= 0)
639 seq = [alloc]
640 for i in range(100):
Guido van Rossum9c627722007-08-27 18:31:48 +0000641 b += b"x"
Guido van Rossum20188312006-05-05 15:15:40 +0000642 alloc = b.__alloc__()
643 self.assert_(alloc >= len(b))
644 if alloc not in seq:
645 seq.append(alloc)
Guido van Rossum20188312006-05-05 15:15:40 +0000646
Neal Norwitz6968b052007-02-27 19:02:19 +0000647 def test_extend(self):
648 orig = b'hello'
Guido van Rossum254348e2007-11-21 19:29:53 +0000649 a = bytearray(orig)
Neal Norwitz6968b052007-02-27 19:02:19 +0000650 a.extend(a)
651 self.assertEqual(a, orig + orig)
652 self.assertEqual(a[5:], orig)
Alexandre Vassalotti09121e82007-12-04 05:51:13 +0000653 a = bytearray(b'')
654 # Test iterators that don't have a __length_hint__
655 a.extend(map(int, orig * 25))
656 a.extend(int(x) for x in orig * 25)
657 self.assertEqual(a, orig * 50)
658 self.assertEqual(a[-5:], orig)
659 a = bytearray(b'')
660 a.extend(iter(map(int, orig * 50)))
661 self.assertEqual(a, orig * 50)
662 self.assertEqual(a[-5:], orig)
663 a = bytearray(b'')
664 a.extend(list(map(int, orig * 50)))
665 self.assertEqual(a, orig * 50)
666 self.assertEqual(a[-5:], orig)
667 a = bytearray(b'')
668 self.assertRaises(ValueError, a.extend, [0, 1, 2, 256])
669 self.assertRaises(ValueError, a.extend, [0, 1, 2, -1])
670 self.assertEqual(len(a), 0)
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000671 a = bytearray(b'')
672 a.extend([Indexable(ord('a'))])
673 self.assertEqual(a, b'a')
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000674
Neal Norwitz6968b052007-02-27 19:02:19 +0000675 def test_remove(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000676 b = bytearray(b'hello')
Neal Norwitz6968b052007-02-27 19:02:19 +0000677 b.remove(ord('l'))
678 self.assertEqual(b, b'helo')
679 b.remove(ord('l'))
680 self.assertEqual(b, b'heo')
681 self.assertRaises(ValueError, lambda: b.remove(ord('l')))
682 self.assertRaises(ValueError, lambda: b.remove(400))
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000683 self.assertRaises(TypeError, lambda: b.remove('e'))
Neal Norwitz6968b052007-02-27 19:02:19 +0000684 # remove first and last
685 b.remove(ord('o'))
686 b.remove(ord('h'))
687 self.assertEqual(b, b'e')
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000688 self.assertRaises(TypeError, lambda: b.remove(b'e'))
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000689 b.remove(Indexable(ord('e')))
690 self.assertEqual(b, b'')
Neal Norwitz6968b052007-02-27 19:02:19 +0000691
692 def test_pop(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000693 b = bytearray(b'world')
Neal Norwitz6968b052007-02-27 19:02:19 +0000694 self.assertEqual(b.pop(), ord('d'))
695 self.assertEqual(b.pop(0), ord('w'))
696 self.assertEqual(b.pop(-2), ord('r'))
697 self.assertRaises(IndexError, lambda: b.pop(10))
Guido van Rossum254348e2007-11-21 19:29:53 +0000698 self.assertRaises(OverflowError, lambda: bytearray().pop())
Neal Norwitz6968b052007-02-27 19:02:19 +0000699
700 def test_nosort(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000701 self.assertRaises(AttributeError, lambda: bytearray().sort())
Neal Norwitz6968b052007-02-27 19:02:19 +0000702
Neal Norwitz6968b052007-02-27 19:02:19 +0000703 def test_append(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000704 b = bytearray(b'hell')
Neal Norwitz6968b052007-02-27 19:02:19 +0000705 b.append(ord('o'))
706 self.assertEqual(b, b'hello')
707 self.assertEqual(b.append(100), None)
Guido van Rossum254348e2007-11-21 19:29:53 +0000708 b = bytearray()
Neal Norwitz6968b052007-02-27 19:02:19 +0000709 b.append(ord('A'))
710 self.assertEqual(len(b), 1)
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000711 self.assertRaises(TypeError, lambda: b.append(b'o'))
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000712 b = bytearray()
713 b.append(Indexable(ord('A')))
714 self.assertEqual(b, b'A')
Neal Norwitz6968b052007-02-27 19:02:19 +0000715
716 def test_insert(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000717 b = bytearray(b'msssspp')
Neal Norwitz6968b052007-02-27 19:02:19 +0000718 b.insert(1, ord('i'))
719 b.insert(4, ord('i'))
720 b.insert(-2, ord('i'))
721 b.insert(1000, ord('i'))
722 self.assertEqual(b, b'mississippi')
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000723 self.assertRaises(TypeError, lambda: b.insert(0, b'1'))
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000724 b = bytearray()
725 b.insert(0, Indexable(ord('A')))
726 self.assertEqual(b, b'A')
Neal Norwitz6968b052007-02-27 19:02:19 +0000727
Guido van Rossum254348e2007-11-21 19:29:53 +0000728 def test_partition_bytearray_doesnt_share_nullstring(self):
729 a, b, c = bytearray(b"x").partition(b"y")
Guido van Rossum98297ee2007-11-06 21:34:58 +0000730 self.assertEqual(b, b"")
731 self.assertEqual(c, b"")
732 self.assert_(b is not c)
733 b += b"!"
734 self.assertEqual(c, b"")
Guido van Rossum254348e2007-11-21 19:29:53 +0000735 a, b, c = bytearray(b"x").partition(b"y")
Guido van Rossum98297ee2007-11-06 21:34:58 +0000736 self.assertEqual(b, b"")
737 self.assertEqual(c, b"")
738 # Same for rpartition
Guido van Rossum254348e2007-11-21 19:29:53 +0000739 b, c, a = bytearray(b"x").rpartition(b"y")
Guido van Rossum98297ee2007-11-06 21:34:58 +0000740 self.assertEqual(b, b"")
741 self.assertEqual(c, b"")
742 self.assert_(b is not c)
743 b += b"!"
744 self.assertEqual(c, b"")
Guido van Rossum254348e2007-11-21 19:29:53 +0000745 c, b, a = bytearray(b"x").rpartition(b"y")
Guido van Rossum98297ee2007-11-06 21:34:58 +0000746 self.assertEqual(b, b"")
747 self.assertEqual(c, b"")
748
749
Christian Heimes510711d2008-01-30 11:57:58 +0000750class AssortedBytesTest(unittest.TestCase):
751 #
752 # Test various combinations of bytes and bytearray
753 #
754
755 def setUp(self):
756 self.warning_filters = warnings.filters[:]
757
758 def tearDown(self):
759 warnings.filters = self.warning_filters
760
761 def test_repr_str(self):
762 warnings.simplefilter('ignore', BytesWarning)
763 for f in str, repr:
764 self.assertEqual(f(bytearray()), "bytearray(b'')")
765 self.assertEqual(f(bytearray([0])), "bytearray(b'\\x00')")
766 self.assertEqual(f(bytearray([0, 1, 254, 255])),
767 "bytearray(b'\\x00\\x01\\xfe\\xff')")
768 self.assertEqual(f(b"abc"), "b'abc'")
769 self.assertEqual(f(b"'"), '''b"'"''') # '''
770 self.assertEqual(f(b"'\""), r"""b'\'"'""") # '
771
772 def test_compare_bytes_to_bytearray(self):
773 self.assertEqual(b"abc" == 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"ab" < bytes(b"abc"), True)
777 self.assertEqual(b"abc" >= bytes(b"ab"), True)
778 self.assertEqual(b"abc" > bytes(b"ab"), True)
779
780 self.assertEqual(b"abc" != 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"ab" >= bytes(b"abc"), False)
784 self.assertEqual(b"abc" < bytes(b"ab"), False)
785 self.assertEqual(b"abc" <= bytes(b"ab"), False)
786
787 self.assertEqual(bytes(b"abc") == 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"ab") < b"abc", True)
791 self.assertEqual(bytes(b"abc") >= b"ab", True)
792 self.assertEqual(bytes(b"abc") > b"ab", True)
793
794 self.assertEqual(bytes(b"abc") != 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"ab") >= b"abc", False)
798 self.assertEqual(bytes(b"abc") < b"ab", False)
799 self.assertEqual(bytes(b"abc") <= b"ab", False)
800
801 def test_doc(self):
802 self.failUnless(bytearray.__doc__ != None)
803 self.failUnless(bytearray.__doc__.startswith("bytearray("), bytearray.__doc__)
804 self.failUnless(bytes.__doc__ != None)
805 self.failUnless(bytes.__doc__.startswith("bytes("), bytes.__doc__)
806
807 def test_from_bytearray(self):
808 sample = bytes(b"Hello world\n\x80\x81\xfe\xff")
809 buf = memoryview(sample)
810 b = bytearray(buf)
811 self.assertEqual(b, bytearray(sample))
812
813 def test_to_str(self):
814 warnings.simplefilter('ignore', BytesWarning)
815 self.assertEqual(str(b''), "b''")
816 self.assertEqual(str(b'x'), "b'x'")
817 self.assertEqual(str(b'\x80'), "b'\\x80'")
818 self.assertEqual(str(bytearray(b'')), "bytearray(b'')")
819 self.assertEqual(str(bytearray(b'x')), "bytearray(b'x')")
820 self.assertEqual(str(bytearray(b'\x80')), "bytearray(b'\\x80')")
821
822 def test_literal(self):
823 tests = [
824 (b"Wonderful spam", "Wonderful spam"),
825 (br"Wonderful spam too", "Wonderful spam too"),
826 (b"\xaa\x00\000\200", "\xaa\x00\000\200"),
827 (br"\xaa\x00\000\200", r"\xaa\x00\000\200"),
828 ]
829 for b, s in tests:
830 self.assertEqual(b, bytearray(s, 'latin-1'))
831 for c in range(128, 256):
832 self.assertRaises(SyntaxError, eval,
833 'b"%s"' % chr(c))
834
835 def test_translate(self):
836 b = b'hello'
837 rosetta = bytearray(range(0, 256))
838 rosetta[ord('o')] = ord('e')
839 c = b.translate(rosetta, b'l')
840 self.assertEqual(b, b'hello')
841 self.assertEqual(c, b'hee')
842
843 def test_split_bytearray(self):
844 self.assertEqual(b'a b'.split(memoryview(b' ')), [b'a', b'b'])
845
846 def test_rsplit_bytearray(self):
847 self.assertEqual(b'a b'.rsplit(memoryview(b' ')), [b'a', b'b'])
848
Georg Brandleb2c9642008-05-30 12:05:02 +0000849 def test_return_self(self):
850 # bytearray.replace must always return a new bytearray
851 b = bytearray()
852 self.failIf(b.replace(b'', b'') is b)
853
Guido van Rossumd624f182006-04-24 13:47:05 +0000854 # Optimizations:
Guido van Rossume06b6b82006-04-23 07:43:54 +0000855 # __iter__? (optimization)
Guido van Rossumd624f182006-04-24 13:47:05 +0000856 # __reversed__? (optimization)
857
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000858 # XXX More string methods? (Those that don't use character properties)
859
Neal Norwitz6968b052007-02-27 19:02:19 +0000860 # There are tests in string_tests.py that are more
861 # comprehensive for things like split, partition, etc.
862 # Unfortunately they are all bundled with tests that
863 # are not appropriate for bytes
Guido van Rossume06b6b82006-04-23 07:43:54 +0000864
Guido van Rossum254348e2007-11-21 19:29:53 +0000865 # I've started porting some of those into bytearray_tests.py, we should port
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000866 # the rest that make sense (the code can be cleaned up to use modern
867 # unittest methods at the same time).
868
Guido van Rossum254348e2007-11-21 19:29:53 +0000869class BytearrayPEP3137Test(unittest.TestCase,
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000870 test.buffer_tests.MixinBytesBufferCommonTests):
871 def marshal(self, x):
Guido van Rossum254348e2007-11-21 19:29:53 +0000872 return bytearray(x)
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000873
874 def test_returns_new_copy(self):
875 val = self.marshal(b'1234')
876 # On immutable types these MAY return a reference to themselves
Guido van Rossum254348e2007-11-21 19:29:53 +0000877 # but on mutable types like bytearray they MUST return a new copy.
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000878 for methname in ('zfill', 'rjust', 'ljust', 'center'):
879 method = getattr(val, methname)
880 newval = method(3)
881 self.assertEqual(val, newval)
882 self.assertTrue(val is not newval,
883 methname+' returned self on a mutable object')
884
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000885
Christian Heimes510711d2008-01-30 11:57:58 +0000886class FixedStringTest(test.string_tests.BaseTest):
Georg Brandlc7885542007-03-06 19:16:20 +0000887
Guido van Rossum9c627722007-08-27 18:31:48 +0000888 def fixtype(self, obj):
889 if isinstance(obj, str):
890 return obj.encode("utf-8")
891 return super().fixtype(obj)
892
Georg Brandlc7885542007-03-06 19:16:20 +0000893 # Currently the bytes containment testing uses a single integer
894 # value. This may not be the final design, but until then the
895 # bytes section with in a bytes containment not valid
896 def test_contains(self):
897 pass
Guido van Rossumcd16bf62007-06-13 18:07:49 +0000898 def test_expandtabs(self):
899 pass
900 def test_upper(self):
901 pass
902 def test_lower(self):
903 pass
Georg Brandlc7885542007-03-06 19:16:20 +0000904
Christian Heimes510711d2008-01-30 11:57:58 +0000905class ByteArrayAsStringTest(FixedStringTest):
906 type2test = bytearray
907
908class BytesAsStringTest(FixedStringTest):
909 type2test = bytes
910
Georg Brandlc7885542007-03-06 19:16:20 +0000911
Guido van Rossum254348e2007-11-21 19:29:53 +0000912class ByteArraySubclass(bytearray):
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000913 pass
914
Guido van Rossum254348e2007-11-21 19:29:53 +0000915class ByteArraySubclassTest(unittest.TestCase):
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000916
917 def test_basic(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000918 self.assert_(issubclass(ByteArraySubclass, bytearray))
919 self.assert_(isinstance(ByteArraySubclass(), bytearray))
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000920
921 a, b = b"abcd", b"efgh"
Guido van Rossum254348e2007-11-21 19:29:53 +0000922 _a, _b = ByteArraySubclass(a), ByteArraySubclass(b)
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000923
924 # test comparison operators with subclass instances
925 self.assert_(_a == _a)
926 self.assert_(_a != _b)
927 self.assert_(_a < _b)
928 self.assert_(_a <= _b)
929 self.assert_(_b >= _a)
930 self.assert_(_b > _a)
931 self.assert_(_a is not a)
932
933 # test concat of subclass instances
934 self.assertEqual(a + b, _a + _b)
935 self.assertEqual(a + b, a + _b)
936 self.assertEqual(a + b, _a + b)
937
938 # test repeat
939 self.assert_(a*5 == _a*5)
940
941 def test_join(self):
942 # Make sure join returns a NEW object for single item sequences
943 # involving a subclass.
944 # Make sure that it is of the appropriate type.
Guido van Rossum254348e2007-11-21 19:29:53 +0000945 s1 = ByteArraySubclass(b"abcd")
946 s2 = bytearray().join([s1])
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000947 self.assert_(s1 is not s2)
Guido van Rossum254348e2007-11-21 19:29:53 +0000948 self.assert_(type(s2) is bytearray, type(s2))
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000949
950 # Test reverse, calling join on subclass
951 s3 = s1.join([b"abcd"])
Guido van Rossum254348e2007-11-21 19:29:53 +0000952 self.assert_(type(s3) is bytearray)
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000953
954 def test_pickle(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000955 a = ByteArraySubclass(b"abcd")
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000956 a.x = 10
Guido van Rossum254348e2007-11-21 19:29:53 +0000957 a.y = ByteArraySubclass(b"efgh")
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000958 for proto in range(pickle.HIGHEST_PROTOCOL):
959 b = pickle.loads(pickle.dumps(a, proto))
960 self.assertNotEqual(id(a), id(b))
961 self.assertEqual(a, b)
962 self.assertEqual(a.x, b.x)
963 self.assertEqual(a.y, b.y)
964 self.assertEqual(type(a), type(b))
965 self.assertEqual(type(a.y), type(b.y))
966
967 def test_copy(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000968 a = ByteArraySubclass(b"abcd")
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000969 a.x = 10
Guido van Rossum254348e2007-11-21 19:29:53 +0000970 a.y = ByteArraySubclass(b"efgh")
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000971 for copy_method in (copy.copy, copy.deepcopy):
972 b = copy_method(a)
973 self.assertNotEqual(id(a), id(b))
974 self.assertEqual(a, b)
975 self.assertEqual(a.x, b.x)
976 self.assertEqual(a.y, b.y)
977 self.assertEqual(type(a), type(b))
978 self.assertEqual(type(a.y), type(b.y))
979
980 def test_init_override(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000981 class subclass(bytearray):
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000982 def __init__(self, newarg=1, *args, **kwargs):
Guido van Rossum254348e2007-11-21 19:29:53 +0000983 bytearray.__init__(self, *args, **kwargs)
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000984 x = subclass(4, source=b"abcd")
985 self.assertEqual(x, b"abcd")
986 x = subclass(newarg=4, source=b"abcd")
987 self.assertEqual(x, b"abcd")
988
989
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000990def test_main():
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000991 test.support.run_unittest(BytesTest)
992 test.support.run_unittest(ByteArrayTest)
993 test.support.run_unittest(AssortedBytesTest)
994 test.support.run_unittest(BytesAsStringTest)
995 test.support.run_unittest(ByteArrayAsStringTest)
996 test.support.run_unittest(ByteArraySubclassTest)
997 test.support.run_unittest(BytearrayPEP3137Test)
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000998
999if __name__ == "__main__":
Guido van Rossuma6c04be2007-11-03 00:24:24 +00001000 test_main()