23
23
from bzrlib.bundle.serializer import write_bundle
24
24
import bzrlib.bzrdir
25
25
import bzrlib.errors as errors
26
from bzrlib.symbol_versioning import deprecated_in
26
27
from bzrlib import tests
27
28
from bzrlib.tests.test_transport import TestTransportImplementation
28
29
from bzrlib.tests.test_transport_implementations import TransportTestProviderAdapter
34
35
def load_tests(standard_tests, module, loader):
35
36
"""Multiply tests for tranport implementations."""
36
37
result = loader.suiteClass()
38
transport_tests, remaining_tests = tests.split_suite_by_condition(
39
standard_tests, tests.condition_isinstance((TestReadBundleFromURL)))
37
41
adapter = TransportTestProviderAdapter()
38
for test in tests.iter_suite_tests(standard_tests):
39
result.addTests(adapter.adapt(test))
42
tests.adapt_tests(transport_tests, adapter, result)
44
# No parametrization for the remaining tests
45
result.addTests(remaining_tests)
70
class TestDeprecations(tests.TestCaseInTempDir):
72
def create_test_bundle(self):
73
out, wt = create_bundle_file(self)
74
f = open('test_bundle', 'wb')
76
f.write(out.getvalue())
81
def test_read_bundle_from_url_deprecated(self):
82
wt = self.create_test_bundle()
83
t = bzrlib.transport.get_transport(self.test_dir)
84
url = t.abspath('test_bundle')
85
self.callDeprecated([deprecated_in((1, 12, 0))
86
% 'bzrlib.bundle.read_bundle_from_url'],
87
bzrlib.bundle.read_bundle_from_url,
63
91
class TestReadBundleFromURL(TestTransportImplementation):
64
92
"""Test that read_bundle works properly across multiple transports"""
70
98
out, wt = create_bundle_file(self)
71
99
if self.get_transport().is_readonly():
72
100
f = open('test_bundle', 'wb')
73
f.write(out.getvalue())
102
f.write(out.getvalue())
76
106
self.get_transport().put_file('test_bundle', out)
77
107
self.log('Put to: %s', self.get_url('test_bundle'))
80
def test_read_bundle_from_url(self):
110
def test_read_mergeable_from_url(self):
81
111
self._captureVar('BZR_NO_SMART_VFS', None)
82
112
wt = self.create_test_bundle()
85
info = bzrlib.bundle.read_bundle_from_url(
86
unicode(self.get_url('test_bundle')))
115
# read_mergeable_from_url will invoke get_transport which may *not*
116
# respect self._transport (i.e. returns a transport that is different
117
# from the one we want to test, so we must inject a correct transport
118
# into possible_transports first.
119
t = self.get_transport('test_bundle')
120
possible_transports = [t]
121
info = bzrlib.bundle.read_mergeable_from_url(
122
unicode(self.get_url('test_bundle')),
123
possible_transports=possible_transports)
87
124
revision = info.real_revisions[-1]
88
125
self.assertEqual('commit-1', revision.revision_id)
98
self.assertRaises(errors.NotABundle,
99
bzrlib.bundle.read_bundle_from_url,
135
self.assertRaises(errors.NotABundle,
136
bzrlib.bundle.read_mergeable_from_url,
100
137
self.get_url('tree'))
101
self.assertRaises(errors.NotABundle,
102
bzrlib.bundle.read_bundle_from_url,
138
self.assertRaises(errors.NotABundle,
139
bzrlib.bundle.read_mergeable_from_url,
103
140
self.get_url('tree/a'))
105
def test_read_mergeable_populates_possible_transports(self):
142
def test_read_mergeable_respects_possible_transports(self):
143
t = self.get_transport('test_bundle')
144
if not isinstance(t, bzrlib.transport.ConnectedTransport):
145
# There is no point testing transport reuse for not connected
146
# transports (the test will fail even).
106
148
self._captureVar('BZR_NO_SMART_VFS', None)
107
149
wt = self.create_test_bundle()
110
possible_transports = []
152
# read_mergeable_from_url will invoke get_transport which may *not*
153
# respect self._transport (i.e. returns a transport that is different
154
# from the one we want to test, so we must inject a correct transport
155
# into possible_transports first.
156
possible_transports = [t]
111
157
url = unicode(self.get_url('test_bundle'))
112
158
info = bzrlib.bundle.read_mergeable_from_url(url,
113
159
possible_transports=possible_transports)