242
227
inv = breezy.bzr.xml5.serializer_v5.read_inventory(inp)
243
228
eq = self.assertEqual
245
ie = inv.get_entry(b'bar-20050824000535-6bc48cfad47ed134')
230
ie = inv['bar-20050824000535-6bc48cfad47ed134']
246
231
eq(ie.kind, 'file')
247
eq(ie.revision, b'mbp@foo-00')
232
eq(ie.revision, 'mbp@foo-00')
248
233
eq(ie.name, 'bar')
249
eq(inv.get_entry(ie.parent_id).kind, 'directory')
234
eq(inv[ie.parent_id].kind, 'directory')
251
236
def test_unpack_basis_inventory_5(self):
252
237
"""Unpack canned new-style inventory"""
253
inv = breezy.bzr.xml5.serializer_v5.read_inventory_from_lines(
254
breezy.osutils.split_lines(_basis_inv_v5))
238
inp = BytesIO(_basis_inv_v5)
239
inv = breezy.bzr.xml5.serializer_v5.read_inventory(inp)
255
240
eq = self.assertEqual
258
b'mbp@sourcefrog.net-20050905063503-43948f59fa127d92')
259
ie = inv.get_entry(b'bar-20050824000535-6bc48cfad47ed134')
242
eq(inv.revision_id, 'mbp@sourcefrog.net-20050905063503-43948f59fa127d92')
243
ie = inv['bar-20050824000535-6bc48cfad47ed134']
260
244
eq(ie.kind, 'file')
261
eq(ie.revision, b'mbp@foo-00')
245
eq(ie.revision, 'mbp@foo-00')
262
246
eq(ie.name, 'bar')
263
eq(inv.get_entry(ie.parent_id).kind, 'directory')
247
eq(inv[ie.parent_id].kind, 'directory')
265
249
def test_unpack_inventory_5a(self):
266
inv = breezy.bzr.xml5.serializer_v5.read_inventory_from_lines(
267
breezy.osutils.split_lines(_inventory_v5a), revision_id=b'test-rev-id')
268
self.assertEqual(b'test-rev-id', inv.root.revision)
250
inv = breezy.bzr.xml5.serializer_v5.read_inventory_from_string(
251
_inventory_v5a, revision_id='test-rev-id')
252
self.assertEqual('test-rev-id', inv.root.revision)
270
254
def test_unpack_inventory_5a_cache_and_copy(self):
271
255
# Passing an entry_cache should get populated with the objects
272
256
# But the returned objects should be copies if return_from_cache is
274
258
entry_cache = fifo_cache.FIFOCache()
275
inv = breezy.bzr.xml5.serializer_v5.read_inventory_from_lines(
276
breezy.osutils.split_lines(_inventory_v5a), revision_id=b'test-rev-id',
259
inv = breezy.bzr.xml5.serializer_v5.read_inventory_from_string(
260
_inventory_v5a, revision_id='test-rev-id',
277
261
entry_cache=entry_cache, return_from_cache=False)
278
262
for entry in inv.iter_just_entries():
279
263
key = (entry.file_id, entry.revision)
349
332
def test_pack_revision_5(self):
350
333
"""Pack revision to XML v5"""
351
334
# fixed 20051025, revisions should have final newline
352
rev = breezy.bzr.xml5.serializer_v5.read_revision_from_string(
354
outfile_contents = breezy.bzr.xml5.serializer_v5.write_revision_to_string(rev)
355
self.assertEqual(outfile_contents[-1:], b'\n')
356
self.assertEqualDiff(
358
b''.join(breezy.bzr.xml5.serializer_v5.write_revision_to_lines(rev)))
335
rev = breezy.bzr.xml5.serializer_v5.read_revision_from_string(_revision_v5)
337
breezy.bzr.xml5.serializer_v5.write_revision(rev, outp)
338
outfile_contents = outp.getvalue()
339
self.assertEqual(outfile_contents[-1], '\n')
340
self.assertEqualDiff(outfile_contents, breezy.bzr.xml5.serializer_v5.write_revision_to_string(rev))
359
341
self.assertEqualDiff(outfile_contents, _expected_rev_v5)
361
343
def test_empty_property_value(self):
362
344
"""Create an empty property value check that it serializes correctly"""
363
345
s_v5 = breezy.bzr.xml5.serializer_v5
364
346
rev = s_v5.read_revision_from_string(_revision_v5)
365
props = {'empty': '', 'one': 'one'}
348
props = {'empty':'', 'one':'one'}
366
349
rev.properties = props
367
txt = b''.join(s_v5.write_revision_to_lines(rev))
350
txt = s_v5.write_revision_to_string(rev)
368
351
new_rev = s_v5.read_revision_from_string(txt)
369
352
self.assertEqual(props, new_rev.properties)
371
354
def get_sample_inventory(self):
372
inv = Inventory(b'tree-root-321', revision_id=b'rev_outer')
373
inv.add(inventory.InventoryFile(b'file-id', 'file', b'tree-root-321'))
374
inv.add(inventory.InventoryDirectory(b'dir-id', 'dir',
376
inv.add(inventory.InventoryLink(b'link-id', 'link', b'tree-root-321'))
377
inv.get_entry(b'tree-root-321').revision = b'rev_outer'
378
inv.get_entry(b'dir-id').revision = b'rev_outer'
379
inv.get_entry(b'file-id').revision = b'rev_outer'
380
inv.get_entry(b'file-id').text_sha1 = b'A'
381
inv.get_entry(b'file-id').text_size = 1
382
inv.get_entry(b'link-id').revision = b'rev_outer'
383
inv.get_entry(b'link-id').symlink_target = 'a'
355
inv = Inventory('tree-root-321', revision_id='rev_outer')
356
inv.add(inventory.InventoryFile('file-id', 'file', 'tree-root-321'))
357
inv.add(inventory.InventoryDirectory('dir-id', 'dir',
359
inv.add(inventory.InventoryLink('link-id', 'link', 'tree-root-321'))
360
inv['tree-root-321'].revision = 'rev_outer'
361
inv['dir-id'].revision = 'rev_outer'
362
inv['file-id'].revision = 'rev_outer'
363
inv['file-id'].text_sha1 = 'A'
364
inv['file-id'].text_size = 1
365
inv['link-id'].revision = 'rev_outer'
366
inv['link-id'].symlink_target = 'a'
386
369
def test_roundtrip_inventory_v7(self):
387
370
inv = self.get_sample_inventory()
388
inv.add(inventory.TreeReference(b'nested-id', 'nested', b'tree-root-321',
389
b'rev_outer', b'rev_inner'))
371
inv.add(inventory.TreeReference('nested-id', 'nested', 'tree-root-321',
372
'rev_outer', 'rev_inner'))
373
txt = xml7.serializer_v7.write_inventory_to_string(inv)
390
374
lines = xml7.serializer_v7.write_inventory_to_lines(inv)
391
self.assertEqualDiff(_expected_inv_v7, b''.join(lines))
392
inv2 = xml7.serializer_v7.read_inventory_from_lines(lines)
375
self.assertEqual(breezy.osutils.split_lines(txt), lines)
376
self.assertEqualDiff(_expected_inv_v7, txt)
377
inv2 = xml7.serializer_v7.read_inventory_from_string(txt)
393
378
self.assertEqual(5, len(inv2))
394
379
for path, ie in inv.iter_entries():
395
self.assertEqual(ie, inv2.get_entry(ie.file_id))
380
self.assertEqual(ie, inv2[ie.file_id])
397
382
def test_roundtrip_inventory_v6(self):
398
383
inv = self.get_sample_inventory()
384
txt = xml6.serializer_v6.write_inventory_to_string(inv)
399
385
lines = xml6.serializer_v6.write_inventory_to_lines(inv)
400
self.assertEqualDiff(_expected_inv_v6, b''.join(lines))
401
inv2 = xml6.serializer_v6.read_inventory_from_lines(lines)
386
self.assertEqual(breezy.osutils.split_lines(txt), lines)
387
self.assertEqualDiff(_expected_inv_v6, txt)
388
inv2 = xml6.serializer_v6.read_inventory_from_string(txt)
402
389
self.assertEqual(4, len(inv2))
403
390
for path, ie in inv.iter_entries():
404
self.assertEqual(ie, inv2.get_entry(ie.file_id))
391
self.assertEqual(ie, inv2[ie.file_id])
406
393
def test_wrong_format_v7(self):
407
394
"""Can't accidentally open a file with wrong serializer"""
408
395
s_v6 = breezy.bzr.xml6.serializer_v6
409
396
s_v7 = xml7.serializer_v7
410
self.assertRaises(serializer.UnexpectedInventoryFormat,
411
s_v7.read_inventory_from_lines,
412
breezy.osutils.split_lines(_expected_inv_v5))
413
self.assertRaises(serializer.UnexpectedInventoryFormat,
414
s_v6.read_inventory_from_lines,
415
breezy.osutils.split_lines(_expected_inv_v7))
397
self.assertRaises(errors.UnexpectedInventoryFormat,
398
s_v7.read_inventory_from_string, _expected_inv_v5)
399
self.assertRaises(errors.UnexpectedInventoryFormat,
400
s_v6.read_inventory_from_string, _expected_inv_v7)
417
402
def test_tree_reference(self):
418
403
s_v5 = breezy.bzr.xml5.serializer_v5
419
404
s_v6 = breezy.bzr.xml6.serializer_v6
420
405
s_v7 = xml7.serializer_v7
421
inv = Inventory(b'tree-root-321', revision_id=b'rev-outer')
422
inv.root.revision = b'root-rev'
423
inv.add(inventory.TreeReference(b'nested-id', 'nested', b'tree-root-321',
424
b'rev-outer', b'rev-inner'))
425
self.assertRaises(serializer.UnsupportedInventoryKind,
426
s_v5.write_inventory_to_lines, inv)
427
self.assertRaises(serializer.UnsupportedInventoryKind,
428
s_v6.write_inventory_to_lines, inv)
429
lines = s_v7.write_inventory_to_chunks(inv)
430
inv2 = s_v7.read_inventory_from_lines(lines)
431
self.assertEqual(b'tree-root-321',
432
inv2.get_entry(b'nested-id').parent_id)
433
self.assertEqual(b'rev-outer', inv2.get_entry(b'nested-id').revision)
435
b'rev-inner', inv2.get_entry(b'nested-id').reference_revision)
406
inv = Inventory('tree-root-321', revision_id='rev-outer')
407
inv.root.revision = 'root-rev'
408
inv.add(inventory.TreeReference('nested-id', 'nested', 'tree-root-321',
409
'rev-outer', 'rev-inner'))
410
self.assertRaises(errors.UnsupportedInventoryKind,
411
s_v5.write_inventory_to_string, inv)
412
self.assertRaises(errors.UnsupportedInventoryKind,
413
s_v6.write_inventory_to_string, inv)
414
txt = s_v7.write_inventory_to_string(inv)
415
lines = s_v7.write_inventory_to_lines(inv)
416
self.assertEqual(breezy.osutils.split_lines(txt), lines)
417
inv2 = s_v7.read_inventory_from_string(txt)
418
self.assertEqual('tree-root-321', inv2['nested-id'].parent_id)
419
self.assertEqual('rev-outer', inv2['nested-id'].revision)
420
self.assertEqual('rev-inner', inv2['nested-id'].reference_revision)
437
422
def test_roundtrip_inventory_v8(self):
438
423
inv = self.get_sample_inventory()
439
lines = xml8.serializer_v8.write_inventory_to_lines(inv)
440
inv2 = xml8.serializer_v8.read_inventory_from_lines(lines)
424
txt = xml8.serializer_v8.write_inventory_to_string(inv)
425
inv2 = xml8.serializer_v8.read_inventory_from_string(txt)
441
426
self.assertEqual(4, len(inv2))
442
427
for path, ie in inv.iter_entries():
443
self.assertEqual(ie, inv2.get_entry(ie.file_id))
428
self.assertEqual(ie, inv2[ie.file_id])
445
430
def test_inventory_text_v8(self):
446
431
inv = self.get_sample_inventory()
432
txt = xml8.serializer_v8.write_inventory_to_string(inv)
447
433
lines = xml8.serializer_v8.write_inventory_to_lines(inv)
448
self.assertEqualDiff(_expected_inv_v8, b''.join(lines))
434
self.assertEqual(breezy.osutils.split_lines(txt), lines)
435
self.assertEqualDiff(_expected_inv_v8, txt)
450
437
def test_revision_text_v6(self):
451
438
"""Pack revision to XML v6"""
452
439
rev = breezy.bzr.xml6.serializer_v6.read_revision_from_string(
453
440
_expected_rev_v5)
454
serialized = breezy.bzr.xml6.serializer_v6.write_revision_to_lines(
456
self.assertEqualDiff(b''.join(serialized), _expected_rev_v5)
441
serialized = breezy.bzr.xml6.serializer_v6.write_revision_to_string(rev)
442
self.assertEqualDiff(serialized, _expected_rev_v5)
458
444
def test_revision_text_v7(self):
459
445
"""Pack revision to XML v7"""
460
446
rev = breezy.bzr.xml7.serializer_v7.read_revision_from_string(
461
447
_expected_rev_v5)
462
serialized = breezy.bzr.xml7.serializer_v7.write_revision_to_lines(
464
self.assertEqualDiff(b''.join(serialized), _expected_rev_v5)
448
serialized = breezy.bzr.xml7.serializer_v7.write_revision_to_string(rev)
449
self.assertEqualDiff(serialized, _expected_rev_v5)
466
451
def test_revision_text_v8(self):
467
452
"""Pack revision to XML v8"""
468
453
rev = breezy.bzr.xml8.serializer_v8.read_revision_from_string(
469
454
_expected_rev_v8)
470
serialized = breezy.bzr.xml8.serializer_v8.write_revision_to_lines(
472
self.assertEqualDiff(b''.join(serialized), _expected_rev_v8)
474
def test_revision_text_v8_complex(self):
475
"""Pack revision to XML v8"""
476
rev = breezy.bzr.xml8.serializer_v8.read_revision_from_string(
477
_expected_rev_v8_complex)
478
serialized = breezy.bzr.xml8.serializer_v8.write_revision_to_lines(
480
self.assertEqualDiff(b''.join(serialized), _expected_rev_v8_complex)
455
serialized = breezy.bzr.xml8.serializer_v8.write_revision_to_string(rev)
456
self.assertEqualDiff(serialized, _expected_rev_v8)
482
458
def test_revision_ids_are_utf8(self):
483
459
"""Parsed revision_ids should all be utf-8 strings, not unicode."""
484
460
s_v5 = breezy.bzr.xml5.serializer_v5
485
461
rev = s_v5.read_revision_from_string(_revision_utf8_v5)
486
self.assertEqual(b'erik@b\xc3\xa5gfors-02', rev.revision_id)
487
self.assertIsInstance(rev.revision_id, bytes)
488
self.assertEqual([b'erik@b\xc3\xa5gfors-01'], rev.parent_ids)
462
self.assertEqual('erik@b\xc3\xa5gfors-02', rev.revision_id)
463
self.assertIsInstance(rev.revision_id, str)
464
self.assertEqual(['erik@b\xc3\xa5gfors-01'], rev.parent_ids)
489
465
for parent_id in rev.parent_ids:
490
self.assertIsInstance(parent_id, bytes)
466
self.assertIsInstance(parent_id, str)
491
467
self.assertEqual(u'Include \xb5nicode characters\n', rev.message)
492
self.assertIsInstance(rev.message, str)
468
self.assertIsInstance(rev.message, unicode)
494
470
# ie.revision should either be None or a utf-8 revision id
495
inv = s_v5.read_inventory_from_lines(breezy.osutils.split_lines(_inventory_utf8_v5))
471
inv = s_v5.read_inventory_from_string(_inventory_utf8_v5)
496
472
rev_id_1 = u'erik@b\xe5gfors-01'.encode('utf8')
497
473
rev_id_2 = u'erik@b\xe5gfors-02'.encode('utf8')
498
474
fid_root = u'TRE\xe9_ROOT'.encode('utf8')
503
479
(u'b\xe5r', fid_bar1, fid_root, rev_id_1),
504
480
(u's\xb5bdir', fid_sub, fid_root, rev_id_1),
505
481
(u's\xb5bdir/b\xe5r', fid_bar2, fid_sub, rev_id_2),
507
483
self.assertEqual(rev_id_2, inv.revision_id)
508
self.assertIsInstance(inv.revision_id, bytes)
484
self.assertIsInstance(inv.revision_id, str)
510
486
actual = list(inv.iter_entries_by_dir())
511
487
for ((exp_path, exp_file_id, exp_parent_id, exp_rev_id),
512
488
(act_path, act_ie)) in zip(expected, actual):
513
489
self.assertEqual(exp_path, act_path)
514
self.assertIsInstance(act_path, str)
490
self.assertIsInstance(act_path, unicode)
515
491
self.assertEqual(exp_file_id, act_ie.file_id)
516
self.assertIsInstance(act_ie.file_id, bytes)
492
self.assertIsInstance(act_ie.file_id, str)
517
493
self.assertEqual(exp_parent_id, act_ie.parent_id)
518
494
if exp_parent_id is not None:
519
self.assertIsInstance(act_ie.parent_id, bytes)
495
self.assertIsInstance(act_ie.parent_id, str)
520
496
self.assertEqual(exp_rev_id, act_ie.revision)
521
497
if exp_rev_id is not None:
522
self.assertIsInstance(act_ie.revision, bytes)
498
self.assertIsInstance(act_ie.revision, str)
524
500
self.assertEqual(len(expected), len(actual))
526
def test_serialization_error(self):
527
s_v5 = breezy.bzr.xml5.serializer_v5
528
e = self.assertRaises(
529
serializer.UnexpectedInventoryFormat,
530
s_v5.read_inventory_from_lines, [b"<Notquitexml"])
531
self.assertEqual(str(e), "unclosed token: line 1, column 0")
534
503
class TestEncodeAndEscape(TestCase):
535
504
"""Whitebox testing of the _encode_and_escape function."""