41
43
"Reconciliation complete.\n" %
43
t.bzrdir.root_transport.base,
45
t.controldir.root_transport.base,
45
47
self.assertEqualDiff(err, "")
48
50
t = controldir.ControlDir.create_standalone_workingtree('.')
49
51
# an empty inventory with no revision will trigger reconciliation.
50
52
repo = t.branch.repository
51
inv = inventory.Inventory(revision_id='missing')
52
inv.root.revision='missing'
53
inv = inventory.Inventory(revision_id=b'missing')
54
inv.root.revision = b'missing'
54
repo.start_write_group()
55
repo.add_inventory('missing', inv, [])
56
repo.commit_write_group()
56
with repo.lock_write(), WriteGroup(repo):
57
repo.add_inventory(b'missing', inv, [])
58
58
(out, err) = self.run_bzr('reconcile')
59
59
if repo._reconcile_backsup_inventory:
60
60
does_backup_text = (
69
69
"Reconciliation complete.\n" %
71
t.bzrdir.root_transport.base,
71
t.controldir.root_transport.base,
73
73
self.assertEqualDiff(expected, out)
74
74
self.assertEqualDiff(err, "")
77
class TestSmartServerReconcile(tests.TestCaseWithTransport):
79
def test_simple_reconcile(self):
80
self.setup_smart_server_with_call_log()
81
self.make_branch('branch')
82
self.reset_smart_call_log()
83
out, err = self.run_bzr(['reconcile', self.get_url('branch')])
84
# This figure represent the amount of work to perform this use case. It
85
# is entirely ok to reduce this number if a test fails due to rpc_count
86
# being too low. If rpc_count increases, more network roundtrips have
87
# become necessary for this use case. Please do not adjust this number
88
# upwards without agreement from bzr's network support maintainers.
89
self.assertLength(10, self.hpss_calls)
90
self.assertLength(1, self.hpss_connections)
91
self.assertThat(self.hpss_calls, ContainsNoVfsCalls)