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