blob: 7b2a0bd06344fda406c2b9b06ccd8fbb424e57f8 [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):
Hirokazu Yamamotod0d0b652008-10-23 00:38:15 +0000400 for proto in range(pickle.HIGHEST_PROTOCOL + 1):
Christian Heimes510711d2008-01-30 11:57:58 +0000401 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
Benjamin Peterson0f3641c2008-11-19 22:05:52 +0000741 def test_copied(self):
742 # Issue 4348. Make sure that operations that don't mutate the array
743 # copy the bytes.
744 b = bytearray(b'abc')
745 #self.assertFalse(b is b.replace(b'abc', b'cde', 0))
746
747 t = bytearray([i for i in range(256)])
748 x = bytearray(b'')
749 self.assertFalse(x is x.translate(t))
750
Guido van Rossum254348e2007-11-21 19:29:53 +0000751 def test_partition_bytearray_doesnt_share_nullstring(self):
752 a, b, c = bytearray(b"x").partition(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 a, b, c = bytearray(b"x").partition(b"y")
Guido van Rossum98297ee2007-11-06 21:34:58 +0000759 self.assertEqual(b, b"")
760 self.assertEqual(c, b"")
761 # Same for rpartition
Guido van Rossum254348e2007-11-21 19:29:53 +0000762 b, c, a = bytearray(b"x").rpartition(b"y")
Guido van Rossum98297ee2007-11-06 21:34:58 +0000763 self.assertEqual(b, b"")
764 self.assertEqual(c, b"")
765 self.assert_(b is not c)
766 b += b"!"
767 self.assertEqual(c, b"")
Guido van Rossum254348e2007-11-21 19:29:53 +0000768 c, b, a = bytearray(b"x").rpartition(b"y")
Guido van Rossum98297ee2007-11-06 21:34:58 +0000769 self.assertEqual(b, b"")
770 self.assertEqual(c, b"")
771
772
Christian Heimes510711d2008-01-30 11:57:58 +0000773class AssortedBytesTest(unittest.TestCase):
774 #
775 # Test various combinations of bytes and bytearray
776 #
777
778 def setUp(self):
779 self.warning_filters = warnings.filters[:]
780
781 def tearDown(self):
782 warnings.filters = self.warning_filters
783
784 def test_repr_str(self):
785 warnings.simplefilter('ignore', BytesWarning)
786 for f in str, repr:
787 self.assertEqual(f(bytearray()), "bytearray(b'')")
788 self.assertEqual(f(bytearray([0])), "bytearray(b'\\x00')")
789 self.assertEqual(f(bytearray([0, 1, 254, 255])),
790 "bytearray(b'\\x00\\x01\\xfe\\xff')")
791 self.assertEqual(f(b"abc"), "b'abc'")
792 self.assertEqual(f(b"'"), '''b"'"''') # '''
793 self.assertEqual(f(b"'\""), r"""b'\'"'""") # '
794
795 def test_compare_bytes_to_bytearray(self):
796 self.assertEqual(b"abc" == bytes(b"abc"), True)
797 self.assertEqual(b"ab" != bytes(b"abc"), True)
798 self.assertEqual(b"ab" <= bytes(b"abc"), True)
799 self.assertEqual(b"ab" < bytes(b"abc"), True)
800 self.assertEqual(b"abc" >= bytes(b"ab"), True)
801 self.assertEqual(b"abc" > bytes(b"ab"), True)
802
803 self.assertEqual(b"abc" != bytes(b"abc"), False)
804 self.assertEqual(b"ab" == bytes(b"abc"), False)
805 self.assertEqual(b"ab" > bytes(b"abc"), False)
806 self.assertEqual(b"ab" >= bytes(b"abc"), False)
807 self.assertEqual(b"abc" < bytes(b"ab"), False)
808 self.assertEqual(b"abc" <= bytes(b"ab"), False)
809
810 self.assertEqual(bytes(b"abc") == b"abc", True)
811 self.assertEqual(bytes(b"ab") != b"abc", True)
812 self.assertEqual(bytes(b"ab") <= b"abc", True)
813 self.assertEqual(bytes(b"ab") < b"abc", True)
814 self.assertEqual(bytes(b"abc") >= b"ab", True)
815 self.assertEqual(bytes(b"abc") > b"ab", True)
816
817 self.assertEqual(bytes(b"abc") != b"abc", False)
818 self.assertEqual(bytes(b"ab") == b"abc", False)
819 self.assertEqual(bytes(b"ab") > b"abc", False)
820 self.assertEqual(bytes(b"ab") >= b"abc", False)
821 self.assertEqual(bytes(b"abc") < b"ab", False)
822 self.assertEqual(bytes(b"abc") <= b"ab", False)
823
824 def test_doc(self):
825 self.failUnless(bytearray.__doc__ != None)
826 self.failUnless(bytearray.__doc__.startswith("bytearray("), bytearray.__doc__)
827 self.failUnless(bytes.__doc__ != None)
828 self.failUnless(bytes.__doc__.startswith("bytes("), bytes.__doc__)
829
830 def test_from_bytearray(self):
831 sample = bytes(b"Hello world\n\x80\x81\xfe\xff")
832 buf = memoryview(sample)
833 b = bytearray(buf)
834 self.assertEqual(b, bytearray(sample))
835
836 def test_to_str(self):
837 warnings.simplefilter('ignore', BytesWarning)
838 self.assertEqual(str(b''), "b''")
839 self.assertEqual(str(b'x'), "b'x'")
840 self.assertEqual(str(b'\x80'), "b'\\x80'")
841 self.assertEqual(str(bytearray(b'')), "bytearray(b'')")
842 self.assertEqual(str(bytearray(b'x')), "bytearray(b'x')")
843 self.assertEqual(str(bytearray(b'\x80')), "bytearray(b'\\x80')")
844
845 def test_literal(self):
846 tests = [
847 (b"Wonderful spam", "Wonderful spam"),
848 (br"Wonderful spam too", "Wonderful spam too"),
849 (b"\xaa\x00\000\200", "\xaa\x00\000\200"),
850 (br"\xaa\x00\000\200", r"\xaa\x00\000\200"),
851 ]
852 for b, s in tests:
853 self.assertEqual(b, bytearray(s, 'latin-1'))
854 for c in range(128, 256):
855 self.assertRaises(SyntaxError, eval,
856 'b"%s"' % chr(c))
857
858 def test_translate(self):
859 b = b'hello'
860 rosetta = bytearray(range(0, 256))
861 rosetta[ord('o')] = ord('e')
862 c = b.translate(rosetta, b'l')
863 self.assertEqual(b, b'hello')
864 self.assertEqual(c, b'hee')
865
866 def test_split_bytearray(self):
867 self.assertEqual(b'a b'.split(memoryview(b' ')), [b'a', b'b'])
868
869 def test_rsplit_bytearray(self):
870 self.assertEqual(b'a b'.rsplit(memoryview(b' ')), [b'a', b'b'])
871
Georg Brandleb2c9642008-05-30 12:05:02 +0000872 def test_return_self(self):
873 # bytearray.replace must always return a new bytearray
874 b = bytearray()
875 self.failIf(b.replace(b'', b'') is b)
876
Barry Warsaw9e9dcd62008-10-17 01:50:37 +0000877 def test_compare(self):
878 if sys.flags.bytes_warning:
879 warnings.simplefilter('error', BytesWarning)
880 self.assertRaises(BytesWarning, operator.eq, b'', '')
881 self.assertRaises(BytesWarning, operator.ne, b'', '')
882 self.assertRaises(BytesWarning, operator.eq, bytearray(b''), '')
883 self.assertRaises(BytesWarning, operator.ne, bytearray(b''), '')
884 else:
885 # raise test.support.TestSkipped("BytesWarning is needed for this test: use -bb option")
886 pass
887
Guido van Rossumd624f182006-04-24 13:47:05 +0000888 # Optimizations:
Guido van Rossume06b6b82006-04-23 07:43:54 +0000889 # __iter__? (optimization)
Guido van Rossumd624f182006-04-24 13:47:05 +0000890 # __reversed__? (optimization)
891
Guido van Rossumad7d8d12007-04-13 01:39:34 +0000892 # XXX More string methods? (Those that don't use character properties)
893
Neal Norwitz6968b052007-02-27 19:02:19 +0000894 # There are tests in string_tests.py that are more
895 # comprehensive for things like split, partition, etc.
896 # Unfortunately they are all bundled with tests that
897 # are not appropriate for bytes
Guido van Rossume06b6b82006-04-23 07:43:54 +0000898
Guido van Rossum254348e2007-11-21 19:29:53 +0000899 # I've started porting some of those into bytearray_tests.py, we should port
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000900 # the rest that make sense (the code can be cleaned up to use modern
901 # unittest methods at the same time).
902
Guido van Rossum254348e2007-11-21 19:29:53 +0000903class BytearrayPEP3137Test(unittest.TestCase,
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000904 test.buffer_tests.MixinBytesBufferCommonTests):
905 def marshal(self, x):
Guido van Rossum254348e2007-11-21 19:29:53 +0000906 return bytearray(x)
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000907
908 def test_returns_new_copy(self):
909 val = self.marshal(b'1234')
910 # On immutable types these MAY return a reference to themselves
Guido van Rossum254348e2007-11-21 19:29:53 +0000911 # but on mutable types like bytearray they MUST return a new copy.
Gregory P. Smith60d241f2007-10-16 06:31:30 +0000912 for methname in ('zfill', 'rjust', 'ljust', 'center'):
913 method = getattr(val, methname)
914 newval = method(3)
915 self.assertEqual(val, newval)
916 self.assertTrue(val is not newval,
917 methname+' returned self on a mutable object')
918
Guido van Rossum4dfe8a12006-04-22 23:28:04 +0000919
Christian Heimes510711d2008-01-30 11:57:58 +0000920class FixedStringTest(test.string_tests.BaseTest):
Georg Brandlc7885542007-03-06 19:16:20 +0000921
Guido van Rossum9c627722007-08-27 18:31:48 +0000922 def fixtype(self, obj):
923 if isinstance(obj, str):
924 return obj.encode("utf-8")
925 return super().fixtype(obj)
926
Georg Brandlc7885542007-03-06 19:16:20 +0000927 # Currently the bytes containment testing uses a single integer
928 # value. This may not be the final design, but until then the
929 # bytes section with in a bytes containment not valid
930 def test_contains(self):
931 pass
Guido van Rossumcd16bf62007-06-13 18:07:49 +0000932 def test_expandtabs(self):
933 pass
934 def test_upper(self):
935 pass
936 def test_lower(self):
937 pass
Georg Brandlc7885542007-03-06 19:16:20 +0000938
Christian Heimes510711d2008-01-30 11:57:58 +0000939class ByteArrayAsStringTest(FixedStringTest):
940 type2test = bytearray
941
942class BytesAsStringTest(FixedStringTest):
943 type2test = bytes
944
Georg Brandlc7885542007-03-06 19:16:20 +0000945
Guido van Rossum254348e2007-11-21 19:29:53 +0000946class ByteArraySubclass(bytearray):
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000947 pass
948
Guido van Rossum254348e2007-11-21 19:29:53 +0000949class ByteArraySubclassTest(unittest.TestCase):
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000950
951 def test_basic(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000952 self.assert_(issubclass(ByteArraySubclass, bytearray))
953 self.assert_(isinstance(ByteArraySubclass(), bytearray))
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000954
955 a, b = b"abcd", b"efgh"
Guido van Rossum254348e2007-11-21 19:29:53 +0000956 _a, _b = ByteArraySubclass(a), ByteArraySubclass(b)
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000957
958 # test comparison operators with subclass instances
959 self.assert_(_a == _a)
960 self.assert_(_a != _b)
961 self.assert_(_a < _b)
962 self.assert_(_a <= _b)
963 self.assert_(_b >= _a)
964 self.assert_(_b > _a)
965 self.assert_(_a is not a)
966
967 # test concat of subclass instances
968 self.assertEqual(a + b, _a + _b)
969 self.assertEqual(a + b, a + _b)
970 self.assertEqual(a + b, _a + b)
971
972 # test repeat
973 self.assert_(a*5 == _a*5)
974
975 def test_join(self):
976 # Make sure join returns a NEW object for single item sequences
977 # involving a subclass.
978 # Make sure that it is of the appropriate type.
Guido van Rossum254348e2007-11-21 19:29:53 +0000979 s1 = ByteArraySubclass(b"abcd")
980 s2 = bytearray().join([s1])
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000981 self.assert_(s1 is not s2)
Guido van Rossum254348e2007-11-21 19:29:53 +0000982 self.assert_(type(s2) is bytearray, type(s2))
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000983
984 # Test reverse, calling join on subclass
985 s3 = s1.join([b"abcd"])
Guido van Rossum254348e2007-11-21 19:29:53 +0000986 self.assert_(type(s3) is bytearray)
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000987
988 def test_pickle(self):
Guido van Rossum254348e2007-11-21 19:29:53 +0000989 a = ByteArraySubclass(b"abcd")
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000990 a.x = 10
Guido van Rossum254348e2007-11-21 19:29:53 +0000991 a.y = ByteArraySubclass(b"efgh")
Hirokazu Yamamotod0d0b652008-10-23 00:38:15 +0000992 for proto in range(pickle.HIGHEST_PROTOCOL + 1):
Guido van Rossuma6c04be2007-11-03 00:24:24 +0000993 b = pickle.loads(pickle.dumps(a, proto))
994 self.assertNotEqual(id(a), id(b))
995 self.assertEqual(a, b)
996 self.assertEqual(a.x, b.x)
997 self.assertEqual(a.y, b.y)
998 self.assertEqual(type(a), type(b))
999 self.assertEqual(type(a.y), type(b.y))
1000
1001 def test_copy(self):
Guido van Rossum254348e2007-11-21 19:29:53 +00001002 a = ByteArraySubclass(b"abcd")
Guido van Rossuma6c04be2007-11-03 00:24:24 +00001003 a.x = 10
Guido van Rossum254348e2007-11-21 19:29:53 +00001004 a.y = ByteArraySubclass(b"efgh")
Guido van Rossuma6c04be2007-11-03 00:24:24 +00001005 for copy_method in (copy.copy, copy.deepcopy):
1006 b = copy_method(a)
1007 self.assertNotEqual(id(a), id(b))
1008 self.assertEqual(a, b)
1009 self.assertEqual(a.x, b.x)
1010 self.assertEqual(a.y, b.y)
1011 self.assertEqual(type(a), type(b))
1012 self.assertEqual(type(a.y), type(b.y))
1013
1014 def test_init_override(self):
Guido van Rossum254348e2007-11-21 19:29:53 +00001015 class subclass(bytearray):
Guido van Rossuma6c04be2007-11-03 00:24:24 +00001016 def __init__(self, newarg=1, *args, **kwargs):
Guido van Rossum254348e2007-11-21 19:29:53 +00001017 bytearray.__init__(self, *args, **kwargs)
Guido van Rossuma6c04be2007-11-03 00:24:24 +00001018 x = subclass(4, source=b"abcd")
1019 self.assertEqual(x, b"abcd")
1020 x = subclass(newarg=4, source=b"abcd")
1021 self.assertEqual(x, b"abcd")
1022
1023
Guido van Rossum4dfe8a12006-04-22 23:28:04 +00001024def test_main():
Benjamin Petersonee8712c2008-05-20 21:35:26 +00001025 test.support.run_unittest(BytesTest)
1026 test.support.run_unittest(ByteArrayTest)
1027 test.support.run_unittest(AssortedBytesTest)
1028 test.support.run_unittest(BytesAsStringTest)
1029 test.support.run_unittest(ByteArrayAsStringTest)
1030 test.support.run_unittest(ByteArraySubclassTest)
1031 test.support.run_unittest(BytearrayPEP3137Test)
Guido van Rossum4dfe8a12006-04-22 23:28:04 +00001032
1033if __name__ == "__main__":
Guido van Rossuma6c04be2007-11-03 00:24:24 +00001034 test_main()