1
# Copyright (C) 2006 by 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
"""InterTree implementation tests for bzr.
20
These test the conformance of all the InterTree variations to the expected API.
21
Specific tests for individual variations are in other places such as:
22
- tests/test_workingtree.py
25
import bzrlib.errors as errors
26
from bzrlib.transport import get_transport
27
from bzrlib.tests import (
33
from bzrlib.tests.tree_implementations import (
35
revision_tree_from_workingtree,
38
from bzrlib.tree import InterTree
39
from bzrlib.workingtree import (WorkingTreeFormat,
40
WorkingTreeTestProviderAdapter,
44
class TestCaseWithTwoTrees(TestCaseWithTree):
46
def make_to_branch_and_tree(self, relpath):
47
"""Make a to_workingtree_format branch and tree."""
48
made_control = self.make_bzrdir(relpath,
49
format=self.workingtree_format_to._matchingbzrdir)
50
made_control.create_repository()
51
made_control.create_branch()
52
return self.workingtree_format_to.initialize(made_control)
54
def get_to_tree_no_parents_no_content(self, empty_tree):
55
return super(TestCaseWithTwoTrees, self).get_tree_no_parents_no_content(empty_tree, converter=self.workingtree_to_test_tree_to)
57
class InterTreeTestProviderAdapter(WorkingTreeTestProviderAdapter):
58
"""Generate test suites for each InterTree implementation in bzrlib."""
60
def adapt(self, test):
64
workingtree_to_test_tree,
65
workingtree_format_to,
66
workingtree_to_test_tree_to) in self._formats:
67
new_test = self._clone_test(
69
workingtree_format._matchingbzrdir,
71
intertree_class.__name__)
72
new_test.intertree_class = intertree_class
73
new_test.workingtree_to_test_tree = workingtree_to_test_tree
74
new_test.workingtree_format_to = workingtree_format_to
75
new_test.workingtree_to_test_tree_to = workingtree_to_test_tree_to
76
result.addTest(new_test)
83
# load the tests of the infrastructure for these tests
84
result.addTests(loader.loadTestsFromModuleNames(['bzrlib.tests.intertree_implementations']))
86
default_tree_format = WorkingTreeFormat.get_default_format()
87
test_intertree_implementations = [
88
'bzrlib.tests.intertree_implementations.test_compare',
90
test_intertree_permutations = [
91
# test InterTree with two default-format working trees.
92
(InterTree, default_tree_format, return_parameter,
93
default_tree_format, return_parameter)]
94
for optimiser in InterTree._optimisers:
95
test_intertree_permutations.append(
97
optimiser._matching_from_tree_format, optimiser._from_tree_converter,
98
optimiser._matching_to_tree_format, optimiser._to_tree_converter))
99
adapter = InterTreeTestProviderAdapter(
101
# None here will cause a readonly decorator to be created
102
# by the TestCaseWithTransport.get_readonly_transport method.
104
test_intertree_permutations)
105
adapt_modules(test_intertree_implementations, adapter, loader, result)