1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
# Copyright (C) 2006 Canonical Ltd
# Authors: Robert Collins <robert.collins@canonical.com>
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
"""InterVersioned implementation tests for bzr.
These test the conformance of all the interversionedfile variations to the
expected API including generally applicable corner cases.
Specific tests for individual cases are in the tests/test_versionedfile.py file
rather than in tests/interversionedfile_implementations/*.py.
"""
from bzrlib.tests import (
adapt_modules,
default_transport,
TestLoader,
TestScenarioApplier,
TestSuite,
)
class InterVersionedFileTestProviderAdapter(TestScenarioApplier):
"""A tool to generate a suite testing multiple inter versioned-file classes.
This is done by copying the test once for each InterVersionedFile provider
and injecting the transport_server, transport_readonly_server,
versionedfile_factory and versionedfile_factory_to classes into each copy.
Each copy is also given a new id() to make it easy to identify.
"""
def __init__(self, transport_server, transport_readonly_server, formats):
self._transport_server = transport_server
self._transport_readonly_server = transport_readonly_server
self.scenarios = self.formats_to_scenarios(formats)
def formats_to_scenarios(self, formats):
"""Transform the input formats to a list of scenarios.
:param formats: A list of tuples:
(interversionedfile_class, versionedfile_factory,
versionedfile_factory_to).
"""
result = []
for (interversionedfile_class,
versionedfile_factory,
versionedfile_factory_to) in formats:
scenario = (interversionedfile_class.__name__, {
"transport_server":self._transport_server,
"transport_readonly_server":self._transport_readonly_server,
"interversionedfile_class":interversionedfile_class,
"versionedfile_factory":versionedfile_factory,
"versionedfile_factory_to":versionedfile_factory_to,
})
result.append(scenario)
return result
@staticmethod
def default_test_list():
"""Generate the default list of interversionedfile permutations to test."""
from bzrlib.versionedfile import InterVersionedFile
from bzrlib.weave import WeaveFile
from bzrlib.knit import make_file_knit
result = []
# test the fallback InterVersionedFile from annotated knits to weave
result.append((InterVersionedFile,
make_file_knit,
WeaveFile))
for optimiser in InterVersionedFile._optimisers:
result.append((optimiser,
optimiser._matching_file_from_factory,
optimiser._matching_file_to_factory
))
# if there are specific combinations we want to use, we can add them
# here.
return result
def test_suite():
result = TestSuite()
test_interversionedfile_implementations = [
'bzrlib.tests.interversionedfile_implementations.test_join',
]
adapter = InterVersionedFileTestProviderAdapter(
default_transport,
# None here will cause a readonly decorator to be created
# by the TestCaseWithTransport.get_readonly_transport method.
None,
InterVersionedFileTestProviderAdapter.default_test_list()
)
loader = TestLoader()
adapt_modules(test_interversionedfile_implementations, adapter, loader, result)
return result
|