~bzr-pqm/bzr/bzr.dev

3389.2.5 by John Arbash Meinel
Fix the line endings on test_check and test_reconcile
1
# Copyright (C) 2008 Canonical Ltd
2
#
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
7
#
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
# GNU General Public License for more details.
12
#
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
4183.7.1 by Sabin Iacob
update FSF mailing address
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
3389.2.5 by John Arbash Meinel
Fix the line endings on test_check and test_reconcile
16
3389.2.6 by John Arbash Meinel
minor fix to test file comment
17
"""Tests for branch implementations - test check() functionality"""
3389.2.5 by John Arbash Meinel
Fix the line endings on test_check and test_reconcile
18
4332.3.3 by Robert Collins
Alter Branch.check to log errors rather than raising.
19
from StringIO import StringIO
20
21
from bzrlib import errors, tests, ui
4523.1.1 by Martin Pool
Rename tests.branch_implementations to per_branch
22
from bzrlib.tests.per_branch import TestCaseWithBranch
3389.2.5 by John Arbash Meinel
Fix the line endings on test_check and test_reconcile
23
24
25
class TestBranchCheck(TestCaseWithBranch):
26
27
    def test_check_detects_invalid_revhistory(self):
28
        # Different formats have different ways of handling invalid revision
29
        # histories, so the setup portion is customized
30
        tree = self.make_branch_and_tree('test')
31
        r1 = tree.commit('one')
32
        r2 = tree.commit('two')
33
        r3 = tree.commit('three')
34
        r4 = tree.commit('four')
35
        # create an alternate branch
36
        tree.set_parent_ids([r1])
37
        tree.branch.set_last_revision_info(1, r1)
38
        r2b = tree.commit('two-b')
39
40
        # now go back and merge the commit
41
        tree.set_parent_ids([r4, r2b])
42
        tree.branch.set_last_revision_info(4, r4)
43
44
        r5 = tree.commit('five')
45
        # Now, try to set an invalid history
46
        try:
47
            tree.branch.set_revision_history([r1, r2b, r5])
3489.2.4 by Andrew Bennetts
Fix all tests broken by fixing make_branch_and_tree.
48
            if tree.branch.last_revision_info() != (3, r5):
49
                # RemoteBranch silently corrects an impossible revision
50
                # history given to set_revision_history.  It can be tricked
51
                # with set_last_revision_info though.
52
                tree.branch.set_last_revision_info(3, r5)
3389.2.5 by John Arbash Meinel
Fix the line endings on test_check and test_reconcile
53
        except errors.NotLefthandHistory:
54
            # Branch5 allows set_revision_history to be wrong
55
            # Branch6 raises NotLefthandHistory, but we can force bogus stuff
56
            # with set_last_revision_info
57
            tree.branch.set_last_revision_info(3, r5)
58
4332.3.7 by Robert Collins
Convert Branch.check to take a refs dict as well.
59
        tree.lock_read()
60
        self.addCleanup(tree.unlock)
61
        refs = self.make_refs(tree.branch)
62
        result = tree.branch.check(refs)
4332.3.3 by Robert Collins
Alter Branch.check to log errors rather than raising.
63
        ui.ui_factory = tests.TestUIFactory(stdout=StringIO())
64
        result.report_results(True)
65
        self.assertContainsRe('revno does not match len',
66
            ui.ui_factory.stdout.getvalue())
3389.2.5 by John Arbash Meinel
Fix the line endings on test_check and test_reconcile
67
68
    def test_check_branch_report_results(self):
69
        """Checking a branch produces results which can be printed"""
70
        branch = self.make_branch('.')
4332.3.7 by Robert Collins
Convert Branch.check to take a refs dict as well.
71
        branch.lock_read()
72
        self.addCleanup(branch.unlock)
73
        result = branch.check(self.make_refs(branch))
3389.2.5 by John Arbash Meinel
Fix the line endings on test_check and test_reconcile
74
        # reports results through logging
75
        result.report_results(verbose=True)
76
        result.report_results(verbose=False)
77
4332.3.5 by Robert Collins
Add Branch._get_check_refs.
78
    def test__get_check_refs(self):
79
        tree = self.make_branch_and_tree('.')
80
        revid = tree.commit('foo')
81
        self.assertEqual(
82
            set([('revision-existence', revid), ('lefthand-distance', revid)]),
83
            set(tree.branch._get_check_refs()))
4332.3.7 by Robert Collins
Convert Branch.check to take a refs dict as well.
84
85
    def make_refs(self, branch):
86
        needed_refs = branch._get_check_refs()
87
        refs = {}
88
        distances = set()
89
        existences = set()
90
        for ref in needed_refs:
91
            kind, value = ref
92
            if kind == 'lefthand-distance':
93
                distances.add(value)
94
            elif kind == 'revision-existence':
95
                existences.add(value)
96
            else:
97
                raise AssertionError(
98
                    'unknown ref kind for ref %s' % ref)
99
        node_distances = branch.repository.get_graph().find_lefthand_distances(
100
            distances)
101
        for key, distance in node_distances.iteritems():
102
            refs[('lefthand-distance', key)] = distance
103
            if key in existences and distance > 0:
104
                refs[('revision-existence', key)] = True
105
                existences.remove(key)
106
        parent_map = branch.repository.get_graph().get_parent_map(existences)
107
        for key in parent_map:
108
            refs[('revision-existence', key)] = True
109
            existences.remove(key)
110
        for key in existences:
111
            refs[('revision-existence', key)] = False
112
        return refs