forked from reingart/exercism
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathvariable_length_quantity_test.py
138 lines (109 loc) · 4.23 KB
/
variable_length_quantity_test.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
# These tests are auto-generated with test data from:
# https://github.com/exercism/problem-specifications/tree/main/exercises/variable-length-quantity/canonical-data.json
# File last updated on 2023-07-19
import unittest
from variable_length_quantity import (
decode,
encode,
)
class VariableLengthQuantityTest(unittest.TestCase):
def test_zero(self):
self.assertEqual(encode([0x0]), [0x0])
def test_arbitrary_single_byte(self):
self.assertEqual(encode([0x40]), [0x40])
def test_largest_single_byte(self):
self.assertEqual(encode([0x7F]), [0x7F])
def test_smallest_double_byte(self):
self.assertEqual(encode([0x80]), [0x81, 0x0])
def test_arbitrary_double_byte(self):
self.assertEqual(encode([0x2000]), [0xC0, 0x0])
def test_largest_double_byte(self):
self.assertEqual(encode([0x3FFF]), [0xFF, 0x7F])
def test_smallest_triple_byte(self):
self.assertEqual(encode([0x4000]), [0x81, 0x80, 0x0])
def test_arbitrary_triple_byte(self):
self.assertEqual(encode([0x100000]), [0xC0, 0x80, 0x0])
def test_largest_triple_byte(self):
self.assertEqual(encode([0x1FFFFF]), [0xFF, 0xFF, 0x7F])
def test_smallest_quadruple_byte(self):
self.assertEqual(encode([0x200000]), [0x81, 0x80, 0x80, 0x0])
def test_arbitrary_quadruple_byte(self):
self.assertEqual(encode([0x8000000]), [0xC0, 0x80, 0x80, 0x0])
def test_largest_quadruple_byte(self):
self.assertEqual(encode([0xFFFFFFF]), [0xFF, 0xFF, 0xFF, 0x7F])
def test_smallest_quintuple_byte(self):
self.assertEqual(encode([0x10000000]), [0x81, 0x80, 0x80, 0x80, 0x0])
def test_arbitrary_quintuple_byte(self):
self.assertEqual(encode([0xFF000000]), [0x8F, 0xF8, 0x80, 0x80, 0x0])
def test_maximum_32_bit_integer_input(self):
self.assertEqual(encode([0xFFFFFFFF]), [0x8F, 0xFF, 0xFF, 0xFF, 0x7F])
def test_two_single_byte_values(self):
self.assertEqual(encode([0x40, 0x7F]), [0x40, 0x7F])
def test_two_multi_byte_values(self):
self.assertEqual(
encode([0x4000, 0x123456]), [0x81, 0x80, 0x0, 0xC8, 0xE8, 0x56]
)
def test_many_multi_byte_values(self):
self.assertEqual(
encode([0x2000, 0x123456, 0xFFFFFFF, 0x0, 0x3FFF, 0x4000]),
[
0xC0,
0x0,
0xC8,
0xE8,
0x56,
0xFF,
0xFF,
0xFF,
0x7F,
0x0,
0xFF,
0x7F,
0x81,
0x80,
0x0,
],
)
def test_one_byte(self):
self.assertEqual(decode([0x7F]), [0x7F])
def test_two_bytes(self):
self.assertEqual(decode([0xC0, 0x0]), [0x2000])
def test_three_bytes(self):
self.assertEqual(decode([0xFF, 0xFF, 0x7F]), [0x1FFFFF])
def test_four_bytes(self):
self.assertEqual(decode([0x81, 0x80, 0x80, 0x0]), [0x200000])
def test_maximum_32_bit_integer(self):
self.assertEqual(decode([0x8F, 0xFF, 0xFF, 0xFF, 0x7F]), [0xFFFFFFFF])
def test_incomplete_sequence_causes_error(self):
with self.assertRaises(ValueError) as err:
decode([0xFF])
self.assertEqual(type(err.exception), ValueError)
self.assertEqual(err.exception.args[0], "incomplete sequence")
def test_incomplete_sequence_causes_error_even_if_value_is_zero(self):
with self.assertRaises(ValueError) as err:
decode([0x80])
self.assertEqual(type(err.exception), ValueError)
self.assertEqual(err.exception.args[0], "incomplete sequence")
def test_multiple_values(self):
self.assertEqual(
decode(
[
0xC0,
0x0,
0xC8,
0xE8,
0x56,
0xFF,
0xFF,
0xFF,
0x7F,
0x0,
0xFF,
0x7F,
0x81,
0x80,
0x0,
]
),
[0x2000, 0x123456, 0xFFFFFFF, 0x0, 0x3FFF, 0x4000],
)