blob: c3681437d54c79c5fc1b57072a1e886b8160b8f5 [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
Barry Warsaw9e9dcd62008-10-17 01:50:37 +000012import operator
Guido van Rossum0ad08122007-04-11 04:37:43 +000013import pickle
Guido van Rossumd624f182006-04-24 13:47:05 +000014import tempfile
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000015import unittest
Guido van Rossum98297ee2007-11-06 21:34:58 +000016import warnings
Benjamin Petersonee8712c2008-05-20 21:35:26 +000017import test.support
Georg Brandlc7885542007-03-06 19:16:20 +000018import test.string_tests
Gregory P. Smith60d241f2007-10-16 06:31:30 +000019import test.buffer_tests
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000020
Georg Brandl9a54d7c2008-07-16 23:15:30 +000021class Indexable:
22 def __init__(self, value=0):
23 self.value = value
24 def __index__(self):
25 return self.value
26
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000027
Christian Heimes510711d2008-01-30 11:57:58 +000028class BaseBytesTest(unittest.TestCase):
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000029
Guido van Rossum98297ee2007-11-06 21:34:58 +000030 def setUp(self):
31 self.warning_filters = warnings.filters[:]
32
33 def tearDown(self):
34 warnings.filters = self.warning_filters
35
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000036 def test_basics(self):
Christian Heimes510711d2008-01-30 11:57:58 +000037 b = self.type2test()
38 self.assertEqual(type(b), self.type2test)
39 self.assertEqual(b.__class__, self.type2test)
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000040
41 def test_empty_sequence(self):
Christian Heimes510711d2008-01-30 11:57:58 +000042 b = self.type2test()
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000043 self.assertEqual(len(b), 0)
44 self.assertRaises(IndexError, lambda: b[0])
45 self.assertRaises(IndexError, lambda: b[1])
Christian Heimesa37d4c62007-12-04 23:02:19 +000046 self.assertRaises(IndexError, lambda: b[sys.maxsize])
47 self.assertRaises(IndexError, lambda: b[sys.maxsize+1])
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000048 self.assertRaises(IndexError, lambda: b[10**100])
49 self.assertRaises(IndexError, lambda: b[-1])
50 self.assertRaises(IndexError, lambda: b[-2])
Christian Heimesa37d4c62007-12-04 23:02:19 +000051 self.assertRaises(IndexError, lambda: b[-sys.maxsize])
52 self.assertRaises(IndexError, lambda: b[-sys.maxsize-1])
53 self.assertRaises(IndexError, lambda: b[-sys.maxsize-2])
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000054 self.assertRaises(IndexError, lambda: b[-10**100])
55
56 def test_from_list(self):
57 ints = list(range(256))
Christian Heimes510711d2008-01-30 11:57:58 +000058 b = self.type2test(i for i in ints)
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000059 self.assertEqual(len(b), 256)
60 self.assertEqual(list(b), ints)
61
62 def test_from_index(self):
Georg Brandl9a54d7c2008-07-16 23:15:30 +000063 b = self.type2test([Indexable(), Indexable(1), Indexable(254),
64 Indexable(255)])
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000065 self.assertEqual(list(b), [0, 1, 254, 255])
Georg Brandl9a54d7c2008-07-16 23:15:30 +000066 self.assertRaises(ValueError, bytearray, [Indexable(-1)])
67 self.assertRaises(ValueError, bytearray, [Indexable(256)])
Guido van Rossum98297ee2007-11-06 21:34:58 +000068
69 def test_from_ssize(self):
Guido van Rossum254348e2007-11-21 19:29:53 +000070 self.assertEqual(bytearray(0), b'')
71 self.assertEqual(bytearray(1), b'\x00')
72 self.assertEqual(bytearray(5), b'\x00\x00\x00\x00\x00')
73 self.assertRaises(ValueError, bytearray, -1)
Guido van Rossum98297ee2007-11-06 21:34:58 +000074
Guido van Rossum254348e2007-11-21 19:29:53 +000075 self.assertEqual(bytearray('0', 'ascii'), b'0')
76 self.assertEqual(bytearray(b'0'), b'0')
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000077
78 def test_constructor_type_errors(self):
Christian Heimes510711d2008-01-30 11:57:58 +000079 self.assertRaises(TypeError, self.type2test, 0.0)
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000080 class C:
81 pass
Christian Heimes510711d2008-01-30 11:57:58 +000082 self.assertRaises(TypeError, self.type2test, ["0"])
83 self.assertRaises(TypeError, self.type2test, [0.0])
84 self.assertRaises(TypeError, self.type2test, [None])
85 self.assertRaises(TypeError, self.type2test, [C()])
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000086
87 def test_constructor_value_errors(self):
Christian Heimes510711d2008-01-30 11:57:58 +000088 self.assertRaises(ValueError, self.type2test, [-1])
89 self.assertRaises(ValueError, self.type2test, [-sys.maxsize])
90 self.assertRaises(ValueError, self.type2test, [-sys.maxsize-1])
91 self.assertRaises(ValueError, self.type2test, [-sys.maxsize-2])
92 self.assertRaises(ValueError, self.type2test, [-10**100])
93 self.assertRaises(ValueError, self.type2test, [256])
94 self.assertRaises(ValueError, self.type2test, [257])
95 self.assertRaises(ValueError, self.type2test, [sys.maxsize])
96 self.assertRaises(ValueError, self.type2test, [sys.maxsize+1])
97 self.assertRaises(ValueError, self.type2test, [10**100])
Guido van Rossum4dfe8a12006-04-22 23:28:04 +000098
99 def test_compare(self):
Christian Heimes510711d2008-01-30 11:57:58 +0000100 b1 = self.type2test([1, 2, 3])
101 b2 = self.type2test([1, 2, 3])
102 b3 = self.type2test([1, 3])
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000103
Guido van Rossume61fd5b2007-07-11 12:20:59 +0000104 self.assertEqual(b1, b2)
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000105 self.failUnless(b2 != b3)
106 self.failUnless(b1 <= b2)
107 self.failUnless(b1 <= b3)
108 self.failUnless(b1 < b3)
109 self.failUnless(b1 >= b2)
110 self.failUnless(b3 >= b2)
111 self.failUnless(b3 > b2)
112
113 self.failIf(b1 != b2)
114 self.failIf(b2 == b3)
115 self.failIf(b1 > b2)
116 self.failIf(b1 > b3)
117 self.failIf(b1 >= b3)
118 self.failIf(b1 < b2)
119 self.failIf(b3 < b2)
120 self.failIf(b3 <= b2)
121
Guido van Rossum343e97f2007-04-09 00:43:24 +0000122 def test_compare_to_str(self):
Guido van Rossum98297ee2007-11-06 21:34:58 +0000123 warnings.simplefilter('ignore', BytesWarning)
Guido van Rossum1e35e762007-10-09 17:21:10 +0000124 # Byte comparisons with unicode should always fail!
Guido van Rossumebea9be2007-04-09 00:49:13 +0000125 # Test this for all expected byte orders and Unicode character sizes
Christian Heimes510711d2008-01-30 11:57:58 +0000126 self.assertEqual(self.type2test(b"\0a\0b\0c") == "abc", False)
127 self.assertEqual(self.type2test(b"\0\0\0a\0\0\0b\0\0\0c") == "abc", False)
128 self.assertEqual(self.type2test(b"a\0b\0c\0") == "abc", False)
129 self.assertEqual(self.type2test(b"a\0\0\0b\0\0\0c\0\0\0") == "abc", False)
130 self.assertEqual(self.type2test() == str(), False)
131 self.assertEqual(self.type2test() != str(), True)
132
133 def test_reversed(self):
134 input = list(map(ord, "Hello"))
135 b = self.type2test(input)
136 output = list(reversed(b))
137 input.reverse()
138 self.assertEqual(output, input)
139
140 def test_getslice(self):
141 def by(s):
142 return self.type2test(map(ord, s))
143 b = by("Hello, world")
144
145 self.assertEqual(b[:5], by("Hello"))
146 self.assertEqual(b[1:5], by("ello"))
147 self.assertEqual(b[5:7], by(", "))
148 self.assertEqual(b[7:], by("world"))
149 self.assertEqual(b[7:12], by("world"))
150 self.assertEqual(b[7:100], by("world"))
151
152 self.assertEqual(b[:-7], by("Hello"))
153 self.assertEqual(b[-11:-7], by("ello"))
154 self.assertEqual(b[-7:-5], by(", "))
155 self.assertEqual(b[-5:], by("world"))
156 self.assertEqual(b[-5:12], by("world"))
157 self.assertEqual(b[-5:100], by("world"))
158 self.assertEqual(b[-100:5], by("Hello"))
159
160 def test_extended_getslice(self):
161 # Test extended slicing by comparing with list slicing.
162 L = list(range(255))
163 b = self.type2test(L)
164 indices = (0, None, 1, 3, 19, 100, -1, -2, -31, -100)
165 for start in indices:
166 for stop in indices:
167 # Skip step 0 (invalid)
168 for step in indices[1:]:
169 self.assertEqual(b[start:stop:step], self.type2test(L[start:stop:step]))
170
171 def test_encoding(self):
172 sample = "Hello world\n\u1234\u5678\u9abc\udef0"
173 for enc in ("utf8", "utf16"):
174 b = self.type2test(sample, enc)
175 self.assertEqual(b, self.type2test(sample.encode(enc)))
176 self.assertRaises(UnicodeEncodeError, self.type2test, sample, "latin1")
177 b = self.type2test(sample, "latin1", "ignore")
178 self.assertEqual(b, self.type2test(sample[:-4], "utf-8"))
179
180 def test_decode(self):
181 sample = "Hello world\n\u1234\u5678\u9abc\def0\def0"
182 for enc in ("utf8", "utf16"):
183 b = self.type2test(sample, enc)
184 self.assertEqual(b.decode(enc), sample)
185 sample = "Hello world\n\x80\x81\xfe\xff"
186 b = self.type2test(sample, "latin1")
187 self.assertRaises(UnicodeDecodeError, b.decode, "utf8")
188 self.assertEqual(b.decode("utf8", "ignore"), "Hello world\n")
189
190 def test_from_int(self):
191 b = self.type2test(0)
192 self.assertEqual(b, self.type2test())
193 b = self.type2test(10)
194 self.assertEqual(b, self.type2test([0]*10))
195 b = self.type2test(10000)
196 self.assertEqual(b, self.type2test([0]*10000))
197
198 def test_concat(self):
199 b1 = self.type2test(b"abc")
200 b2 = self.type2test(b"def")
201 self.assertEqual(b1 + b2, b"abcdef")
202 self.assertEqual(b1 + bytes(b"def"), b"abcdef")
203 self.assertEqual(bytes(b"def") + b1, b"defabc")
204 self.assertRaises(TypeError, lambda: b1 + "def")
205 self.assertRaises(TypeError, lambda: "abc" + b2)
206
207 def test_repeat(self):
208 for b in b"abc", self.type2test(b"abc"):
209 self.assertEqual(b * 3, b"abcabcabc")
210 self.assertEqual(b * 0, b"")
211 self.assertEqual(b * -1, b"")
212 self.assertRaises(TypeError, lambda: b * 3.14)
213 self.assertRaises(TypeError, lambda: 3.14 * b)
214 # XXX Shouldn't bytes and bytearray agree on what to raise?
215 self.assertRaises((OverflowError, MemoryError),
216 lambda: b * sys.maxsize)
217
218 def test_repeat_1char(self):
219 self.assertEqual(self.type2test(b'x')*100, self.type2test([ord('x')]*100))
220
221 def test_contains(self):
222 b = self.type2test(b"abc")
223 self.failUnless(ord('a') in b)
224 self.failUnless(int(ord('a')) in b)
225 self.failIf(200 in b)
226 self.failIf(200 in b)
227 self.assertRaises(ValueError, lambda: 300 in b)
228 self.assertRaises(ValueError, lambda: -1 in b)
229 self.assertRaises(TypeError, lambda: None in b)
230 self.assertRaises(TypeError, lambda: float(ord('a')) in b)
231 self.assertRaises(TypeError, lambda: "a" in b)
232 for f in bytes, bytearray:
233 self.failUnless(f(b"") in b)
234 self.failUnless(f(b"a") in b)
235 self.failUnless(f(b"b") in b)
236 self.failUnless(f(b"c") in b)
237 self.failUnless(f(b"ab") in b)
238 self.failUnless(f(b"bc") in b)
239 self.failUnless(f(b"abc") in b)
240 self.failIf(f(b"ac") in b)
241 self.failIf(f(b"d") in b)
242 self.failIf(f(b"dab") in b)
243 self.failIf(f(b"abd") in b)
244
245 def test_fromhex(self):
246 self.assertRaises(TypeError, self.type2test.fromhex)
247 self.assertRaises(TypeError, self.type2test.fromhex, 1)
Christian Heimes4f066122008-01-30 15:02:52 +0000248 self.assertEquals(self.type2test.fromhex(''), self.type2test())
Christian Heimes510711d2008-01-30 11:57:58 +0000249 b = bytearray([0x1a, 0x2b, 0x30])
250 self.assertEquals(self.type2test.fromhex('1a2B30'), b)
251 self.assertEquals(self.type2test.fromhex(' 1A 2B 30 '), b)
252 self.assertEquals(self.type2test.fromhex('0000'), b'\0\0')
253 self.assertRaises(TypeError, self.type2test.fromhex, b'1B')
254 self.assertRaises(ValueError, self.type2test.fromhex, 'a')
255 self.assertRaises(ValueError, self.type2test.fromhex, 'rt')
256 self.assertRaises(ValueError, self.type2test.fromhex, '1a b cd')
257 self.assertRaises(ValueError, self.type2test.fromhex, '\x00')
258 self.assertRaises(ValueError, self.type2test.fromhex, '12 \x00 34')
259
260 def test_join(self):
261 self.assertEqual(self.type2test(b"").join([]), b"")
262 self.assertEqual(self.type2test(b"").join([b""]), b"")
263 for lst in [[b"abc"], [b"a", b"bc"], [b"ab", b"c"], [b"a", b"b", b"c"]]:
264 lst = list(map(self.type2test, lst))
265 self.assertEqual(self.type2test(b"").join(lst), b"abc")
266 self.assertEqual(self.type2test(b"").join(tuple(lst)), b"abc")
267 self.assertEqual(self.type2test(b"").join(iter(lst)), b"abc")
268 self.assertEqual(self.type2test(b".").join([b"ab", b"cd"]), b"ab.cd")
269 # XXX more...
270
271 def test_index(self):
272 b = self.type2test(b'parrot')
273 self.assertEqual(b.index('p'), 0)
274 self.assertEqual(b.index('rr'), 2)
275 self.assertEqual(b.index('t'), 5)
276 self.assertRaises(ValueError, lambda: b.index('w'))
277
278 def test_count(self):
279 b = self.type2test(b'mississippi')
280 self.assertEqual(b.count(b'i'), 4)
281 self.assertEqual(b.count(b'ss'), 2)
282 self.assertEqual(b.count(b'w'), 0)
283
284 def test_startswith(self):
285 b = self.type2test(b'hello')
286 self.assertFalse(self.type2test().startswith(b"anything"))
287 self.assertTrue(b.startswith(b"hello"))
288 self.assertTrue(b.startswith(b"hel"))
289 self.assertTrue(b.startswith(b"h"))
290 self.assertFalse(b.startswith(b"hellow"))
291 self.assertFalse(b.startswith(b"ha"))
292
293 def test_endswith(self):
294 b = self.type2test(b'hello')
295 self.assertFalse(bytearray().endswith(b"anything"))
296 self.assertTrue(b.endswith(b"hello"))
297 self.assertTrue(b.endswith(b"llo"))
298 self.assertTrue(b.endswith(b"o"))
299 self.assertFalse(b.endswith(b"whello"))
300 self.assertFalse(b.endswith(b"no"))
301
302 def test_find(self):
303 b = self.type2test(b'mississippi')
304 self.assertEqual(b.find(b'ss'), 2)
305 self.assertEqual(b.find(b'ss', 3), 5)
306 self.assertEqual(b.find(b'ss', 1, 7), 2)
307 self.assertEqual(b.find(b'ss', 1, 3), -1)
308 self.assertEqual(b.find(b'w'), -1)
309 self.assertEqual(b.find(b'mississippian'), -1)
310
311 def test_rfind(self):
312 b = self.type2test(b'mississippi')
313 self.assertEqual(b.rfind(b'ss'), 5)
314 self.assertEqual(b.rfind(b'ss', 3), 5)
315 self.assertEqual(b.rfind(b'ss', 0, 6), 2)
316 self.assertEqual(b.rfind(b'w'), -1)
317 self.assertEqual(b.rfind(b'mississippian'), -1)
318
319 def test_index(self):
320 b = self.type2test(b'world')
321 self.assertEqual(b.index(b'w'), 0)
322 self.assertEqual(b.index(b'orl'), 1)
323 self.assertRaises(ValueError, b.index, b'worm')
324 self.assertRaises(ValueError, b.index, b'ldo')
325
326 def test_rindex(self):
327 # XXX could be more rigorous
328 b = self.type2test(b'world')
329 self.assertEqual(b.rindex(b'w'), 0)
330 self.assertEqual(b.rindex(b'orl'), 1)
331 self.assertRaises(ValueError, b.rindex, b'worm')
332 self.assertRaises(ValueError, b.rindex, b'ldo')
333
334 def test_replace(self):
335 b = self.type2test(b'mississippi')
336 self.assertEqual(b.replace(b'i', b'a'), b'massassappa')
337 self.assertEqual(b.replace(b'ss', b'x'), b'mixixippi')
338
339 def test_split(self):
340 b = self.type2test(b'mississippi')
341 self.assertEqual(b.split(b'i'), [b'm', b'ss', b'ss', b'pp', b''])
342 self.assertEqual(b.split(b'ss'), [b'mi', b'i', b'ippi'])
343 self.assertEqual(b.split(b'w'), [b])
344
345 def test_split_whitespace(self):
346 for b in (b' arf barf ', b'arf\tbarf', b'arf\nbarf', b'arf\rbarf',
347 b'arf\fbarf', b'arf\vbarf'):
348 b = self.type2test(b)
349 self.assertEqual(b.split(), [b'arf', b'barf'])
350 self.assertEqual(b.split(None), [b'arf', b'barf'])
351 self.assertEqual(b.split(None, 2), [b'arf', b'barf'])
352 for b in (b'a\x1Cb', b'a\x1Db', b'a\x1Eb', b'a\x1Fb'):
353 b = self.type2test(b)
354 self.assertEqual(b.split(), [b])
355 self.assertEqual(self.type2test(b' a bb c ').split(None, 0), [b'a bb c '])
356 self.assertEqual(self.type2test(b' a bb c ').split(None, 1), [b'a', b'bb c '])
357 self.assertEqual(self.type2test(b' a bb c ').split(None, 2), [b'a', b'bb', b'c '])
358 self.assertEqual(self.type2test(b' a bb c ').split(None, 3), [b'a', b'bb', b'c'])
359
360 def test_split_string_error(self):
361 self.assertRaises(TypeError, self.type2test(b'a b').split, ' ')
362
363 def test_rsplit(self):
364 b = self.type2test(b'mississippi')
365 self.assertEqual(b.rsplit(b'i'), [b'm', b'ss', b'ss', b'pp', b''])
366 self.assertEqual(b.rsplit(b'ss'), [b'mi', b'i', b'ippi'])
367 self.assertEqual(b.rsplit(b'w'), [b])
368
369 def test_rsplit_whitespace(self):
370 for b in (b' arf barf ', b'arf\tbarf', b'arf\nbarf', b'arf\rbarf',
371 b'arf\fbarf', b'arf\vbarf'):
372 b = self.type2test(b)
373 self.assertEqual(b.rsplit(), [b'arf', b'barf'])
374 self.assertEqual(b.rsplit(None), [b'arf', b'barf'])
375 self.assertEqual(b.rsplit(None, 2), [b'arf', b'barf'])
376 self.assertEqual(self.type2test(b' a bb c ').rsplit(None, 0), [b' a bb c'])
377 self.assertEqual(self.type2test(b' a bb c ').rsplit(None, 1), [b' a bb', b'c'])
378 self.assertEqual(self.type2test(b' a bb c ').rsplit(None, 2), [b' a', b'bb', b'c'])
379 self.assertEqual(self.type2test(b' a bb c ').rsplit(None, 3), [b'a', b'bb', b'c'])
380
381 def test_rsplit_string_error(self):
382 self.assertRaises(TypeError, self.type2test(b'a b').rsplit, ' ')
383
384 def test_rsplit_unicodewhitespace(self):
385 b = self.type2test(b"\x09\x0A\x0B\x0C\x0D\x1C\x1D\x1E\x1F")
386 self.assertEqual(b.split(), [b'\x1c\x1d\x1e\x1f'])
387 self.assertEqual(b.rsplit(), [b'\x1c\x1d\x1e\x1f'])
388
389 def test_partition(self):
390 b = self.type2test(b'mississippi')
391 self.assertEqual(b.partition(b'ss'), (b'mi', b'ss', b'issippi'))
392 self.assertEqual(b.rpartition(b'w'), (b'', b'', b'mississippi'))
393
394 def test_rpartition(self):
395 b = self.type2test(b'mississippi')
396 self.assertEqual(b.rpartition(b'ss'), (b'missi', b'ss', b'ippi'))
397 self.assertEqual(b.rpartition(b'i'), (b'mississipp', b'i', b''))
398
399 def test_pickling(self):
400 for proto in range(pickle.HIGHEST_PROTOCOL):
401 for b in b"", b"a", b"abc", b"\xffab\x80", b"\0\0\377\0\0":
402 b = self.type2test(b)
403 ps = pickle.dumps(b, proto)
404 q = pickle.loads(ps)
405 self.assertEqual(b, q)
406
407 def test_strip(self):
408 b = self.type2test(b'mississippi')
409 self.assertEqual(b.strip(b'i'), b'mississipp')
410 self.assertEqual(b.strip(b'm'), b'ississippi')
411 self.assertEqual(b.strip(b'pi'), b'mississ')
412 self.assertEqual(b.strip(b'im'), b'ssissipp')
413 self.assertEqual(b.strip(b'pim'), b'ssiss')
414 self.assertEqual(b.strip(b), b'')
415
416 def test_lstrip(self):
417 b = self.type2test(b'mississippi')
418 self.assertEqual(b.lstrip(b'i'), b'mississippi')
419 self.assertEqual(b.lstrip(b'm'), b'ississippi')
420 self.assertEqual(b.lstrip(b'pi'), b'mississippi')
421 self.assertEqual(b.lstrip(b'im'), b'ssissippi')
422 self.assertEqual(b.lstrip(b'pim'), b'ssissippi')
423
424 def test_rstrip(self):
425 b = self.type2test(b'mississippi')
426 self.assertEqual(b.rstrip(b'i'), b'mississipp')
427 self.assertEqual(b.rstrip(b'm'), b'mississippi')
428 self.assertEqual(b.rstrip(b'pi'), b'mississ')
429 self.assertEqual(b.rstrip(b'im'), b'mississipp')
430 self.assertEqual(b.rstrip(b'pim'), b'mississ')
431
432 def test_strip_whitespace(self):
433 b = self.type2test(b' \t\n\r\f\vabc \t\n\r\f\v')
434 self.assertEqual(b.strip(), b'abc')
435 self.assertEqual(b.lstrip(), b'abc \t\n\r\f\v')
436 self.assertEqual(b.rstrip(), b' \t\n\r\f\vabc')
437
438 def test_strip_bytearray(self):
439 self.assertEqual(self.type2test(b'abc').strip(memoryview(b'ac')), b'b')
440 self.assertEqual(self.type2test(b'abc').lstrip(memoryview(b'ac')), b'bc')
441 self.assertEqual(self.type2test(b'abc').rstrip(memoryview(b'ac')), b'ab')
442
443 def test_strip_string_error(self):
444 self.assertRaises(TypeError, self.type2test(b'abc').strip, 'b')
445 self.assertRaises(TypeError, self.type2test(b'abc').lstrip, 'b')
446 self.assertRaises(TypeError, self.type2test(b'abc').rstrip, 'b')
447
448 def test_ord(self):
449 b = self.type2test(b'\0A\x7f\x80\xff')
450 self.assertEqual([ord(b[i:i+1]) for i in range(len(b))],
451 [0, 65, 127, 128, 255])
452
453
454class BytesTest(BaseBytesTest):
455 type2test = bytes
456
Antoine Pitrou2f89aa62008-08-02 21:02:48 +0000457 def test_buffer_is_readonly(self):
Antoine Pitrou47d305d2008-08-16 23:28:44 +0000458 fd = os.dup(sys.stdin.fileno())
459 with open(fd, "rb", buffering=0) as f:
Antoine Pitrou2f89aa62008-08-02 21:02:48 +0000460 self.assertRaises(TypeError, f.readinto, b"")
461
Benjamin Petersonc15a0732008-08-26 16:46:47 +0000462 def test_custom(self):
463 class A:
464 def __bytes__(self):
465 return b'abc'
466 self.assertEqual(bytes(A()), b'abc')
467 class A: pass
468 self.assertRaises(TypeError, bytes, A())
469 class A:
470 def __bytes__(self):
471 return None
472 self.assertRaises(TypeError, bytes, A())
473
Antoine Pitrou2f89aa62008-08-02 21:02:48 +0000474
Christian Heimes510711d2008-01-30 11:57:58 +0000475class ByteArrayTest(BaseBytesTest):
476 type2test = bytearray
Guido van Rossumebea9be2007-04-09 00:49:13 +0000477
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000478 def test_nohash(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000479 self.assertRaises(TypeError, hash, bytearray())
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000480
Guido van Rossum254348e2007-11-21 19:29:53 +0000481 def test_bytearray_api(self):
Guido van Rossum75d6f1a2007-05-24 17:52:00 +0000482 short_sample = b"Hello world\n"
Guido van Rossum98297ee2007-11-06 21:34:58 +0000483 sample = short_sample + b"\0"*(20 - len(short_sample))
Guido van Rossumd624f182006-04-24 13:47:05 +0000484 tfn = tempfile.mktemp()
485 try:
486 # Prepare
487 with open(tfn, "wb") as f:
488 f.write(short_sample)
489 # Test readinto
490 with open(tfn, "rb") as f:
Guido van Rossum254348e2007-11-21 19:29:53 +0000491 b = bytearray(20)
Guido van Rossumd624f182006-04-24 13:47:05 +0000492 n = f.readinto(b)
493 self.assertEqual(n, len(short_sample))
Guido van Rossumc1f779c2007-07-03 08:25:58 +0000494 self.assertEqual(list(b), list(sample))
Guido van Rossumd624f182006-04-24 13:47:05 +0000495 # Test writing in binary mode
496 with open(tfn, "wb") as f:
497 f.write(b)
498 with open(tfn, "rb") as f:
499 self.assertEqual(f.read(), sample)
Guido van Rossum13633bb2007-04-13 18:42:35 +0000500 # Text mode is ambiguous; don't test
Guido van Rossumd624f182006-04-24 13:47:05 +0000501 finally:
502 try:
503 os.remove(tfn)
504 except os.error:
505 pass
506
Neal Norwitz6968b052007-02-27 19:02:19 +0000507 def test_reverse(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000508 b = bytearray(b'hello')
Neal Norwitz6968b052007-02-27 19:02:19 +0000509 self.assertEqual(b.reverse(), None)
510 self.assertEqual(b, b'olleh')
Guido van Rossum254348e2007-11-21 19:29:53 +0000511 b = bytearray(b'hello1') # test even number of items
Neal Norwitz6968b052007-02-27 19:02:19 +0000512 b.reverse()
513 self.assertEqual(b, b'1olleh')
Guido van Rossum254348e2007-11-21 19:29:53 +0000514 b = bytearray()
Neal Norwitz6968b052007-02-27 19:02:19 +0000515 b.reverse()
516 self.assertFalse(b)
517
Guido van Rossumd624f182006-04-24 13:47:05 +0000518 def test_regexps(self):
519 def by(s):
Guido van Rossum254348e2007-11-21 19:29:53 +0000520 return bytearray(map(ord, s))
Guido van Rossumd624f182006-04-24 13:47:05 +0000521 b = by("Hello, world")
Antoine Pitroufd036452008-08-19 17:56:33 +0000522 self.assertEqual(re.findall(br"\w+", b), [by("Hello"), by("world")])
Guido van Rossumd624f182006-04-24 13:47:05 +0000523
524 def test_setitem(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000525 b = bytearray([1, 2, 3])
Guido van Rossumd624f182006-04-24 13:47:05 +0000526 b[1] = 100
Guido van Rossum254348e2007-11-21 19:29:53 +0000527 self.assertEqual(b, bytearray([1, 100, 3]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000528 b[-1] = 200
Guido van Rossum254348e2007-11-21 19:29:53 +0000529 self.assertEqual(b, bytearray([1, 100, 200]))
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000530 b[0] = Indexable(10)
Guido van Rossum254348e2007-11-21 19:29:53 +0000531 self.assertEqual(b, bytearray([10, 100, 200]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000532 try:
533 b[3] = 0
534 self.fail("Didn't raise IndexError")
535 except IndexError:
536 pass
537 try:
538 b[-10] = 0
539 self.fail("Didn't raise IndexError")
540 except IndexError:
541 pass
542 try:
543 b[0] = 256
544 self.fail("Didn't raise ValueError")
545 except ValueError:
546 pass
547 try:
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000548 b[0] = Indexable(-1)
Guido van Rossumd624f182006-04-24 13:47:05 +0000549 self.fail("Didn't raise ValueError")
550 except ValueError:
551 pass
552 try:
553 b[0] = None
554 self.fail("Didn't raise TypeError")
555 except TypeError:
556 pass
557
558 def test_delitem(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000559 b = bytearray(range(10))
Guido van Rossumd624f182006-04-24 13:47:05 +0000560 del b[0]
Guido van Rossum254348e2007-11-21 19:29:53 +0000561 self.assertEqual(b, bytearray(range(1, 10)))
Guido van Rossumd624f182006-04-24 13:47:05 +0000562 del b[-1]
Guido van Rossum254348e2007-11-21 19:29:53 +0000563 self.assertEqual(b, bytearray(range(1, 9)))
Guido van Rossumd624f182006-04-24 13:47:05 +0000564 del b[4]
Guido van Rossum254348e2007-11-21 19:29:53 +0000565 self.assertEqual(b, bytearray([1, 2, 3, 4, 6, 7, 8]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000566
567 def test_setslice(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000568 b = bytearray(range(10))
Guido van Rossumd624f182006-04-24 13:47:05 +0000569 self.assertEqual(list(b), list(range(10)))
570
Guido van Rossum254348e2007-11-21 19:29:53 +0000571 b[0:5] = bytearray([1, 1, 1, 1, 1])
572 self.assertEqual(b, bytearray([1, 1, 1, 1, 1, 5, 6, 7, 8, 9]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000573
574 del b[0:-5]
Guido van Rossum254348e2007-11-21 19:29:53 +0000575 self.assertEqual(b, bytearray([5, 6, 7, 8, 9]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000576
Guido van Rossum254348e2007-11-21 19:29:53 +0000577 b[0:0] = bytearray([0, 1, 2, 3, 4])
578 self.assertEqual(b, bytearray(range(10)))
Guido van Rossumd624f182006-04-24 13:47:05 +0000579
Guido van Rossum254348e2007-11-21 19:29:53 +0000580 b[-7:-3] = bytearray([100, 101])
581 self.assertEqual(b, bytearray([0, 1, 2, 100, 101, 7, 8, 9]))
Guido van Rossumd624f182006-04-24 13:47:05 +0000582
583 b[3:5] = [3, 4, 5, 6]
Guido van Rossum254348e2007-11-21 19:29:53 +0000584 self.assertEqual(b, bytearray(range(10)))
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000585
Thomas Wouters9a6e62b2006-08-23 23:20:29 +0000586 b[3:0] = [42, 42, 42]
Guido van Rossum254348e2007-11-21 19:29:53 +0000587 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 +0000588
Thomas Wouters376446d2006-12-19 08:30:14 +0000589 def test_extended_set_del_slice(self):
590 indices = (0, None, 1, 3, 19, 300, -1, -2, -31, -300)
591 for start in indices:
592 for stop in indices:
593 # Skip invalid step 0
594 for step in indices[1:]:
595 L = list(range(255))
Guido van Rossum254348e2007-11-21 19:29:53 +0000596 b = bytearray(L)
Thomas Wouters376446d2006-12-19 08:30:14 +0000597 # Make sure we have a slice of exactly the right length,
598 # but with different data.
599 data = L[start:stop:step]
600 data.reverse()
601 L[start:stop:step] = data
602 b[start:stop:step] = data
Guido van Rossum254348e2007-11-21 19:29:53 +0000603 self.assertEquals(b, bytearray(L))
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000604
Thomas Wouters376446d2006-12-19 08:30:14 +0000605 del L[start:stop:step]
606 del b[start:stop:step]
Guido van Rossum254348e2007-11-21 19:29:53 +0000607 self.assertEquals(b, bytearray(L))
Thomas Wouters376446d2006-12-19 08:30:14 +0000608
Guido van Rossumd624f182006-04-24 13:47:05 +0000609 def test_setslice_trap(self):
610 # This test verifies that we correctly handle assigning self
611 # to a slice of self (the old Lambert Meertens trap).
Guido van Rossum254348e2007-11-21 19:29:53 +0000612 b = bytearray(range(256))
Guido van Rossumd624f182006-04-24 13:47:05 +0000613 b[8:] = b
Guido van Rossum254348e2007-11-21 19:29:53 +0000614 self.assertEqual(b, bytearray(list(range(8)) + list(range(256))))
Guido van Rossumd624f182006-04-24 13:47:05 +0000615
Guido van Rossum13e57212006-04-27 22:54:26 +0000616 def test_iconcat(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000617 b = bytearray(b"abc")
Guido van Rossum13e57212006-04-27 22:54:26 +0000618 b1 = b
Guido van Rossum9c627722007-08-27 18:31:48 +0000619 b += b"def"
620 self.assertEqual(b, b"abcdef")
Guido van Rossum13e57212006-04-27 22:54:26 +0000621 self.assertEqual(b, b1)
622 self.failUnless(b is b1)
Guido van Rossum98297ee2007-11-06 21:34:58 +0000623 b += b"xyz"
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000624 self.assertEqual(b, b"abcdefxyz")
625 try:
Guido van Rossumef87d6e2007-05-02 19:09:54 +0000626 b += ""
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000627 except TypeError:
628 pass
629 else:
630 self.fail("bytes += unicode didn't raise TypeError")
Guido van Rossum13e57212006-04-27 22:54:26 +0000631
632 def test_irepeat(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000633 b = bytearray(b"abc")
Guido van Rossum13e57212006-04-27 22:54:26 +0000634 b1 = b
635 b *= 3
Guido van Rossum9c627722007-08-27 18:31:48 +0000636 self.assertEqual(b, b"abcabcabc")
Guido van Rossum13e57212006-04-27 22:54:26 +0000637 self.assertEqual(b, b1)
638 self.failUnless(b is b1)
639
640 def test_irepeat_1char(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000641 b = bytearray(b"x")
Guido van Rossum13e57212006-04-27 22:54:26 +0000642 b1 = b
643 b *= 100
Guido van Rossum98297ee2007-11-06 21:34:58 +0000644 self.assertEqual(b, b"x"*100)
Guido van Rossum13e57212006-04-27 22:54:26 +0000645 self.assertEqual(b, b1)
646 self.failUnless(b is b1)
647
Guido van Rossum20188312006-05-05 15:15:40 +0000648 def test_alloc(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000649 b = bytearray()
Guido van Rossum20188312006-05-05 15:15:40 +0000650 alloc = b.__alloc__()
651 self.assert_(alloc >= 0)
652 seq = [alloc]
653 for i in range(100):
Guido van Rossum9c627722007-08-27 18:31:48 +0000654 b += b"x"
Guido van Rossum20188312006-05-05 15:15:40 +0000655 alloc = b.__alloc__()
656 self.assert_(alloc >= len(b))
657 if alloc not in seq:
658 seq.append(alloc)
Guido van Rossum20188312006-05-05 15:15:40 +0000659
Neal Norwitz6968b052007-02-27 19:02:19 +0000660 def test_extend(self):
661 orig = b'hello'
Guido van Rossum254348e2007-11-21 19:29:53 +0000662 a = bytearray(orig)
Neal Norwitz6968b052007-02-27 19:02:19 +0000663 a.extend(a)
664 self.assertEqual(a, orig + orig)
665 self.assertEqual(a[5:], orig)
Alexandre Vassalotti09121e82007-12-04 05:51:13 +0000666 a = bytearray(b'')
667 # Test iterators that don't have a __length_hint__
668 a.extend(map(int, orig * 25))
669 a.extend(int(x) for x in orig * 25)
670 self.assertEqual(a, orig * 50)
671 self.assertEqual(a[-5:], orig)
672 a = bytearray(b'')
673 a.extend(iter(map(int, orig * 50)))
674 self.assertEqual(a, orig * 50)
675 self.assertEqual(a[-5:], orig)
676 a = bytearray(b'')
677 a.extend(list(map(int, orig * 50)))
678 self.assertEqual(a, orig * 50)
679 self.assertEqual(a[-5:], orig)
680 a = bytearray(b'')
681 self.assertRaises(ValueError, a.extend, [0, 1, 2, 256])
682 self.assertRaises(ValueError, a.extend, [0, 1, 2, -1])
683 self.assertEqual(len(a), 0)
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000684 a = bytearray(b'')
685 a.extend([Indexable(ord('a'))])
686 self.assertEqual(a, b'a')
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000687
Neal Norwitz6968b052007-02-27 19:02:19 +0000688 def test_remove(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000689 b = bytearray(b'hello')
Neal Norwitz6968b052007-02-27 19:02:19 +0000690 b.remove(ord('l'))
691 self.assertEqual(b, b'helo')
692 b.remove(ord('l'))
693 self.assertEqual(b, b'heo')
694 self.assertRaises(ValueError, lambda: b.remove(ord('l')))
695 self.assertRaises(ValueError, lambda: b.remove(400))
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000696 self.assertRaises(TypeError, lambda: b.remove('e'))
Neal Norwitz6968b052007-02-27 19:02:19 +0000697 # remove first and last
698 b.remove(ord('o'))
699 b.remove(ord('h'))
700 self.assertEqual(b, b'e')
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000701 self.assertRaises(TypeError, lambda: b.remove(b'e'))
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000702 b.remove(Indexable(ord('e')))
703 self.assertEqual(b, b'')
Neal Norwitz6968b052007-02-27 19:02:19 +0000704
705 def test_pop(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000706 b = bytearray(b'world')
Neal Norwitz6968b052007-02-27 19:02:19 +0000707 self.assertEqual(b.pop(), ord('d'))
708 self.assertEqual(b.pop(0), ord('w'))
709 self.assertEqual(b.pop(-2), ord('r'))
710 self.assertRaises(IndexError, lambda: b.pop(10))
Guido van Rossum254348e2007-11-21 19:29:53 +0000711 self.assertRaises(OverflowError, lambda: bytearray().pop())
Neal Norwitz6968b052007-02-27 19:02:19 +0000712
713 def test_nosort(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000714 self.assertRaises(AttributeError, lambda: bytearray().sort())
Neal Norwitz6968b052007-02-27 19:02:19 +0000715
Neal Norwitz6968b052007-02-27 19:02:19 +0000716 def test_append(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000717 b = bytearray(b'hell')
Neal Norwitz6968b052007-02-27 19:02:19 +0000718 b.append(ord('o'))
719 self.assertEqual(b, b'hello')
720 self.assertEqual(b.append(100), None)
Guido van Rossum254348e2007-11-21 19:29:53 +0000721 b = bytearray()
Neal Norwitz6968b052007-02-27 19:02:19 +0000722 b.append(ord('A'))
723 self.assertEqual(len(b), 1)
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000724 self.assertRaises(TypeError, lambda: b.append(b'o'))
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000725 b = bytearray()
726 b.append(Indexable(ord('A')))
727 self.assertEqual(b, b'A')
Neal Norwitz6968b052007-02-27 19:02:19 +0000728
729 def test_insert(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000730 b = bytearray(b'msssspp')
Neal Norwitz6968b052007-02-27 19:02:19 +0000731 b.insert(1, ord('i'))
732 b.insert(4, ord('i'))
733 b.insert(-2, ord('i'))
734 b.insert(1000, ord('i'))
735 self.assertEqual(b, b'mississippi')
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000736 self.assertRaises(TypeError, lambda: b.insert(0, b'1'))
Georg Brandl9a54d7c2008-07-16 23:15:30 +0000737 b = bytearray()
738 b.insert(0, Indexable(ord('A')))
739 self.assertEqual(b, b'A')
Neal Norwitz6968b052007-02-27 19:02:19 +0000740
Guido van Rossum254348e2007-11-21 19:29:53 +0000741 def test_partition_bytearray_doesnt_share_nullstring(self):
742 a, b, c = bytearray(b"x").partition(b"y")
Guido van Rossum98297ee2007-11-06 21:34:58 +0000743 self.assertEqual(b, b"")
744 self.assertEqual(c, b"")
745 self.assert_(b is not c)
746 b += b"!"
747 self.assertEqual(c, b"")
Guido van Rossum254348e2007-11-21 19:29:53 +0000748 a, b, c = bytearray(b"x").partition(b"y")
Guido van Rossum98297ee2007-11-06 21:34:58 +0000749 self.assertEqual(b, b"")
750 self.assertEqual(c, b"")
751 # Same for rpartition
Guido van Rossum254348e2007-11-21 19:29:53 +0000752 b, c, a = bytearray(b"x").rpartition(b"y")
Guido van Rossum98297ee2007-11-06 21:34:58 +0000753 self.assertEqual(b, b"")
754 self.assertEqual(c, b"")
755 self.assert_(b is not c)
756 b += b"!"
757 self.assertEqual(c, b"")
Guido van Rossum254348e2007-11-21 19:29:53 +0000758 c, b, a = bytearray(b"x").rpartition(b"y")
Guido van Rossum98297ee2007-11-06 21:34:58 +0000759 self.assertEqual(b, b"")
760 self.assertEqual(c, b"")
761
762
Christian Heimes510711d2008-01-30 11:57:58 +0000763class AssortedBytesTest(unittest.TestCase):
764 #
765 # Test various combinations of bytes and bytearray
766 #
767
768 def setUp(self):
769 self.warning_filters = warnings.filters[:]
770
771 def tearDown(self):
772 warnings.filters = self.warning_filters
773
774 def test_repr_str(self):
775 warnings.simplefilter('ignore', BytesWarning)
776 for f in str, repr:
777 self.assertEqual(f(bytearray()), "bytearray(b'')")
778 self.assertEqual(f(bytearray([0])), "bytearray(b'\\x00')")
779 self.assertEqual(f(bytearray([0, 1, 254, 255])),
780 "bytearray(b'\\x00\\x01\\xfe\\xff')")
781 self.assertEqual(f(b"abc"), "b'abc'")
782 self.assertEqual(f(b"'"), '''b"'"''') # '''
783 self.assertEqual(f(b"'\""), r"""b'\'"'""") # '
784
785 def test_compare_bytes_to_bytearray(self):
786 self.assertEqual(b"abc" == bytes(b"abc"), True)
787 self.assertEqual(b"ab" != bytes(b"abc"), True)
788 self.assertEqual(b"ab" <= bytes(b"abc"), True)
789 self.assertEqual(b"ab" < bytes(b"abc"), True)
790 self.assertEqual(b"abc" >= bytes(b"ab"), True)
791 self.assertEqual(b"abc" > bytes(b"ab"), True)
792
793 self.assertEqual(b"abc" != bytes(b"abc"), False)
794 self.assertEqual(b"ab" == bytes(b"abc"), False)
795 self.assertEqual(b"ab" > bytes(b"abc"), False)
796 self.assertEqual(b"ab" >= bytes(b"abc"), False)
797 self.assertEqual(b"abc" < bytes(b"ab"), False)
798 self.assertEqual(b"abc" <= bytes(b"ab"), False)
799
800 self.assertEqual(bytes(b"abc") == b"abc", True)
801 self.assertEqual(bytes(b"ab") != b"abc", True)
802 self.assertEqual(bytes(b"ab") <= b"abc", True)
803 self.assertEqual(bytes(b"ab") < b"abc", True)
804 self.assertEqual(bytes(b"abc") >= b"ab", True)
805 self.assertEqual(bytes(b"abc") > b"ab", True)
806
807 self.assertEqual(bytes(b"abc") != b"abc", False)
808 self.assertEqual(bytes(b"ab") == b"abc", False)
809 self.assertEqual(bytes(b"ab") > b"abc", False)
810 self.assertEqual(bytes(b"ab") >= b"abc", False)
811 self.assertEqual(bytes(b"abc") < b"ab", False)
812 self.assertEqual(bytes(b"abc") <= b"ab", False)
813
814 def test_doc(self):
815 self.failUnless(bytearray.__doc__ != None)
816 self.failUnless(bytearray.__doc__.startswith("bytearray("), bytearray.__doc__)
817 self.failUnless(bytes.__doc__ != None)
818 self.failUnless(bytes.__doc__.startswith("bytes("), bytes.__doc__)
819
820 def test_from_bytearray(self):
821 sample = bytes(b"Hello world\n\x80\x81\xfe\xff")
822 buf = memoryview(sample)
823 b = bytearray(buf)
824 self.assertEqual(b, bytearray(sample))
825
826 def test_to_str(self):
827 warnings.simplefilter('ignore', BytesWarning)
828 self.assertEqual(str(b''), "b''")
829 self.assertEqual(str(b'x'), "b'x'")
830 self.assertEqual(str(b'\x80'), "b'\\x80'")
831 self.assertEqual(str(bytearray(b'')), "bytearray(b'')")
832 self.assertEqual(str(bytearray(b'x')), "bytearray(b'x')")
833 self.assertEqual(str(bytearray(b'\x80')), "bytearray(b'\\x80')")
834
835 def test_literal(self):
836 tests = [
837 (b"Wonderful spam", "Wonderful spam"),
838 (br"Wonderful spam too", "Wonderful spam too"),
839 (b"\xaa\x00\000\200", "\xaa\x00\000\200"),
840 (br"\xaa\x00\000\200", r"\xaa\x00\000\200"),
841 ]
842 for b, s in tests:
843 self.assertEqual(b, bytearray(s, 'latin-1'))
844 for c in range(128, 256):
845 self.assertRaises(SyntaxError, eval,
846 'b"%s"' % chr(c))
847
848 def test_translate(self):
849 b = b'hello'
850 rosetta = bytearray(range(0, 256))
851 rosetta[ord('o')] = ord('e')
852 c = b.translate(rosetta, b'l')
853 self.assertEqual(b, b'hello')
854 self.assertEqual(c, b'hee')
855
856 def test_split_bytearray(self):
857 self.assertEqual(b'a b'.split(memoryview(b' ')), [b'a', b'b'])
858
859 def test_rsplit_bytearray(self):
860 self.assertEqual(b'a b'.rsplit(memoryview(b' ')), [b'a', b'b'])
861
Georg Brandleb2c9642008-05-30 12:05:02 +0000862 def test_return_self(self):
863 # bytearray.replace must always return a new bytearray
864 b = bytearray()
865 self.failIf(b.replace(b'', b'') is b)
866
Barry Warsaw9e9dcd62008-10-17 01:50:37 +0000867 def test_compare(self):
868 if sys.flags.bytes_warning:
869 warnings.simplefilter('error', BytesWarning)
870 self.assertRaises(BytesWarning, operator.eq, b'', '')
871 self.assertRaises(BytesWarning, operator.ne, b'', '')
872 self.assertRaises(BytesWarning, operator.eq, bytearray(b''), '')
873 self.assertRaises(BytesWarning, operator.ne, bytearray(b''), '')
874 else:
875 # raise test.support.TestSkipped("BytesWarning is needed for this test: use -bb option")
876 pass
877
Guido van Rossumd624f182006-04-24 13:47:05 +0000878 # Optimizations:
Guido van Rossume06b6b82006-04-23 07:43:54 +0000879 # __iter__? (optimization)
Guido van Rossumd624f182006-04-24 13:47:05 +0000880 # __reversed__? (optimization)
881
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000882 # XXX More string methods? (Those that don't use character properties)
883
Neal Norwitz6968b052007-02-27 19:02:19 +0000884 # There are tests in string_tests.py that are more
885 # comprehensive for things like split, partition, etc.
886 # Unfortunately they are all bundled with tests that
887 # are not appropriate for bytes
Guido van Rossume06b6b82006-04-23 07:43:54 +0000888
Guido van Rossum254348e2007-11-21 19:29:53 +0000889 # I've started porting some of those into bytearray_tests.py, we should port
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000890 # the rest that make sense (the code can be cleaned up to use modern
891 # unittest methods at the same time).
892
Guido van Rossum254348e2007-11-21 19:29:53 +0000893class BytearrayPEP3137Test(unittest.TestCase,
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000894 test.buffer_tests.MixinBytesBufferCommonTests):
895 def marshal(self, x):
Guido van Rossum254348e2007-11-21 19:29:53 +0000896 return bytearray(x)
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000897
898 def test_returns_new_copy(self):
899 val = self.marshal(b'1234')
900 # On immutable types these MAY return a reference to themselves
Guido van Rossum254348e2007-11-21 19:29:53 +0000901 # but on mutable types like bytearray they MUST return a new copy.
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000902 for methname in ('zfill', 'rjust', 'ljust', 'center'):
903 method = getattr(val, methname)
904 newval = method(3)
905 self.assertEqual(val, newval)
906 self.assertTrue(val is not newval,
907 methname+' returned self on a mutable object')
908
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000909
Christian Heimes510711d2008-01-30 11:57:58 +0000910class FixedStringTest(test.string_tests.BaseTest):
Georg Brandlc7885542007-03-06 19:16:20 +0000911
Guido van Rossum9c627722007-08-27 18:31:48 +0000912 def fixtype(self, obj):
913 if isinstance(obj, str):
914 return obj.encode("utf-8")
915 return super().fixtype(obj)
916
Georg Brandlc7885542007-03-06 19:16:20 +0000917 # Currently the bytes containment testing uses a single integer
918 # value. This may not be the final design, but until then the
919 # bytes section with in a bytes containment not valid
920 def test_contains(self):
921 pass
Guido van Rossumcd16bf62007-06-13 18:07:49 +0000922 def test_expandtabs(self):
923 pass
924 def test_upper(self):
925 pass
926 def test_lower(self):
927 pass
Georg Brandlc7885542007-03-06 19:16:20 +0000928
Christian Heimes510711d2008-01-30 11:57:58 +0000929class ByteArrayAsStringTest(FixedStringTest):
930 type2test = bytearray
931
932class BytesAsStringTest(FixedStringTest):
933 type2test = bytes
934
Georg Brandlc7885542007-03-06 19:16:20 +0000935
Guido van Rossum254348e2007-11-21 19:29:53 +0000936class ByteArraySubclass(bytearray):
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000937 pass
938
Guido van Rossum254348e2007-11-21 19:29:53 +0000939class ByteArraySubclassTest(unittest.TestCase):
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000940
941 def test_basic(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000942 self.assert_(issubclass(ByteArraySubclass, bytearray))
943 self.assert_(isinstance(ByteArraySubclass(), bytearray))
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000944
945 a, b = b"abcd", b"efgh"
Guido van Rossum254348e2007-11-21 19:29:53 +0000946 _a, _b = ByteArraySubclass(a), ByteArraySubclass(b)
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000947
948 # test comparison operators with subclass instances
949 self.assert_(_a == _a)
950 self.assert_(_a != _b)
951 self.assert_(_a < _b)
952 self.assert_(_a <= _b)
953 self.assert_(_b >= _a)
954 self.assert_(_b > _a)
955 self.assert_(_a is not a)
956
957 # test concat of subclass instances
958 self.assertEqual(a + b, _a + _b)
959 self.assertEqual(a + b, a + _b)
960 self.assertEqual(a + b, _a + b)
961
962 # test repeat
963 self.assert_(a*5 == _a*5)
964
965 def test_join(self):
966 # Make sure join returns a NEW object for single item sequences
967 # involving a subclass.
968 # Make sure that it is of the appropriate type.
Guido van Rossum254348e2007-11-21 19:29:53 +0000969 s1 = ByteArraySubclass(b"abcd")
970 s2 = bytearray().join([s1])
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000971 self.assert_(s1 is not s2)
Guido van Rossum254348e2007-11-21 19:29:53 +0000972 self.assert_(type(s2) is bytearray, type(s2))
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000973
974 # Test reverse, calling join on subclass
975 s3 = s1.join([b"abcd"])
Guido van Rossum254348e2007-11-21 19:29:53 +0000976 self.assert_(type(s3) is bytearray)
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000977
978 def test_pickle(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000979 a = ByteArraySubclass(b"abcd")
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000980 a.x = 10
Guido van Rossum254348e2007-11-21 19:29:53 +0000981 a.y = ByteArraySubclass(b"efgh")
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000982 for proto in range(pickle.HIGHEST_PROTOCOL):
983 b = pickle.loads(pickle.dumps(a, proto))
984 self.assertNotEqual(id(a), id(b))
985 self.assertEqual(a, b)
986 self.assertEqual(a.x, b.x)
987 self.assertEqual(a.y, b.y)
988 self.assertEqual(type(a), type(b))
989 self.assertEqual(type(a.y), type(b.y))
990
991 def test_copy(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000992 a = ByteArraySubclass(b"abcd")
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000993 a.x = 10
Guido van Rossum254348e2007-11-21 19:29:53 +0000994 a.y = ByteArraySubclass(b"efgh")
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000995 for copy_method in (copy.copy, copy.deepcopy):
996 b = copy_method(a)
997 self.assertNotEqual(id(a), id(b))
998 self.assertEqual(a, b)
999 self.assertEqual(a.x, b.x)
1000 self.assertEqual(a.y, b.y)
1001 self.assertEqual(type(a), type(b))
1002 self.assertEqual(type(a.y), type(b.y))
1003
1004 def test_init_override(self):
Guido van Rossum254348e2007-11-21 19:29:53 +00001005 class subclass(bytearray):
Guido van Rossuma6c04be2007-11-03 00:24:24 +00001006 def __init__(self, newarg=1, *args, **kwargs):
Guido van Rossum254348e2007-11-21 19:29:53 +00001007 bytearray.__init__(self, *args, **kwargs)
Guido van Rossuma6c04be2007-11-03 00:24:24 +00001008 x = subclass(4, source=b"abcd")
1009 self.assertEqual(x, b"abcd")
1010 x = subclass(newarg=4, source=b"abcd")
1011 self.assertEqual(x, b"abcd")
1012
1013
Guido van Rossum4dfe8a12006-04-22 23:28:04 +00001014def test_main():
Benjamin Petersonee8712c2008-05-20 21:35:26 +00001015 test.support.run_unittest(BytesTest)
1016 test.support.run_unittest(ByteArrayTest)
1017 test.support.run_unittest(AssortedBytesTest)
1018 test.support.run_unittest(BytesAsStringTest)
1019 test.support.run_unittest(ByteArrayAsStringTest)
1020 test.support.run_unittest(ByteArraySubclassTest)
1021 test.support.run_unittest(BytearrayPEP3137Test)
Guido van Rossum4dfe8a12006-04-22 23:28:04 +00001022
1023if __name__ == "__main__":
Guido van Rossuma6c04be2007-11-03 00:24:24 +00001024 test_main()