/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
1
# Copyright (C) 2007 Canonical Ltd
2
#
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
7
#
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
# GNU General Public License for more details.
12
#
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
2694.5.14 by Jelmer Vernooij
Fix copyright headers, add _bencode_py.py to the list of files that do not have to have canonical copyright.
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
16
17
"""Tests for bencode structured encoding"""
18
2694.5.8 by Jelmer Vernooij
Use standard infrastructure for testing python and pyrex bencode implementations.
19
from bzrlib import tests
20
21
def load_tests(standard_tests, module, loader):
4913.3.1 by John Arbash Meinel
Implement a permute_for_extension helper.
22
    suite, _ = tests.permute_tests_for_extension(standard_tests, loader,
23
        'bzrlib.util._bencode_py', 'bzrlib._bencode_pyx')
2694.5.8 by Jelmer Vernooij
Use standard infrastructure for testing python and pyrex bencode implementations.
24
    return suite
25
26
27
class TestBencodeDecode(tests.TestCase):
28
29
    bencode = None
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
30
31
    def _check(self, expected, source):
32
        self.assertEquals(expected, self.bencode.bdecode(source))
33
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
34
    def _run_check_error(self, exc, bad):
35
        """Check that bdecoding a string raises a particular exception."""
36
        self.assertRaises(exc, self.bencode.bdecode, bad)
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
37
38
    def test_int(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
39
        self._check(0, 'i0e')
40
        self._check(4, 'i4e')
41
        self._check(123456789, 'i123456789e')
42
        self._check(-10, 'i-10e')
2694.5.19 by Jelmer Vernooij
Support longs in the pyrex extensions, avoid memcpy.
43
        self._check(int('1' * 1000), 'i' + ('1' * 1000) + 'e')
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
44
45
    def test_long(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
46
        self._check(12345678901234567890L, 'i12345678901234567890e')
47
        self._check(-12345678901234567890L, 'i-12345678901234567890e')
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
48
49
    def test_malformed_int(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
50
        self._run_check_error(ValueError, 'ie')
51
        self._run_check_error(ValueError, 'i-e')
52
        self._run_check_error(ValueError, 'i-010e')
53
        self._run_check_error(ValueError, 'i-0e')
54
        self._run_check_error(ValueError, 'i00e')
55
        self._run_check_error(ValueError, 'i01e')
56
        self._run_check_error(ValueError, 'i-03e')
57
        self._run_check_error(ValueError, 'i')
58
        self._run_check_error(ValueError, 'i123')
59
        self._run_check_error(ValueError, 'i341foo382e')
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
60
61
    def test_string(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
62
        self._check('', '0:')
63
        self._check('abc', '3:abc')
64
        self._check('1234567890', '10:1234567890')
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
65
2694.5.10 by Jelmer Vernooij
Add some more tests.
66
    def test_large_string(self):
67
        self.assertRaises(ValueError, self.bencode.bdecode, "2147483639:foo")
68
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
69
    def test_malformed_string(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
70
        self._run_check_error(ValueError, '10:x')
71
        self._run_check_error(ValueError, '10:')
72
        self._run_check_error(ValueError, '10')
73
        self._run_check_error(ValueError, '01:x')
74
        self._run_check_error(ValueError, '00:')
75
        self._run_check_error(ValueError, '35208734823ljdahflajhdf')
76
        self._run_check_error(ValueError, '432432432432432:foo')
4398.5.14 by John Arbash Meinel
Some small tweaks to decoding strings (avoid passing over the length 2x)
77
        self._run_check_error(ValueError, ' 1:x') # leading whitespace
78
        self._run_check_error(ValueError, '-1:x') # negative
79
        self._run_check_error(ValueError, '1 x') # space vs colon
80
        self._run_check_error(ValueError, '1x') # missing colon
81
        self._run_check_error(ValueError, ('1' * 1000) + ':')
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
82
83
    def test_list(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
84
        self._check([], 'le')
85
        self._check(['', '', ''], 'l0:0:0:e')
86
        self._check([1, 2, 3], 'li1ei2ei3ee')
87
        self._check(['asd', 'xy'], 'l3:asd2:xye')
88
        self._check([['Alice', 'Bob'], [2, 3]], 'll5:Alice3:Bobeli2ei3eee')
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
89
2694.5.20 by Jelmer Vernooij
add handling of deep nesting.
90
    def test_list_deepnested(self):
91
        self._run_check_error(RuntimeError, ("l" * 10000) + ("e" * 10000))
92
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
93
    def test_malformed_list(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
94
        self._run_check_error(ValueError, 'l')
95
        self._run_check_error(ValueError, 'l01:ae')
96
        self._run_check_error(ValueError, 'l0:')
97
        self._run_check_error(ValueError, 'li1e')
98
        self._run_check_error(ValueError, 'l-3:e')
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
99
100
    def test_dict(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
101
        self._check({}, 'de')
102
        self._check({'':3}, 'd0:i3ee')
103
        self._check({'age': 25, 'eyes': 'blue'}, 'd3:agei25e4:eyes4:bluee')
104
        self._check({'spam.mp3': {'author': 'Alice', 'length': 100000}},
105
                            'd8:spam.mp3d6:author5:Alice6:lengthi100000eee')
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
106
2694.5.20 by Jelmer Vernooij
add handling of deep nesting.
107
    def test_dict_deepnested(self):
108
        self._run_check_error(RuntimeError, ("d0:" * 10000) + 'i1e' + ("e" * 10000))
109
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
110
    def test_malformed_dict(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
111
        self._run_check_error(ValueError, 'd')
112
        self._run_check_error(ValueError, 'defoobar')
113
        self._run_check_error(ValueError, 'd3:fooe')
114
        self._run_check_error(ValueError, 'di1e0:e')
115
        self._run_check_error(ValueError, 'd1:b0:1:a0:e')
116
        self._run_check_error(ValueError, 'd1:a0:1:a0:e')
117
        self._run_check_error(ValueError, 'd0:0:')
118
        self._run_check_error(ValueError, 'd0:')
119
        self._run_check_error(ValueError, 'd432432432432432432:e')
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
120
121
    def test_empty_string(self):
2694.5.9 by Jelmer Vernooij
Fix tests.
122
        self.assertRaises(ValueError, self.bencode.bdecode, '')
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
123
124
    def test_junk(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
125
        self._run_check_error(ValueError, 'i6easd')
126
        self._run_check_error(ValueError, '2:abfdjslhfld')
127
        self._run_check_error(ValueError, '0:0:')
128
        self._run_check_error(ValueError, 'leanfdldjfh')
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
129
130
    def test_unknown_object(self):
2694.5.9 by Jelmer Vernooij
Fix tests.
131
        self.assertRaises(ValueError, self.bencode.bdecode, 'relwjhrlewjh')
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
132
2694.5.8 by Jelmer Vernooij
Use standard infrastructure for testing python and pyrex bencode implementations.
133
    def test_unsupported_type(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
134
        self._run_check_error(TypeError, float(1.5))
135
        self._run_check_error(TypeError, None)
136
        self._run_check_error(TypeError, lambda x: x)
137
        self._run_check_error(TypeError, object)
138
        self._run_check_error(TypeError, u"ie")
2694.5.9 by Jelmer Vernooij
Fix tests.
139
140
    def test_decoder_type_error(self):
141
        self.assertRaises(TypeError, self.bencode.bdecode, 1)
2694.5.8 by Jelmer Vernooij
Use standard infrastructure for testing python and pyrex bencode implementations.
142
143
144
class TestBencodeEncode(tests.TestCase):
145
146
    bencode = None
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
147
148
    def _check(self, expected, source):
149
        self.assertEquals(expected, self.bencode.bencode(source))
150
151
    def test_int(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
152
        self._check('i4e', 4)
153
        self._check('i0e', 0)
154
        self._check('i-10e', -10)
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
155
156
    def test_long(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
157
        self._check('i12345678901234567890e', 12345678901234567890L)
158
        self._check('i-12345678901234567890e', -12345678901234567890L)
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
159
160
    def test_string(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
161
        self._check('0:', '')
162
        self._check('3:abc', 'abc')
163
        self._check('10:1234567890', '1234567890')
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
164
165
    def test_list(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
166
        self._check('le', [])
167
        self._check('li1ei2ei3ee', [1, 2, 3])
168
        self._check('ll5:Alice3:Bobeli2ei3eee', [['Alice', 'Bob'], [2, 3]])
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
169
2694.5.5 by Jelmer Vernooij
Support bdecode_as_tuple.
170
    def test_list_as_tuple(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
171
        self._check('le', ())
172
        self._check('li1ei2ei3ee', (1, 2, 3))
173
        self._check('ll5:Alice3:Bobeli2ei3eee', (('Alice', 'Bob'), (2, 3)))
2694.5.5 by Jelmer Vernooij
Support bdecode_as_tuple.
174
2694.5.20 by Jelmer Vernooij
add handling of deep nesting.
175
    def test_list_deep_nested(self):
176
        top = []
177
        l = top
178
        for i in range(10000):
179
            l.append([])
180
            l = l[0]
181
        self.assertRaises(RuntimeError, self.bencode.bencode, 
182
            top)
183
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
184
    def test_dict(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
185
        self._check('de', {})
186
        self._check('d3:agei25e4:eyes4:bluee', {'age': 25, 'eyes': 'blue'})
187
        self._check('d8:spam.mp3d6:author5:Alice6:lengthi100000eee',
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
188
                            {'spam.mp3': {'author': 'Alice',
189
                                          'length': 100000}})
190
2694.5.20 by Jelmer Vernooij
add handling of deep nesting.
191
    def test_dict_deep_nested(self):
192
        d = top = {}
193
        for i in range(10000):
194
            d[''] = {}
195
            d = d['']
196
        self.assertRaises(RuntimeError, self.bencode.bencode, 
197
            top)
198
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
199
    def test_bencached(self):
200
        self._check('i3e', self.bencode.Bencached(self.bencode.bencode(3)))
201
202
    def test_invalid_dict(self):
2694.5.10 by Jelmer Vernooij
Add some more tests.
203
        self.assertRaises(TypeError, self.bencode.bencode, {1:"foo"})
2694.5.1 by Alexander Belchenko
pyrex bencode (without benchmarks)
204
205
    def test_bool(self):
2694.5.16 by Jelmer Vernooij
Simplify the code a bit more.
206
        self._check('i1e', True)
207
        self._check('i0e', False)
2694.5.10 by Jelmer Vernooij
Add some more tests.
208