1
# Copyright (C) 2007 Canonical Ltd
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.
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.
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
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18
"""Test operations that check the repository for corruption"""
24
revision as _mod_revision,
26
from bzrlib.repository import _RevisionTextVersionCache
27
from bzrlib.tests import TestNotApplicable
28
from bzrlib.tests.repository_implementations import TestCaseWithRepository
29
from bzrlib.tests.repository_implementations.helpers import (
30
TestCaseWithBrokenRevisionIndex,
34
class TestFindInconsistentRevisionParents(TestCaseWithBrokenRevisionIndex):
36
def test__find_inconsistent_revision_parents(self):
37
"""_find_inconsistent_revision_parents finds revisions with broken
40
repo = self.make_repo_with_extra_ghost_index()
42
[('revision-id', ['incorrect-parent'], [])],
43
list(repo._find_inconsistent_revision_parents()))
45
def test__check_for_inconsistent_revision_parents(self):
46
"""_check_for_inconsistent_revision_parents raises BzrCheckError if
47
there are any revisions with inconsistent parents.
49
repo = self.make_repo_with_extra_ghost_index()
52
repo._check_for_inconsistent_revision_parents)
54
def test__check_for_inconsistent_revision_parents_on_clean_repo(self):
55
"""_check_for_inconsistent_revision_parents does nothing if there are
58
repo = self.make_repository('empty-repo')
59
if not repo.revision_graph_can_have_wrong_parents():
60
raise TestNotApplicable(
61
'%r cannot have corrupt revision index.' % repo)
62
repo._check_for_inconsistent_revision_parents() # nothing happens
64
def test_check_reports_bad_ancestor(self):
65
repo = self.make_repo_with_extra_ghost_index()
66
# XXX: check requires a non-empty revision IDs list, but it ignores the
68
check_object = repo.check(['ignored'])
69
check_object.report_results(verbose=False)
70
log = self._get_log(keep_log_file=True)
71
self.assertContainsRe(
72
log, '1 revisions have incorrect parents in the revision index')
73
check_object.report_results(verbose=True)
74
log = self._get_log(keep_log_file=True)
75
self.assertContainsRe(
77
"revision-id has wrong parents in index: "
78
r"\['incorrect-parent'\] should be \[\]")