bzr branch
http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
| 
2052.3.2
by John Arbash Meinel
 Change Copyright .. by Canonical to Copyright ... Canonical  | 
1  | 
# Copyright (C) 2006 Canonical Ltd
 | 
| 
1711.3.2
by John Arbash Meinel
 Add the read_bundle_from_url command, which handles lots of exceptions  | 
2  | 
#
 | 
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.
 | 
|
7  | 
#
 | 
|
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.
 | 
|
12  | 
#
 | 
|
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
 | 
|
| 
4183.7.1
by Sabin Iacob
 update FSF mailing address  | 
15  | 
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 | 
| 
1711.3.2
by John Arbash Meinel
 Add the read_bundle_from_url command, which handles lots of exceptions  | 
16  | 
|
17  | 
"""Test read_bundle works properly across various transports."""
 | 
|
18  | 
||
19  | 
import cStringIO  | 
|
20  | 
import os  | 
|
21  | 
||
22  | 
import bzrlib.bundle  | 
|
23  | 
from bzrlib.bundle.serializer import write_bundle  | 
|
24  | 
import bzrlib.bzrdir  | 
|
25  | 
import bzrlib.errors as errors  | 
|
| 
3988.2.1
by Vincent Ladeuil
 Workaround SSLFile wrong readline prototype and fix bogus tests.  | 
26  | 
from bzrlib.symbol_versioning import deprecated_in  | 
| 
3251.4.11
by Aaron Bentley
 Fix wrong local lookups  | 
27  | 
from bzrlib import tests  | 
| 
1871.1.2
by Robert Collins
 Reduce code duplication in transport-parameterised tests.  | 
28  | 
from bzrlib.tests.test_transport import TestTransportImplementation  | 
| 
4523.1.4
by Martin Pool
 Rename remaining *_implementations tests  | 
29  | 
from bzrlib.tests.per_transport import transport_test_permutations  | 
| 
1711.3.2
by John Arbash Meinel
 Add the read_bundle_from_url command, which handles lots of exceptions  | 
30  | 
import bzrlib.transport  | 
31  | 
from bzrlib.transport.memory import MemoryTransport  | 
|
32  | 
import bzrlib.urlutils  | 
|
33  | 
||
34  | 
||
| 
3302.9.22
by Vincent Ladeuil
 bzrlib.tests.test_read_bundle use load_tests.  | 
35  | 
def load_tests(standard_tests, module, loader):  | 
36  | 
"""Multiply tests for tranport implementations."""  | 
|
| 
3988.2.1
by Vincent Ladeuil
 Workaround SSLFile wrong readline prototype and fix bogus tests.  | 
37  | 
transport_tests, remaining_tests = tests.split_suite_by_condition(  | 
| 
4084.5.1
by Robert Collins
 Bulk update all test adaptation into a single approach, using multiply_tests rather than test adapters.  | 
38  | 
standard_tests, tests.condition_isinstance(TestReadBundleFromURL))  | 
39  | 
return tests.multiply_tests(transport_tests, transport_test_permutations(),  | 
|
40  | 
remaining_tests)  | 
|
| 
3302.9.22
by Vincent Ladeuil
 bzrlib.tests.test_read_bundle use load_tests.  | 
41  | 
|
42  | 
||
| 
3251.4.11
by Aaron Bentley
 Fix wrong local lookups  | 
43  | 
def create_bundle_file(test_case):  | 
44  | 
test_case.build_tree(['tree/', 'tree/a', 'tree/subdir/'])  | 
|
45  | 
||
46  | 
format = bzrlib.bzrdir.BzrDirFormat.get_default_format()  | 
|
47  | 
||
48  | 
bzrdir = format.initialize('tree')  | 
|
49  | 
repo = bzrdir.create_repository()  | 
|
50  | 
branch = repo.bzrdir.create_branch()  | 
|
51  | 
wt = branch.bzrdir.create_workingtree()  | 
|
52  | 
||
53  | 
wt.add(['a', 'subdir/'])  | 
|
54  | 
wt.commit('new project', rev_id='commit-1')  | 
|
55  | 
||
56  | 
out = cStringIO.StringIO()  | 
|
57  | 
rev_ids = write_bundle(wt.branch.repository,  | 
|
58  | 
wt.get_parent_ids()[0], 'null:', out)  | 
|
59  | 
out.seek(0)  | 
|
60  | 
return out, wt  | 
|
61  | 
||
62  | 
||
| 
3988.2.1
by Vincent Ladeuil
 Workaround SSLFile wrong readline prototype and fix bogus tests.  | 
63  | 
class TestDeprecations(tests.TestCaseInTempDir):  | 
64  | 
||
65  | 
def create_test_bundle(self):  | 
|
66  | 
out, wt = create_bundle_file(self)  | 
|
67  | 
f = open('test_bundle', 'wb')  | 
|
| 
3988.2.4
by Vincent Ladeuil
 Fixed as per Martin's review.  | 
68  | 
try:  | 
69  | 
f.write(out.getvalue())  | 
|
70  | 
finally:  | 
|
71  | 
f.close()  | 
|
| 
3988.2.1
by Vincent Ladeuil
 Workaround SSLFile wrong readline prototype and fix bogus tests.  | 
72  | 
return wt  | 
73  | 
||
74  | 
def test_read_bundle_from_url_deprecated(self):  | 
|
75  | 
wt = self.create_test_bundle()  | 
|
76  | 
t = bzrlib.transport.get_transport(self.test_dir)  | 
|
77  | 
url = t.abspath('test_bundle')  | 
|
78  | 
self.callDeprecated([deprecated_in((1, 12, 0))  | 
|
79  | 
% 'bzrlib.bundle.read_bundle_from_url'],  | 
|
80  | 
bzrlib.bundle.read_bundle_from_url,  | 
|
81  | 
url)  | 
|
82  | 
||
83  | 
||
| 
1871.1.2
by Robert Collins
 Reduce code duplication in transport-parameterised tests.  | 
84  | 
class TestReadBundleFromURL(TestTransportImplementation):  | 
| 
1711.3.2
by John Arbash Meinel
 Add the read_bundle_from_url command, which handles lots of exceptions  | 
85  | 
"""Test that read_bundle works properly across multiple transports"""  | 
86  | 
||
| 
4512.1.1
by Vincent Ladeuil
 Fix bug #383920 by inserting the missing Content-Length header.  | 
87  | 
def setUp(self):  | 
88  | 
super(TestReadBundleFromURL, self).setUp()  | 
|
89  | 
self.bundle_name = 'test_bundle'  | 
|
90  | 
        # read_mergeable_from_url will invoke get_transport which may *not*
 | 
|
91  | 
        # respect self._transport (i.e. returns a transport that is different
 | 
|
92  | 
        # from the one we want to test, so we must inject a correct transport
 | 
|
| 
4512.1.2
by Vincent Ladeuil
 lifeless said: try harder :)  | 
93  | 
        # into possible_transports first).
 | 
| 
4512.1.1
by Vincent Ladeuil
 Fix bug #383920 by inserting the missing Content-Length header.  | 
94  | 
self.possible_transports = [self.get_transport(self.bundle_name)]  | 
95  | 
self._captureVar('BZR_NO_SMART_VFS', None)  | 
|
96  | 
wt = self.create_test_bundle()  | 
|
97  | 
||
98  | 
def read_mergeable_from_url(self, url):  | 
|
99  | 
return bzrlib.bundle.read_mergeable_from_url(  | 
|
100  | 
url, possible_transports=self.possible_transports)  | 
|
101  | 
||
| 
1711.3.2
by John Arbash Meinel
 Add the read_bundle_from_url command, which handles lots of exceptions  | 
102  | 
def get_url(self, relpath=''):  | 
103  | 
return bzrlib.urlutils.join(self._server.get_url(), relpath)  | 
|
104  | 
||
105  | 
def create_test_bundle(self):  | 
|
| 
3251.4.11
by Aaron Bentley
 Fix wrong local lookups  | 
106  | 
out, wt = create_bundle_file(self)  | 
| 
1752.2.26
by Martin Pool
 test_read_bundle doesn't need to specially hold a connection open anymore  | 
107  | 
if self.get_transport().is_readonly():  | 
| 
4512.1.1
by Vincent Ladeuil
 Fix bug #383920 by inserting the missing Content-Length header.  | 
108  | 
self.build_tree_contents([(self.bundle_name, out.getvalue())])  | 
| 
1711.3.2
by John Arbash Meinel
 Add the read_bundle_from_url command, which handles lots of exceptions  | 
109  | 
else:  | 
| 
4512.1.1
by Vincent Ladeuil
 Fix bug #383920 by inserting the missing Content-Length header.  | 
110  | 
self.get_transport().put_file(self.bundle_name, out)  | 
111  | 
self.log('Put to: %s', self.get_url(self.bundle_name))  | 
|
| 
1711.3.2
by John Arbash Meinel
 Add the read_bundle_from_url command, which handles lots of exceptions  | 
112  | 
return wt  | 
113  | 
||
| 
3988.2.1
by Vincent Ladeuil
 Workaround SSLFile wrong readline prototype and fix bogus tests.  | 
114  | 
def test_read_mergeable_from_url(self):  | 
| 
4512.1.1
by Vincent Ladeuil
 Fix bug #383920 by inserting the missing Content-Length header.  | 
115  | 
info = self.read_mergeable_from_url(  | 
116  | 
unicode(self.get_url(self.bundle_name)))  | 
|
| 
2520.4.82
by Aaron Bentley
 Fix tests to stop expecting bundles to build trees  | 
117  | 
revision = info.real_revisions[-1]  | 
118  | 
self.assertEqual('commit-1', revision.revision_id)  | 
|
| 
1711.3.2
by John Arbash Meinel
 Add the read_bundle_from_url command, which handles lots of exceptions  | 
119  | 
|
120  | 
def test_read_fail(self):  | 
|
121  | 
        # Trying to read from a directory, or non-bundle file
 | 
|
122  | 
        # should fail with NotABundle
 | 
|
| 
4512.1.1
by Vincent Ladeuil
 Fix bug #383920 by inserting the missing Content-Length header.  | 
123  | 
self.assertRaises(errors.NotABundle,  | 
124  | 
self.read_mergeable_from_url, self.get_url('tree'))  | 
|
125  | 
self.assertRaises(errors.NotABundle,  | 
|
126  | 
self.read_mergeable_from_url, self.get_url('tree/a'))  | 
|
| 
3251.4.10
by Aaron Bentley
 Pull of launchpad locations works (abentley, #181945)  | 
127  | 
|
| 
3988.2.1
by Vincent Ladeuil
 Workaround SSLFile wrong readline prototype and fix bogus tests.  | 
128  | 
def test_read_mergeable_respects_possible_transports(self):  | 
| 
4512.1.1
by Vincent Ladeuil
 Fix bug #383920 by inserting the missing Content-Length header.  | 
129  | 
if not isinstance(self.get_transport(self.bundle_name),  | 
130  | 
bzrlib.transport.ConnectedTransport):  | 
|
| 
3988.2.1
by Vincent Ladeuil
 Workaround SSLFile wrong readline prototype and fix bogus tests.  | 
131  | 
            # There is no point testing transport reuse for not connected
 | 
132  | 
            # transports (the test will fail even).
 | 
|
| 
4512.1.1
by Vincent Ladeuil
 Fix bug #383920 by inserting the missing Content-Length header.  | 
133  | 
raise tests.TestSkipped(  | 
134  | 
'Need a ConnectedTransport to test transport reuse')  | 
|
135  | 
url = unicode(self.get_url(self.bundle_name))  | 
|
136  | 
info = self.read_mergeable_from_url(url)  | 
|
137  | 
self.assertEqual(1, len(self.possible_transports))  |