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
27
from bzrlib import tests
26
from bzrlib.tests import TestCaseInTempDir
28
27
from bzrlib.tests.test_transport import TestTransportImplementation
29
from bzrlib.tests.test_transport_implementations import TransportTestProviderAdapter
30
28
import bzrlib.transport
31
29
from bzrlib.transport.memory import MemoryTransport
32
30
import bzrlib.urlutils
35
def load_tests(standard_tests, module, loader):
36
"""Multiply tests for tranport implementations."""
37
result = loader.suiteClass()
38
transport_tests, remaining_tests = tests.split_suite_by_condition(
39
standard_tests, tests.condition_isinstance((TestReadBundleFromURL)))
41
adapter = TransportTestProviderAdapter()
42
tests.adapt_tests(transport_tests, adapter, result)
44
# No parametrization for the remaining tests
45
result.addTests(remaining_tests)
50
def create_bundle_file(test_case):
51
test_case.build_tree(['tree/', 'tree/a', 'tree/subdir/'])
53
format = bzrlib.bzrdir.BzrDirFormat.get_default_format()
55
bzrdir = format.initialize('tree')
56
repo = bzrdir.create_repository()
57
branch = repo.bzrdir.create_branch()
58
wt = branch.bzrdir.create_workingtree()
60
wt.add(['a', 'subdir/'])
61
wt.commit('new project', rev_id='commit-1')
63
out = cStringIO.StringIO()
64
rev_ids = write_bundle(wt.branch.repository,
65
wt.get_parent_ids()[0], 'null:', out)
70
class TestDeprecations(tests.TestCaseInTempDir):
72
def create_test_bundle(self):
73
out, wt = create_bundle_file(self)
74
f = open('test_bundle', 'wb')
75
f.write(out.getvalue())
79
def test_read_bundle_from_url_deprecated(self):
80
wt = self.create_test_bundle()
81
t = bzrlib.transport.get_transport(self.test_dir)
82
url = t.abspath('test_bundle')
83
self.callDeprecated([deprecated_in((1, 12, 0))
84
% 'bzrlib.bundle.read_bundle_from_url'],
85
bzrlib.bundle.read_bundle_from_url,
89
33
class TestReadBundleFromURL(TestTransportImplementation):
90
34
"""Test that read_bundle works properly across multiple transports"""
93
37
return bzrlib.urlutils.join(self._server.get_url(), relpath)
95
39
def create_test_bundle(self):
96
out, wt = create_bundle_file(self)
40
self.build_tree(['tree/', 'tree/a', 'tree/subdir/'])
42
format = bzrlib.bzrdir.BzrDirFormat.get_default_format()
44
bzrdir = format.initialize('tree')
45
repo = bzrdir.create_repository()
46
branch = repo.bzrdir.create_branch()
47
wt = branch.bzrdir.create_workingtree()
49
wt.add(['a', 'subdir/'])
50
wt.commit('new project', rev_id='commit-1')
52
out = cStringIO.StringIO()
53
rev_ids = write_bundle(wt.branch.repository,
54
wt.get_parent_ids()[0], 'null:', out)
97
56
if self.get_transport().is_readonly():
98
57
f = open('test_bundle', 'wb')
99
58
f.write(out.getvalue())
103
62
self.log('Put to: %s', self.get_url('test_bundle'))
106
def test_read_mergeable_from_url(self):
65
def test_read_bundle_from_url(self):
107
66
self._captureVar('BZR_NO_SMART_VFS', None)
108
67
wt = self.create_test_bundle()
111
# read_mergeable_from_url will invoke get_transport which may *not*
112
# respect self._transport (i.e. returns a transport that is different
113
# from the one we want to test, so we must inject a correct transport
114
# into possible_transports first.
115
t = self.get_transport('test_bundle')
116
possible_transports = [t]
117
info = bzrlib.bundle.read_mergeable_from_url(
118
unicode(self.get_url('test_bundle')),
119
possible_transports=possible_transports)
70
info = bzrlib.bundle.read_bundle_from_url(
71
unicode(self.get_url('test_bundle')))
120
72
revision = info.real_revisions[-1]
121
73
self.assertEqual('commit-1', revision.revision_id)
131
self.assertRaises(errors.NotABundle,
132
bzrlib.bundle.read_mergeable_from_url,
83
self.assertRaises(errors.NotABundle,
84
bzrlib.bundle.read_bundle_from_url,
133
85
self.get_url('tree'))
134
self.assertRaises(errors.NotABundle,
135
bzrlib.bundle.read_mergeable_from_url,
86
self.assertRaises(errors.NotABundle,
87
bzrlib.bundle.read_bundle_from_url,
136
88
self.get_url('tree/a'))
138
def test_read_mergeable_respects_possible_transports(self):
139
t = self.get_transport('test_bundle')
140
if not isinstance(t, bzrlib.transport.ConnectedTransport):
141
# There is no point testing transport reuse for not connected
142
# transports (the test will fail even).
144
self._captureVar('BZR_NO_SMART_VFS', None)
145
wt = self.create_test_bundle()
148
# read_mergeable_from_url will invoke get_transport which may *not*
149
# respect self._transport (i.e. returns a transport that is different
150
# from the one we want to test, so we must inject a correct transport
151
# into possible_transports first.
152
possible_transports = [t]
153
url = unicode(self.get_url('test_bundle'))
154
info = bzrlib.bundle.read_mergeable_from_url(url,
155
possible_transports=possible_transports)
156
self.assertEqual(1, len(possible_transports))