blob: 615c9557503c46441b3b0f8a7e3c73ac276d14b7 [file] [log] [blame]
Christian Heimes1a6387e2008-03-26 12:49:49 +00001"""Unit tests for the bytes and bytearray types.
2
3XXX This is a mess. Common tests should be moved to buffer_tests.py,
4which itself ought to be unified with string_tests.py (and the latter
5should be modernized).
6"""
7
8import os
9import re
10import sys
11import copy
12import pickle
13import tempfile
14import unittest
15import warnings
16import test.test_support
17import test.string_tests
18import test.buffer_tests
19
Georg Brandl3e483f62008-07-16 22:57:41 +000020class Indexable:
21 def __init__(self, value=0):
22 self.value = value
23 def __index__(self):
24 return self.value
25
Christian Heimes1a6387e2008-03-26 12:49:49 +000026
27class BaseBytesTest(unittest.TestCase):
28
29 def setUp(self):
30 self.warning_filters = warnings.filters[:]
31
32 def tearDown(self):
33 warnings.filters = self.warning_filters
34
35 def test_basics(self):
36 b = self.type2test()
37 self.assertEqual(type(b), self.type2test)
38 self.assertEqual(b.__class__, self.type2test)
39
40 def test_empty_sequence(self):
41 b = self.type2test()
42 self.assertEqual(len(b), 0)
43 self.assertRaises(IndexError, lambda: b[0])
44 self.assertRaises(IndexError, lambda: b[1])
45 self.assertRaises(IndexError, lambda: b[sys.maxint])
46 self.assertRaises(IndexError, lambda: b[sys.maxint+1])
47 self.assertRaises(IndexError, lambda: b[10**100])
48 self.assertRaises(IndexError, lambda: b[-1])
49 self.assertRaises(IndexError, lambda: b[-2])
50 self.assertRaises(IndexError, lambda: b[-sys.maxint])
51 self.assertRaises(IndexError, lambda: b[-sys.maxint-1])
52 self.assertRaises(IndexError, lambda: b[-sys.maxint-2])
53 self.assertRaises(IndexError, lambda: b[-10**100])
54
55 def test_from_list(self):
56 ints = list(range(256))
57 b = self.type2test(i for i in ints)
58 self.assertEqual(len(b), 256)
59 self.assertEqual(list(b), ints)
60
61 def test_from_index(self):
Georg Brandl3e483f62008-07-16 22:57:41 +000062 b = self.type2test([Indexable(), Indexable(1), Indexable(254),
63 Indexable(255)])
Christian Heimes1a6387e2008-03-26 12:49:49 +000064 self.assertEqual(list(b), [0, 1, 254, 255])
Georg Brandl3e483f62008-07-16 22:57:41 +000065 self.assertRaises(ValueError, bytearray, [Indexable(-1)])
66 self.assertRaises(ValueError, bytearray, [Indexable(256)])
Christian Heimes1a6387e2008-03-26 12:49:49 +000067
68 def test_from_ssize(self):
69 self.assertEqual(bytearray(0), b'')
70 self.assertEqual(bytearray(1), b'\x00')
71 self.assertEqual(bytearray(5), b'\x00\x00\x00\x00\x00')
72 self.assertRaises(ValueError, bytearray, -1)
73
74 self.assertEqual(bytearray('0', 'ascii'), b'0')
75 self.assertEqual(bytearray(b'0'), b'0')
76
77 def test_constructor_type_errors(self):
78 self.assertRaises(TypeError, self.type2test, 0.0)
79 class C:
80 pass
Georg Brandl0a34baf2008-07-16 23:18:51 +000081 # allowed in 2.6
82 #self.assertRaises(TypeError, self.type2test, ["0"])
Christian Heimes1a6387e2008-03-26 12:49:49 +000083 self.assertRaises(TypeError, self.type2test, [0.0])
84 self.assertRaises(TypeError, self.type2test, [None])
85 self.assertRaises(TypeError, self.type2test, [C()])
86
87 def test_constructor_value_errors(self):
88 self.assertRaises(ValueError, self.type2test, [-1])
89 self.assertRaises(ValueError, self.type2test, [-sys.maxint])
90 self.assertRaises(ValueError, self.type2test, [-sys.maxint-1])
91 self.assertRaises(ValueError, self.type2test, [-sys.maxint-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.maxint])
96 self.assertRaises(ValueError, self.type2test, [sys.maxint+1])
97 self.assertRaises(ValueError, self.type2test, [10**100])
98
99 def test_compare(self):
100 b1 = self.type2test([1, 2, 3])
101 b2 = self.type2test([1, 2, 3])
102 b3 = self.type2test([1, 3])
103
104 self.assertEqual(b1, b2)
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000105 self.assertTrue(b2 != b3)
106 self.assertTrue(b1 <= b2)
107 self.assertTrue(b1 <= b3)
108 self.assertTrue(b1 < b3)
109 self.assertTrue(b1 >= b2)
110 self.assertTrue(b3 >= b2)
111 self.assertTrue(b3 > b2)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000112
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000113 self.assertFalse(b1 != b2)
114 self.assertFalse(b2 == b3)
115 self.assertFalse(b1 > b2)
116 self.assertFalse(b1 > b3)
117 self.assertFalse(b1 >= b3)
118 self.assertFalse(b1 < b2)
119 self.assertFalse(b3 < b2)
120 self.assertFalse(b3 <= b2)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000121
122 def test_compare_to_str(self):
123 warnings.simplefilter('ignore', BytesWarning)
124 # Byte comparisons with unicode should always fail!
125 # Test this for all expected byte orders and Unicode character sizes
126 self.assertEqual(self.type2test(b"\0a\0b\0c") == u"abc", False)
127 self.assertEqual(self.type2test(b"\0\0\0a\0\0\0b\0\0\0c") == u"abc", False)
128 self.assertEqual(self.type2test(b"a\0b\0c\0") == u"abc", False)
129 self.assertEqual(self.type2test(b"a\0\0\0b\0\0\0c\0\0\0") == u"abc", False)
130 self.assertEqual(self.type2test() == unicode(), False)
131 self.assertEqual(self.type2test() != unicode(), 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 = u"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 = u"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 = u"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 + u"def")
205 self.assertRaises(TypeError, lambda: u"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),
Mark Hammond69ed5242008-08-23 00:59:14 +0000216 lambda: b * sys.maxsize)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000217
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")
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000223 self.assertTrue(ord('a') in b)
224 self.assertTrue(int(ord('a')) in b)
225 self.assertFalse(200 in b)
226 self.assertFalse(200 in b)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000227 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: u"a" in b)
232 for f in bytes, bytearray:
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000233 self.assertTrue(f(b"") in b)
234 self.assertTrue(f(b"a") in b)
235 self.assertTrue(f(b"b") in b)
236 self.assertTrue(f(b"c") in b)
237 self.assertTrue(f(b"ab") in b)
238 self.assertTrue(f(b"bc") in b)
239 self.assertTrue(f(b"abc") in b)
240 self.assertFalse(f(b"ac") in b)
241 self.assertFalse(f(b"d") in b)
242 self.assertFalse(f(b"dab") in b)
243 self.assertFalse(f(b"abd") in b)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000244
245 def test_fromhex(self):
246 self.assertRaises(TypeError, self.type2test.fromhex)
247 self.assertRaises(TypeError, self.type2test.fromhex, 1)
248 self.assertEquals(self.type2test.fromhex(u''), self.type2test())
249 b = bytearray([0x1a, 0x2b, 0x30])
250 self.assertEquals(self.type2test.fromhex(u'1a2B30'), b)
251 self.assertEquals(self.type2test.fromhex(u' 1A 2B 30 '), b)
252 self.assertEquals(self.type2test.fromhex(u'0000'), b'\0\0')
Christian Heimes1a6387e2008-03-26 12:49:49 +0000253 self.assertRaises(ValueError, self.type2test.fromhex, u'a')
254 self.assertRaises(ValueError, self.type2test.fromhex, u'rt')
255 self.assertRaises(ValueError, self.type2test.fromhex, u'1a b cd')
256 self.assertRaises(ValueError, self.type2test.fromhex, u'\x00')
257 self.assertRaises(ValueError, self.type2test.fromhex, u'12 \x00 34')
258
259 def test_join(self):
260 self.assertEqual(self.type2test(b"").join([]), b"")
261 self.assertEqual(self.type2test(b"").join([b""]), b"")
262 for lst in [[b"abc"], [b"a", b"bc"], [b"ab", b"c"], [b"a", b"b", b"c"]]:
263 lst = list(map(self.type2test, lst))
264 self.assertEqual(self.type2test(b"").join(lst), b"abc")
265 self.assertEqual(self.type2test(b"").join(tuple(lst)), b"abc")
266 self.assertEqual(self.type2test(b"").join(iter(lst)), b"abc")
267 self.assertEqual(self.type2test(b".").join([b"ab", b"cd"]), b"ab.cd")
268 # XXX more...
269
270 def test_index(self):
271 b = self.type2test(b'parrot')
272 self.assertEqual(b.index('p'), 0)
273 self.assertEqual(b.index('rr'), 2)
274 self.assertEqual(b.index('t'), 5)
275 self.assertRaises(ValueError, lambda: b.index('w'))
276
277 def test_count(self):
278 b = self.type2test(b'mississippi')
279 self.assertEqual(b.count(b'i'), 4)
280 self.assertEqual(b.count(b'ss'), 2)
281 self.assertEqual(b.count(b'w'), 0)
282
283 def test_startswith(self):
284 b = self.type2test(b'hello')
285 self.assertFalse(self.type2test().startswith(b"anything"))
286 self.assertTrue(b.startswith(b"hello"))
287 self.assertTrue(b.startswith(b"hel"))
288 self.assertTrue(b.startswith(b"h"))
289 self.assertFalse(b.startswith(b"hellow"))
290 self.assertFalse(b.startswith(b"ha"))
291
292 def test_endswith(self):
293 b = self.type2test(b'hello')
294 self.assertFalse(bytearray().endswith(b"anything"))
295 self.assertTrue(b.endswith(b"hello"))
296 self.assertTrue(b.endswith(b"llo"))
297 self.assertTrue(b.endswith(b"o"))
298 self.assertFalse(b.endswith(b"whello"))
299 self.assertFalse(b.endswith(b"no"))
300
301 def test_find(self):
302 b = self.type2test(b'mississippi')
303 self.assertEqual(b.find(b'ss'), 2)
304 self.assertEqual(b.find(b'ss', 3), 5)
305 self.assertEqual(b.find(b'ss', 1, 7), 2)
306 self.assertEqual(b.find(b'ss', 1, 3), -1)
307 self.assertEqual(b.find(b'w'), -1)
308 self.assertEqual(b.find(b'mississippian'), -1)
309
310 def test_rfind(self):
311 b = self.type2test(b'mississippi')
312 self.assertEqual(b.rfind(b'ss'), 5)
313 self.assertEqual(b.rfind(b'ss', 3), 5)
314 self.assertEqual(b.rfind(b'ss', 0, 6), 2)
315 self.assertEqual(b.rfind(b'w'), -1)
316 self.assertEqual(b.rfind(b'mississippian'), -1)
317
318 def test_index(self):
319 b = self.type2test(b'world')
320 self.assertEqual(b.index(b'w'), 0)
321 self.assertEqual(b.index(b'orl'), 1)
322 self.assertRaises(ValueError, b.index, b'worm')
323 self.assertRaises(ValueError, b.index, b'ldo')
324
325 def test_rindex(self):
326 # XXX could be more rigorous
327 b = self.type2test(b'world')
328 self.assertEqual(b.rindex(b'w'), 0)
329 self.assertEqual(b.rindex(b'orl'), 1)
330 self.assertRaises(ValueError, b.rindex, b'worm')
331 self.assertRaises(ValueError, b.rindex, b'ldo')
332
333 def test_replace(self):
334 b = self.type2test(b'mississippi')
335 self.assertEqual(b.replace(b'i', b'a'), b'massassappa')
336 self.assertEqual(b.replace(b'ss', b'x'), b'mixixippi')
337
338 def test_split(self):
339 b = self.type2test(b'mississippi')
340 self.assertEqual(b.split(b'i'), [b'm', b'ss', b'ss', b'pp', b''])
341 self.assertEqual(b.split(b'ss'), [b'mi', b'i', b'ippi'])
342 self.assertEqual(b.split(b'w'), [b])
343
344 def test_split_whitespace(self):
345 for b in (b' arf barf ', b'arf\tbarf', b'arf\nbarf', b'arf\rbarf',
346 b'arf\fbarf', b'arf\vbarf'):
347 b = self.type2test(b)
348 self.assertEqual(b.split(), [b'arf', b'barf'])
349 self.assertEqual(b.split(None), [b'arf', b'barf'])
350 self.assertEqual(b.split(None, 2), [b'arf', b'barf'])
351 for b in (b'a\x1Cb', b'a\x1Db', b'a\x1Eb', b'a\x1Fb'):
352 b = self.type2test(b)
353 self.assertEqual(b.split(), [b])
354 self.assertEqual(self.type2test(b' a bb c ').split(None, 0), [b'a bb c '])
355 self.assertEqual(self.type2test(b' a bb c ').split(None, 1), [b'a', b'bb c '])
356 self.assertEqual(self.type2test(b' a bb c ').split(None, 2), [b'a', b'bb', b'c '])
357 self.assertEqual(self.type2test(b' a bb c ').split(None, 3), [b'a', b'bb', b'c'])
358
359 def test_split_string_error(self):
360 self.assertRaises(TypeError, self.type2test(b'a b').split, u' ')
361
362 def test_rsplit(self):
363 b = self.type2test(b'mississippi')
364 self.assertEqual(b.rsplit(b'i'), [b'm', b'ss', b'ss', b'pp', b''])
365 self.assertEqual(b.rsplit(b'ss'), [b'mi', b'i', b'ippi'])
366 self.assertEqual(b.rsplit(b'w'), [b])
367
368 def test_rsplit_whitespace(self):
369 for b in (b' arf barf ', b'arf\tbarf', b'arf\nbarf', b'arf\rbarf',
370 b'arf\fbarf', b'arf\vbarf'):
371 b = self.type2test(b)
372 self.assertEqual(b.rsplit(), [b'arf', b'barf'])
373 self.assertEqual(b.rsplit(None), [b'arf', b'barf'])
374 self.assertEqual(b.rsplit(None, 2), [b'arf', b'barf'])
375 self.assertEqual(self.type2test(b' a bb c ').rsplit(None, 0), [b' a bb c'])
376 self.assertEqual(self.type2test(b' a bb c ').rsplit(None, 1), [b' a bb', b'c'])
377 self.assertEqual(self.type2test(b' a bb c ').rsplit(None, 2), [b' a', b'bb', b'c'])
378 self.assertEqual(self.type2test(b' a bb c ').rsplit(None, 3), [b'a', b'bb', b'c'])
379
380 def test_rsplit_string_error(self):
381 self.assertRaises(TypeError, self.type2test(b'a b').rsplit, u' ')
382
383 def test_rsplit_unicodewhitespace(self):
384 b = self.type2test(b"\x09\x0A\x0B\x0C\x0D\x1C\x1D\x1E\x1F")
385 self.assertEqual(b.split(), [b'\x1c\x1d\x1e\x1f'])
386 self.assertEqual(b.rsplit(), [b'\x1c\x1d\x1e\x1f'])
387
388 def test_partition(self):
389 b = self.type2test(b'mississippi')
390 self.assertEqual(b.partition(b'ss'), (b'mi', b'ss', b'issippi'))
391 self.assertEqual(b.rpartition(b'w'), (b'', b'', b'mississippi'))
392
393 def test_rpartition(self):
394 b = self.type2test(b'mississippi')
395 self.assertEqual(b.rpartition(b'ss'), (b'missi', b'ss', b'ippi'))
396 self.assertEqual(b.rpartition(b'i'), (b'mississipp', b'i', b''))
397
398 def test_pickling(self):
Hirokazu Yamamoto592c2752008-10-23 00:37:33 +0000399 for proto in range(pickle.HIGHEST_PROTOCOL + 1):
Christian Heimes1a6387e2008-03-26 12:49:49 +0000400 for b in b"", b"a", b"abc", b"\xffab\x80", b"\0\0\377\0\0":
401 b = self.type2test(b)
402 ps = pickle.dumps(b, proto)
403 q = pickle.loads(ps)
404 self.assertEqual(b, q)
405
406 def test_strip(self):
407 b = self.type2test(b'mississippi')
408 self.assertEqual(b.strip(b'i'), b'mississipp')
409 self.assertEqual(b.strip(b'm'), b'ississippi')
410 self.assertEqual(b.strip(b'pi'), b'mississ')
411 self.assertEqual(b.strip(b'im'), b'ssissipp')
412 self.assertEqual(b.strip(b'pim'), b'ssiss')
413 self.assertEqual(b.strip(b), b'')
414
415 def test_lstrip(self):
416 b = self.type2test(b'mississippi')
417 self.assertEqual(b.lstrip(b'i'), b'mississippi')
418 self.assertEqual(b.lstrip(b'm'), b'ississippi')
419 self.assertEqual(b.lstrip(b'pi'), b'mississippi')
420 self.assertEqual(b.lstrip(b'im'), b'ssissippi')
421 self.assertEqual(b.lstrip(b'pim'), b'ssissippi')
422
423 def test_rstrip(self):
424 b = self.type2test(b'mississippi')
425 self.assertEqual(b.rstrip(b'i'), b'mississipp')
426 self.assertEqual(b.rstrip(b'm'), b'mississippi')
427 self.assertEqual(b.rstrip(b'pi'), b'mississ')
428 self.assertEqual(b.rstrip(b'im'), b'mississipp')
429 self.assertEqual(b.rstrip(b'pim'), b'mississ')
430
431 def test_strip_whitespace(self):
432 b = self.type2test(b' \t\n\r\f\vabc \t\n\r\f\v')
433 self.assertEqual(b.strip(), b'abc')
434 self.assertEqual(b.lstrip(), b'abc \t\n\r\f\v')
435 self.assertEqual(b.rstrip(), b' \t\n\r\f\vabc')
436
437 def XXXtest_strip_bytearray(self):
438 # XXX memoryview not available
439 self.assertEqual(self.type2test(b'abc').strip(memoryview(b'ac')), b'b')
440 self.assertEqual(self.type2test(b'abc').lstrip(memoryview(b'ac')), b'bc')
441 self.assertEqual(self.type2test(b'abc').rstrip(memoryview(b'ac')), b'ab')
442
443 def test_strip_string_error(self):
444 self.assertRaises(TypeError, self.type2test(b'abc').strip, u'b')
445 self.assertRaises(TypeError, self.type2test(b'abc').lstrip, u'b')
446 self.assertRaises(TypeError, self.type2test(b'abc').rstrip, u'b')
447
448 def test_ord(self):
449 b = self.type2test(b'\0A\x7f\x80\xff')
450 self.assertEqual([ord(b[i:i+1]) for i in range(len(b))],
451 [0, 65, 127, 128, 255])
452
453
454class ByteArrayTest(BaseBytesTest):
455 type2test = bytearray
456
457 def test_nohash(self):
458 self.assertRaises(TypeError, hash, bytearray())
459
460 def test_bytearray_api(self):
461 short_sample = b"Hello world\n"
462 sample = short_sample + b"\0"*(20 - len(short_sample))
463 tfn = tempfile.mktemp()
464 try:
465 # Prepare
466 with open(tfn, "wb") as f:
467 f.write(short_sample)
468 # Test readinto
469 with open(tfn, "rb") as f:
470 b = bytearray(20)
471 n = f.readinto(b)
472 self.assertEqual(n, len(short_sample))
473 # Python 2.x
474 b_sample = (ord(s) for s in sample)
475 self.assertEqual(list(b), list(b_sample))
476 # Test writing in binary mode
477 with open(tfn, "wb") as f:
478 f.write(b)
479 with open(tfn, "rb") as f:
480 self.assertEqual(f.read(), sample)
481 # Text mode is ambiguous; don't test
482 finally:
483 try:
484 os.remove(tfn)
485 except os.error:
486 pass
487
488 def test_reverse(self):
489 b = bytearray(b'hello')
490 self.assertEqual(b.reverse(), None)
491 self.assertEqual(b, b'olleh')
492 b = bytearray(b'hello1') # test even number of items
493 b.reverse()
494 self.assertEqual(b, b'1olleh')
495 b = bytearray()
496 b.reverse()
497 self.assertFalse(b)
498
499 def test_regexps(self):
500 def by(s):
501 return bytearray(map(ord, s))
502 b = by("Hello, world")
503 self.assertEqual(re.findall(r"\w+", b), [by("Hello"), by("world")])
504
505 def test_setitem(self):
506 b = bytearray([1, 2, 3])
507 b[1] = 100
508 self.assertEqual(b, bytearray([1, 100, 3]))
509 b[-1] = 200
510 self.assertEqual(b, bytearray([1, 100, 200]))
Georg Brandl3e483f62008-07-16 22:57:41 +0000511 b[0] = Indexable(10)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000512 self.assertEqual(b, bytearray([10, 100, 200]))
513 try:
514 b[3] = 0
515 self.fail("Didn't raise IndexError")
516 except IndexError:
517 pass
518 try:
519 b[-10] = 0
520 self.fail("Didn't raise IndexError")
521 except IndexError:
522 pass
523 try:
524 b[0] = 256
525 self.fail("Didn't raise ValueError")
526 except ValueError:
527 pass
528 try:
Georg Brandl3e483f62008-07-16 22:57:41 +0000529 b[0] = Indexable(-1)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000530 self.fail("Didn't raise ValueError")
531 except ValueError:
532 pass
533 try:
534 b[0] = None
535 self.fail("Didn't raise TypeError")
536 except TypeError:
537 pass
538
539 def test_delitem(self):
540 b = bytearray(range(10))
541 del b[0]
542 self.assertEqual(b, bytearray(range(1, 10)))
543 del b[-1]
544 self.assertEqual(b, bytearray(range(1, 9)))
545 del b[4]
546 self.assertEqual(b, bytearray([1, 2, 3, 4, 6, 7, 8]))
547
548 def test_setslice(self):
549 b = bytearray(range(10))
550 self.assertEqual(list(b), list(range(10)))
551
552 b[0:5] = bytearray([1, 1, 1, 1, 1])
553 self.assertEqual(b, bytearray([1, 1, 1, 1, 1, 5, 6, 7, 8, 9]))
554
555 del b[0:-5]
556 self.assertEqual(b, bytearray([5, 6, 7, 8, 9]))
557
558 b[0:0] = bytearray([0, 1, 2, 3, 4])
559 self.assertEqual(b, bytearray(range(10)))
560
561 b[-7:-3] = bytearray([100, 101])
562 self.assertEqual(b, bytearray([0, 1, 2, 100, 101, 7, 8, 9]))
563
564 b[3:5] = [3, 4, 5, 6]
565 self.assertEqual(b, bytearray(range(10)))
566
567 b[3:0] = [42, 42, 42]
568 self.assertEqual(b, bytearray([0, 1, 2, 42, 42, 42, 3, 4, 5, 6, 7, 8, 9]))
569
570 def test_extended_set_del_slice(self):
571 indices = (0, None, 1, 3, 19, 300, -1, -2, -31, -300)
572 for start in indices:
573 for stop in indices:
574 # Skip invalid step 0
575 for step in indices[1:]:
576 L = list(range(255))
577 b = bytearray(L)
578 # Make sure we have a slice of exactly the right length,
579 # but with different data.
580 data = L[start:stop:step]
581 data.reverse()
582 L[start:stop:step] = data
583 b[start:stop:step] = data
584 self.assertEquals(b, bytearray(L))
585
586 del L[start:stop:step]
587 del b[start:stop:step]
588 self.assertEquals(b, bytearray(L))
589
590 def test_setslice_trap(self):
591 # This test verifies that we correctly handle assigning self
592 # to a slice of self (the old Lambert Meertens trap).
593 b = bytearray(range(256))
594 b[8:] = b
595 self.assertEqual(b, bytearray(list(range(8)) + list(range(256))))
596
597 def test_iconcat(self):
598 b = bytearray(b"abc")
599 b1 = b
600 b += b"def"
601 self.assertEqual(b, b"abcdef")
602 self.assertEqual(b, b1)
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000603 self.assertTrue(b is b1)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000604 b += b"xyz"
605 self.assertEqual(b, b"abcdefxyz")
606 try:
607 b += u""
608 except TypeError:
609 pass
610 else:
611 self.fail("bytes += unicode didn't raise TypeError")
612
613 def test_irepeat(self):
614 b = bytearray(b"abc")
615 b1 = b
616 b *= 3
617 self.assertEqual(b, b"abcabcabc")
618 self.assertEqual(b, b1)
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000619 self.assertTrue(b is b1)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000620
621 def test_irepeat_1char(self):
622 b = bytearray(b"x")
623 b1 = b
624 b *= 100
625 self.assertEqual(b, b"x"*100)
626 self.assertEqual(b, b1)
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000627 self.assertTrue(b is b1)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000628
629 def test_alloc(self):
630 b = bytearray()
631 alloc = b.__alloc__()
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000632 self.assertTrue(alloc >= 0)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000633 seq = [alloc]
634 for i in range(100):
635 b += b"x"
636 alloc = b.__alloc__()
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000637 self.assertTrue(alloc >= len(b))
Christian Heimes1a6387e2008-03-26 12:49:49 +0000638 if alloc not in seq:
639 seq.append(alloc)
640
641 def test_extend(self):
642 orig = b'hello'
643 a = bytearray(orig)
644 a.extend(a)
645 self.assertEqual(a, orig + orig)
646 self.assertEqual(a[5:], orig)
647 a = bytearray(b'')
648 # Test iterators that don't have a __length_hint__
649 a.extend(map(ord, orig * 25))
650 a.extend(ord(x) for x in orig * 25)
651 self.assertEqual(a, orig * 50)
652 self.assertEqual(a[-5:], orig)
653 a = bytearray(b'')
654 a.extend(iter(map(ord, orig * 50)))
655 self.assertEqual(a, orig * 50)
656 self.assertEqual(a[-5:], orig)
657 a = bytearray(b'')
658 a.extend(list(map(ord, orig * 50)))
659 self.assertEqual(a, orig * 50)
660 self.assertEqual(a[-5:], orig)
661 a = bytearray(b'')
662 self.assertRaises(ValueError, a.extend, [0, 1, 2, 256])
663 self.assertRaises(ValueError, a.extend, [0, 1, 2, -1])
664 self.assertEqual(len(a), 0)
Georg Brandl3e483f62008-07-16 22:57:41 +0000665 a = bytearray(b'')
666 a.extend([Indexable(ord('a'))])
667 self.assertEqual(a, b'a')
Christian Heimes1a6387e2008-03-26 12:49:49 +0000668
669 def test_remove(self):
670 b = bytearray(b'hello')
671 b.remove(ord('l'))
672 self.assertEqual(b, b'helo')
673 b.remove(ord('l'))
674 self.assertEqual(b, b'heo')
675 self.assertRaises(ValueError, lambda: b.remove(ord('l')))
676 self.assertRaises(ValueError, lambda: b.remove(400))
677 self.assertRaises(TypeError, lambda: b.remove(u'e'))
678 # remove first and last
679 b.remove(ord('o'))
680 b.remove(ord('h'))
681 self.assertEqual(b, b'e')
682 self.assertRaises(TypeError, lambda: b.remove(u'e'))
Georg Brandl3e483f62008-07-16 22:57:41 +0000683 b.remove(Indexable(ord('e')))
684 self.assertEqual(b, b'')
Christian Heimes1a6387e2008-03-26 12:49:49 +0000685
686 def test_pop(self):
687 b = bytearray(b'world')
688 self.assertEqual(b.pop(), ord('d'))
689 self.assertEqual(b.pop(0), ord('w'))
690 self.assertEqual(b.pop(-2), ord('r'))
691 self.assertRaises(IndexError, lambda: b.pop(10))
692 self.assertRaises(OverflowError, lambda: bytearray().pop())
Mark Dickinsonc8a7c7c2009-09-06 10:03:31 +0000693 # test for issue #6846
694 self.assertEqual(bytearray(b'\xff').pop(), 0xff)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000695
696 def test_nosort(self):
697 self.assertRaises(AttributeError, lambda: bytearray().sort())
698
699 def test_append(self):
700 b = bytearray(b'hell')
701 b.append(ord('o'))
702 self.assertEqual(b, b'hello')
703 self.assertEqual(b.append(100), None)
704 b = bytearray()
705 b.append(ord('A'))
706 self.assertEqual(len(b), 1)
707 self.assertRaises(TypeError, lambda: b.append(u'o'))
Georg Brandl3e483f62008-07-16 22:57:41 +0000708 b = bytearray()
709 b.append(Indexable(ord('A')))
710 self.assertEqual(b, b'A')
Christian Heimes1a6387e2008-03-26 12:49:49 +0000711
712 def test_insert(self):
713 b = bytearray(b'msssspp')
714 b.insert(1, ord('i'))
715 b.insert(4, ord('i'))
716 b.insert(-2, ord('i'))
717 b.insert(1000, ord('i'))
718 self.assertEqual(b, b'mississippi')
Georg Brandl3e483f62008-07-16 22:57:41 +0000719 # allowed in 2.6
720 #self.assertRaises(TypeError, lambda: b.insert(0, b'1'))
721 b = bytearray()
722 b.insert(0, Indexable(ord('A')))
723 self.assertEqual(b, b'A')
Christian Heimes1a6387e2008-03-26 12:49:49 +0000724
Benjamin Peterson46cc6d12008-11-19 21:49:09 +0000725 def test_copied(self):
726 # Issue 4348. Make sure that operations that don't mutate the array
727 # copy the bytes.
728 b = bytearray(b'abc')
Benjamin Petersond3b5a792008-11-20 21:44:23 +0000729 self.assertFalse(b is b.replace(b'abc', b'cde', 0))
Benjamin Peterson46cc6d12008-11-19 21:49:09 +0000730
731 t = bytearray([i for i in range(256)])
732 x = bytearray(b'')
733 self.assertFalse(x is x.translate(t))
734
Christian Heimes1a6387e2008-03-26 12:49:49 +0000735 def test_partition_bytearray_doesnt_share_nullstring(self):
736 a, b, c = bytearray(b"x").partition(b"y")
737 self.assertEqual(b, b"")
738 self.assertEqual(c, b"")
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000739 self.assertTrue(b is not c)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000740 b += b"!"
741 self.assertEqual(c, b"")
742 a, b, c = bytearray(b"x").partition(b"y")
743 self.assertEqual(b, b"")
744 self.assertEqual(c, b"")
745 # Same for rpartition
746 b, c, a = bytearray(b"x").rpartition(b"y")
747 self.assertEqual(b, b"")
748 self.assertEqual(c, b"")
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000749 self.assertTrue(b is not c)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000750 b += b"!"
751 self.assertEqual(c, b"")
752 c, b, a = bytearray(b"x").rpartition(b"y")
753 self.assertEqual(b, b"")
754 self.assertEqual(c, b"")
755
Antoine Pitrouae5bece2008-12-06 21:29:24 +0000756 # XXX memoryview not available
757 def XXXtest_resize_forbidden(self):
758 # #4509: can't resize a bytearray when there are buffer exports, even
759 # if it wouldn't reallocate the underlying buffer.
760 # Furthermore, no destructive changes to the buffer may be applied
761 # before raising the error.
762 b = bytearray(range(10))
763 v = memoryview(b)
764 def resize(n):
765 b[1:-1] = range(n + 1, 2*n - 1)
766 resize(10)
767 orig = b[:]
768 self.assertRaises(BufferError, resize, 11)
769 self.assertEquals(b, orig)
770 self.assertRaises(BufferError, resize, 9)
771 self.assertEquals(b, orig)
772 self.assertRaises(BufferError, resize, 0)
773 self.assertEquals(b, orig)
774 # Other operations implying resize
775 self.assertRaises(BufferError, b.pop, 0)
776 self.assertEquals(b, orig)
777 self.assertRaises(BufferError, b.remove, b[1])
778 self.assertEquals(b, orig)
779 def delitem():
780 del b[1]
781 self.assertRaises(BufferError, delitem)
782 self.assertEquals(b, orig)
783 # deleting a non-contiguous slice
784 def delslice():
785 b[1:-1:2] = b""
786 self.assertRaises(BufferError, delslice)
787 self.assertEquals(b, orig)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000788
789class AssortedBytesTest(unittest.TestCase):
790 #
791 # Test various combinations of bytes and bytearray
792 #
793
794 def setUp(self):
795 self.warning_filters = warnings.filters[:]
796
797 def tearDown(self):
798 warnings.filters = self.warning_filters
799
800 def test_repr_str(self):
801 warnings.simplefilter('ignore', BytesWarning)
802 for f in str, repr:
803 self.assertEqual(f(bytearray()), "bytearray(b'')")
804 self.assertEqual(f(bytearray([0])), "bytearray(b'\\x00')")
805 self.assertEqual(f(bytearray([0, 1, 254, 255])),
806 "bytearray(b'\\x00\\x01\\xfe\\xff')")
807 self.assertEqual(f(b"abc"), "b'abc'")
808 self.assertEqual(f(b"'"), '''b"'"''') # '''
809 self.assertEqual(f(b"'\""), r"""b'\'"'""") # '
810
811 def test_compare_bytes_to_bytearray(self):
812 self.assertEqual(b"abc" == bytes(b"abc"), True)
813 self.assertEqual(b"ab" != bytes(b"abc"), True)
814 self.assertEqual(b"ab" <= bytes(b"abc"), True)
815 self.assertEqual(b"ab" < bytes(b"abc"), True)
816 self.assertEqual(b"abc" >= bytes(b"ab"), True)
817 self.assertEqual(b"abc" > bytes(b"ab"), True)
818
819 self.assertEqual(b"abc" != bytes(b"abc"), False)
820 self.assertEqual(b"ab" == bytes(b"abc"), False)
821 self.assertEqual(b"ab" > bytes(b"abc"), False)
822 self.assertEqual(b"ab" >= bytes(b"abc"), False)
823 self.assertEqual(b"abc" < bytes(b"ab"), False)
824 self.assertEqual(b"abc" <= bytes(b"ab"), False)
825
826 self.assertEqual(bytes(b"abc") == b"abc", True)
827 self.assertEqual(bytes(b"ab") != b"abc", True)
828 self.assertEqual(bytes(b"ab") <= b"abc", True)
829 self.assertEqual(bytes(b"ab") < b"abc", True)
830 self.assertEqual(bytes(b"abc") >= b"ab", True)
831 self.assertEqual(bytes(b"abc") > b"ab", True)
832
833 self.assertEqual(bytes(b"abc") != b"abc", False)
834 self.assertEqual(bytes(b"ab") == b"abc", False)
835 self.assertEqual(bytes(b"ab") > b"abc", False)
836 self.assertEqual(bytes(b"ab") >= b"abc", False)
837 self.assertEqual(bytes(b"abc") < b"ab", False)
838 self.assertEqual(bytes(b"abc") <= b"ab", False)
839
840 def test_doc(self):
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000841 self.assertTrue(bytearray.__doc__ != None)
842 self.assertTrue(bytearray.__doc__.startswith("bytearray("), bytearray.__doc__)
843 self.assertTrue(bytes.__doc__ != None)
844 self.assertTrue(bytes.__doc__.startswith("bytes("), bytes.__doc__)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000845
846 def test_from_bytearray(self):
847 sample = bytes(b"Hello world\n\x80\x81\xfe\xff")
848 buf = memoryview(sample)
849 b = bytearray(buf)
850 self.assertEqual(b, bytearray(sample))
851
852 def test_to_str(self):
853 warnings.simplefilter('ignore', BytesWarning)
854 self.assertEqual(str(b''), "b''")
855 self.assertEqual(str(b'x'), "b'x'")
856 self.assertEqual(str(b'\x80'), "b'\\x80'")
857 self.assertEqual(str(bytearray(b'')), "bytearray(b'')")
858 self.assertEqual(str(bytearray(b'x')), "bytearray(b'x')")
859 self.assertEqual(str(bytearray(b'\x80')), "bytearray(b'\\x80')")
860
861 def test_literal(self):
862 tests = [
863 (b"Wonderful spam", "Wonderful spam"),
864 (br"Wonderful spam too", "Wonderful spam too"),
865 (b"\xaa\x00\000\200", "\xaa\x00\000\200"),
866 (br"\xaa\x00\000\200", r"\xaa\x00\000\200"),
867 ]
868 for b, s in tests:
869 self.assertEqual(b, bytearray(s, 'latin-1'))
870 for c in range(128, 256):
871 self.assertRaises(SyntaxError, eval,
872 'b"%s"' % chr(c))
873
874 def test_translate(self):
875 b = b'hello'
Georg Brandl6425a2f2008-12-28 11:54:53 +0000876 ba = bytearray(b)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000877 rosetta = bytearray(range(0, 256))
878 rosetta[ord('o')] = ord('e')
879 c = b.translate(rosetta, b'l')
880 self.assertEqual(b, b'hello')
881 self.assertEqual(c, b'hee')
Georg Brandl6425a2f2008-12-28 11:54:53 +0000882 c = ba.translate(rosetta, b'l')
883 self.assertEqual(ba, b'hello')
884 self.assertEqual(c, b'hee')
885 c = b.translate(None, b'e')
886 self.assertEqual(c, b'hllo')
887 c = ba.translate(None, b'e')
888 self.assertEqual(c, b'hllo')
889 self.assertRaises(TypeError, b.translate, None, None)
890 self.assertRaises(TypeError, ba.translate, None, None)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000891
892 def test_split_bytearray(self):
893 self.assertEqual(b'a b'.split(memoryview(b' ')), [b'a', b'b'])
894
895 def test_rsplit_bytearray(self):
896 self.assertEqual(b'a b'.rsplit(memoryview(b' ')), [b'a', b'b'])
897
898 # Optimizations:
899 # __iter__? (optimization)
900 # __reversed__? (optimization)
901
902 # XXX More string methods? (Those that don't use character properties)
903
904 # There are tests in string_tests.py that are more
905 # comprehensive for things like split, partition, etc.
906 # Unfortunately they are all bundled with tests that
907 # are not appropriate for bytes
908
909 # I've started porting some of those into bytearray_tests.py, we should port
910 # the rest that make sense (the code can be cleaned up to use modern
911 # unittest methods at the same time).
912
913class BytearrayPEP3137Test(unittest.TestCase,
914 test.buffer_tests.MixinBytesBufferCommonTests):
915 def marshal(self, x):
916 return bytearray(x)
917
918 def test_returns_new_copy(self):
919 val = self.marshal(b'1234')
920 # On immutable types these MAY return a reference to themselves
921 # but on mutable types like bytearray they MUST return a new copy.
922 for methname in ('zfill', 'rjust', 'ljust', 'center'):
923 method = getattr(val, methname)
924 newval = method(3)
925 self.assertEqual(val, newval)
926 self.assertTrue(val is not newval,
927 methname+' returned self on a mutable object')
928
929
930class FixedStringTest(test.string_tests.BaseTest):
931
932 def fixtype(self, obj):
933 if isinstance(obj, str):
934 return obj.encode("utf-8")
935 return super(FixedStringTest, self).fixtype(obj)
936
937 # Currently the bytes containment testing uses a single integer
938 # value. This may not be the final design, but until then the
939 # bytes section with in a bytes containment not valid
940 def test_contains(self):
941 pass
942 def test_expandtabs(self):
943 pass
944 def test_upper(self):
945 pass
946 def test_lower(self):
947 pass
948 def test_hash(self):
949 # XXX check this out
950 pass
951
952
953class ByteArrayAsStringTest(FixedStringTest):
954 type2test = bytearray
955
956
957class ByteArraySubclass(bytearray):
958 pass
959
960class ByteArraySubclassTest(unittest.TestCase):
961
962 def test_basic(self):
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000963 self.assertTrue(issubclass(ByteArraySubclass, bytearray))
964 self.assertTrue(isinstance(ByteArraySubclass(), bytearray))
Christian Heimes1a6387e2008-03-26 12:49:49 +0000965
966 a, b = b"abcd", b"efgh"
967 _a, _b = ByteArraySubclass(a), ByteArraySubclass(b)
968
969 # test comparison operators with subclass instances
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000970 self.assertTrue(_a == _a)
971 self.assertTrue(_a != _b)
972 self.assertTrue(_a < _b)
973 self.assertTrue(_a <= _b)
974 self.assertTrue(_b >= _a)
975 self.assertTrue(_b > _a)
976 self.assertTrue(_a is not a)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000977
978 # test concat of subclass instances
979 self.assertEqual(a + b, _a + _b)
980 self.assertEqual(a + b, a + _b)
981 self.assertEqual(a + b, _a + b)
982
983 # test repeat
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000984 self.assertTrue(a*5 == _a*5)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000985
986 def test_join(self):
987 # Make sure join returns a NEW object for single item sequences
988 # involving a subclass.
989 # Make sure that it is of the appropriate type.
990 s1 = ByteArraySubclass(b"abcd")
991 s2 = bytearray().join([s1])
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000992 self.assertTrue(s1 is not s2)
993 self.assertTrue(type(s2) is bytearray, type(s2))
Christian Heimes1a6387e2008-03-26 12:49:49 +0000994
995 # Test reverse, calling join on subclass
996 s3 = s1.join([b"abcd"])
Benjamin Peterson5c8da862009-06-30 22:57:08 +0000997 self.assertTrue(type(s3) is bytearray)
Christian Heimes1a6387e2008-03-26 12:49:49 +0000998
999 def test_pickle(self):
1000 a = ByteArraySubclass(b"abcd")
1001 a.x = 10
1002 a.y = ByteArraySubclass(b"efgh")
Hirokazu Yamamoto592c2752008-10-23 00:37:33 +00001003 for proto in range(pickle.HIGHEST_PROTOCOL + 1):
Christian Heimes1a6387e2008-03-26 12:49:49 +00001004 b = pickle.loads(pickle.dumps(a, proto))
1005 self.assertNotEqual(id(a), id(b))
1006 self.assertEqual(a, b)
1007 self.assertEqual(a.x, b.x)
1008 self.assertEqual(a.y, b.y)
1009 self.assertEqual(type(a), type(b))
1010 self.assertEqual(type(a.y), type(b.y))
1011
1012 def test_copy(self):
1013 a = ByteArraySubclass(b"abcd")
1014 a.x = 10
1015 a.y = ByteArraySubclass(b"efgh")
1016 for copy_method in (copy.copy, copy.deepcopy):
1017 b = copy_method(a)
1018 self.assertNotEqual(id(a), id(b))
1019 self.assertEqual(a, b)
1020 self.assertEqual(a.x, b.x)
1021 self.assertEqual(a.y, b.y)
1022 self.assertEqual(type(a), type(b))
1023 self.assertEqual(type(a.y), type(b.y))
1024
1025 def test_init_override(self):
1026 class subclass(bytearray):
1027 def __init__(self, newarg=1, *args, **kwargs):
1028 bytearray.__init__(self, *args, **kwargs)
1029 x = subclass(4, source=b"abcd")
1030 self.assertEqual(x, b"abcd")
1031 x = subclass(newarg=4, source=b"abcd")
1032 self.assertEqual(x, b"abcd")
1033
1034def test_main():
1035 #test.test_support.run_unittest(BytesTest)
1036 #test.test_support.run_unittest(AssortedBytesTest)
1037 #test.test_support.run_unittest(BytesAsStringTest)
1038 test.test_support.run_unittest(
1039 ByteArrayTest,
1040 ByteArrayAsStringTest,
1041 ByteArraySubclassTest,
1042 BytearrayPEP3137Test)
1043
1044if __name__ == "__main__":
1045 test_main()