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