46
40
self.assertTrue('number' in s)
47
41
self.assertFalse('color' in s)
48
42
self.assertFalse('42' in s)
49
self.assertEqual(list(s.iter_pairs()),
43
self.assertEquals(list(s.iter_pairs()),
50
44
[('name', 'fred'), ('number', '42')])
51
self.assertEqual(s.get('number'), '42')
52
self.assertEqual(s.get('name'), 'fred')
45
self.assertEquals(s.get('number'), '42')
46
self.assertEquals(s.get('name'), 'fred')
54
48
def test_value_checks(self):
55
49
"""rio checks types on construction"""
56
50
# these aren't enforced at construction time
57
51
## self.assertRaises(ValueError,
58
52
## Stanza, complex=42 + 3j)
59
## self.assertRaises(ValueError,
53
## self.assertRaises(ValueError,
60
54
## Stanza, several=range(10))
62
56
def test_empty_value(self):
115
109
s = read_stanza(lines)
116
110
self.assertTrue('revision' in s)
117
111
self.assertEqualDiff(s.get('revision'), 'mbp@sourcefrog.net-123-abc')
118
self.assertEqual(list(s.iter_pairs()),
112
self.assertEquals(list(s.iter_pairs()),
119
113
[('revision', 'mbp@sourcefrog.net-123-abc'),
120
114
('timestamp', '1130653962'),
121
115
('timezone', '36000'),
122
116
('committer', "Martin Pool <mbp@test.sourcefrog.net>")])
123
self.assertEqual(len(s), 4)
117
self.assertEquals(len(s), 4)
125
119
def test_repeated_field(self):
126
120
"""Repeated field in rio"""
128
for k, v in [('a', '10'), ('b', '20'), ('a', '100'), ('b', '200'),
122
for k, v in [('a', '10'), ('b', '20'), ('a', '100'), ('b', '200'),
129
123
('a', '1000'), ('b', '2000')]:
131
125
s2 = read_stanza(s.to_lines())
132
self.assertEqual(s, s2)
133
self.assertEqual(s.get_all('a'), map(str, [10, 100, 1000]))
134
self.assertEqual(s.get_all('b'), map(str, [20, 200, 2000]))
126
self.assertEquals(s, s2)
127
self.assertEquals(s.get_all('a'), map(str, [10, 100, 1000]))
128
self.assertEquals(s.get_all('b'), map(str, [20, 200, 2000]))
136
130
def test_backslash(self):
137
131
s = Stanza(q='\\')
138
132
t = s.to_string()
139
133
self.assertEqualDiff(t, 'q: \\\n')
140
134
s2 = read_stanza(s.to_lines())
141
self.assertEqual(s, s2)
135
self.assertEquals(s, s2)
143
137
def test_blank_line(self):
144
138
s = Stanza(none='', one='\n', two='\n\n')
145
139
self.assertEqualDiff(s.to_string(), """\
153
147
s2 = read_stanza(s.to_lines())
154
self.assertEqual(s, s2)
148
self.assertEquals(s, s2)
156
150
def test_whitespace_value(self):
157
151
s = Stanza(space=' ', tabs='\t\t\t', combo='\n\t\t\n')
158
152
self.assertEqualDiff(s.to_string(), """\
165
159
s2 = read_stanza(s.to_lines())
166
self.assertEqual(s, s2)
160
self.assertEquals(s, s2)
167
161
self.rio_file_stanzas([s])
169
163
def test_quoted(self):
170
164
"""rio quoted string cases"""
171
s = Stanza(q1='"hello"',
165
s = Stanza(q1='"hello"',
173
167
q3='\n\n"for"\n',
174
168
q4='for\n"\nfor',
181
175
s2 = read_stanza(s.to_lines())
182
self.assertEqual(s, s2)
176
self.assertEquals(s, s2)
183
177
# apparent bug in read_stanza
184
178
# s3 = read_stanza(self.stanzas_to_str([s]))
185
# self.assertEqual(s, s3)
179
# self.assertEquals(s, s3)
187
181
def test_read_empty(self):
188
182
"""Detect end of rio file"""
189
183
s = read_stanza([])
190
184
self.assertEqual(s, None)
191
185
self.assertTrue(s is None)
193
def test_read_nul_byte(self):
194
"""File consisting of a nul byte causes an error."""
195
self.assertRaises(ValueError, read_stanza, ['\0'])
197
def test_read_nul_bytes(self):
198
"""File consisting of many nul bytes causes an error."""
199
self.assertRaises(ValueError, read_stanza, ['\0' * 100])
201
187
def test_read_iter(self):
202
188
"""Read several stanzas from file"""
203
189
tmpf = TemporaryFile()
240
226
s = read_stanza(tmpf)
241
self.assertEqual(s, Stanza(version_header='1'))
227
self.assertEquals(s, Stanza(version_header='1'))
242
228
s = read_stanza(tmpf)
243
self.assertEqual(s, Stanza(name="foo", val='123'))
229
self.assertEquals(s, Stanza(name="foo", val='123'))
244
230
s = read_stanza(tmpf)
245
231
self.assertEqualDiff(s.get('name'), 'quoted')
246
232
self.assertEqualDiff(s.get('address'), ' "Willowglen"\n 42 Wallaby Way\n Sydney')
247
233
s = read_stanza(tmpf)
248
self.assertEqual(s, Stanza(name="bar", val='129319'))
234
self.assertEquals(s, Stanza(name="bar", val='129319'))
249
235
s = read_stanza(tmpf)
250
self.assertEqual(s, None)
236
self.assertEquals(s, None)
251
237
self.check_rio_file(tmpf)
253
239
def check_rio_file(self, real_file):
254
240
real_file.seek(0)
255
241
read_write = rio_file(RioReader(real_file)).read()
256
242
real_file.seek(0)
257
self.assertEqual(read_write, real_file.read())
243
self.assertEquals(read_write, real_file.read())
260
246
def stanzas_to_str(stanzas):
334
320
self.assertRaises(TypeError, s.add, 10, {})
336
322
def test_rio_unicode(self):
323
# intentionally use cStringIO which doesn't accomodate unencoded unicode objects
324
sio = cStringIO.StringIO()
337
325
uni_data = u'\N{KATAKANA LETTER O}'
338
326
s = Stanza(foo=uni_data)
339
self.assertEqual(s.get('foo'), uni_data)
327
self.assertEquals(s.get('foo'), uni_data)
340
328
raw_lines = s.to_lines()
341
self.assertEqual(raw_lines,
329
self.assertEquals(raw_lines,
342
330
['foo: ' + uni_data.encode('utf-8') + '\n'])
343
331
new_s = read_stanza(raw_lines)
344
self.assertEqual(new_s.get('foo'), uni_data)
346
def test_rio_to_unicode(self):
347
uni_data = u'\N{KATAKANA LETTER O}'
348
s = Stanza(foo=uni_data)
349
unicode_str = s.to_unicode()
350
self.assertEqual(u'foo: %s\n' % (uni_data,), unicode_str)
351
new_s = rio.read_stanza_unicode(unicode_str.splitlines(True))
352
self.assertEqual(uni_data, new_s.get('foo'))
354
def test_nested_rio_unicode(self):
355
uni_data = u'\N{KATAKANA LETTER O}'
356
s = Stanza(foo=uni_data)
357
parent_stanza = Stanza(child=s.to_unicode())
358
raw_lines = parent_stanza.to_lines()
359
self.assertEqual(['child: foo: ' + uni_data.encode('utf-8') + '\n',
362
new_parent = read_stanza(raw_lines)
363
child_text = new_parent.get('child')
364
self.assertEqual(u'foo: %s\n' % uni_data, child_text)
365
new_child = rio.read_stanza_unicode(child_text.splitlines(True))
366
self.assertEqual(uni_data, new_child.get('foo'))
368
def mail_munge(self, lines, dos_nl=True):
371
line = re.sub(' *\n', '\n', line)
373
line = re.sub('([^\r])\n', '\\1\r\n', line)
374
new_lines.append(line)
377
def test_patch_rio(self):
378
stanza = Stanza(data='#\n\r\\r ', space=' ' * 255, hash='#' * 255)
379
lines = rio.to_patch_lines(stanza)
381
self.assertContainsRe(line, '^# ')
382
self.assertTrue(72 >= len(line))
383
for line in rio.to_patch_lines(stanza, max_width=12):
384
self.assertTrue(12 >= len(line))
385
new_stanza = rio.read_patch_stanza(self.mail_munge(lines,
387
lines = self.mail_munge(lines)
388
new_stanza = rio.read_patch_stanza(lines)
389
self.assertEqual('#\n\r\\r ', new_stanza.get('data'))
390
self.assertEqual(' '* 255, new_stanza.get('space'))
391
self.assertEqual('#'* 255, new_stanza.get('hash'))
393
def test_patch_rio_linebreaks(self):
394
stanza = Stanza(breaktest='linebreak -/'*30)
395
self.assertContainsRe(rio.to_patch_lines(stanza, 71)[0],
397
stanza = Stanza(breaktest='linebreak-/'*30)
398
self.assertContainsRe(rio.to_patch_lines(stanza, 70)[0],
400
stanza = Stanza(breaktest='linebreak/'*30)
401
self.assertContainsRe(rio.to_patch_lines(stanza, 70)[0],
332
self.assertEquals(new_s.get('foo'), uni_data)