~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/test_read_bundle.py

  • Committer: Vincent Ladeuil
  • Date: 2010-10-26 08:08:23 UTC
  • mfrom: (5514.1.1 665100-content-type)
  • mto: This revision was merged to the branch mainline in revision 5516.
  • Revision ID: v.ladeuil+lp@free.fr-20101026080823-3wggo03b7cpn9908
Correctly set the Content-Type header when POSTing http requests

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2006 by Canonical Ltd
 
1
# Copyright (C) 2006 Canonical Ltd
2
2
#
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
12
12
#
13
13
# You should have received a copy of the GNU General Public License
14
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
 
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
16
 
17
17
"""Test read_bundle works properly across various transports."""
18
18
 
23
23
from bzrlib.bundle.serializer import write_bundle
24
24
import bzrlib.bzrdir
25
25
import bzrlib.errors as errors
26
 
from bzrlib.tests import TestCaseInTempDir
 
26
from bzrlib.symbol_versioning import deprecated_in
 
27
from bzrlib import tests
 
28
from bzrlib.tests.test_transport import TestTransportImplementation
 
29
from bzrlib.tests.per_transport import transport_test_permutations
27
30
import bzrlib.transport
28
31
from bzrlib.transport.memory import MemoryTransport
29
32
import bzrlib.urlutils
30
33
 
31
34
 
32
 
# jam 20060615 Originally I thought I should use TestCaseWithTransport
33
 
#       but it turns out that doesn't play well with the transport adapter
34
 
class TestReadBundleFromURL(TestCaseInTempDir):
 
35
def load_tests(standard_tests, module, loader):
 
36
    """Multiply tests for tranport implementations."""
 
37
    transport_tests, remaining_tests = tests.split_suite_by_condition(
 
38
        standard_tests,
 
39
        tests.condition_isinstance(TestReadMergeableBundleFromURL))
 
40
    return tests.multiply_tests(transport_tests, transport_test_permutations(),
 
41
        remaining_tests)
 
42
 
 
43
 
 
44
def create_bundle_file(test_case):
 
45
    test_case.build_tree(['tree/', 'tree/a', 'tree/subdir/'])
 
46
 
 
47
    format = bzrlib.bzrdir.BzrDirFormat.get_default_format()
 
48
 
 
49
    bzrdir = format.initialize('tree')
 
50
    repo = bzrdir.create_repository()
 
51
    branch = repo.bzrdir.create_branch()
 
52
    wt = branch.bzrdir.create_workingtree()
 
53
 
 
54
    wt.add(['a', 'subdir/'])
 
55
    wt.commit('new project', rev_id='commit-1')
 
56
 
 
57
    out = cStringIO.StringIO()
 
58
    rev_ids = write_bundle(wt.branch.repository,
 
59
                           wt.get_parent_ids()[0], 'null:', out)
 
60
    out.seek(0)
 
61
    return out, wt
 
62
 
 
63
 
 
64
class TestReadMergeableBundleFromURL(TestTransportImplementation):
35
65
    """Test that read_bundle works properly across multiple transports"""
36
66
 
37
67
    def setUp(self):
38
 
        super(TestReadBundleFromURL, self).setUp()
39
 
        self._server = self.transport_server()
40
 
        self._server.setUp()
41
 
        self._transport = None
 
68
        super(TestReadMergeableBundleFromURL, self).setUp()
 
69
        self.bundle_name = 'test_bundle'
 
70
        # read_mergeable_from_url will invoke get_transport which may *not*
 
71
        # respect self._transport (i.e. returns a transport that is different
 
72
        # from the one we want to test, so we must inject a correct transport
 
73
        # into possible_transports first).
 
74
        self.possible_transports = [self.get_transport(self.bundle_name)]
 
75
        self._captureVar('BZR_NO_SMART_VFS', None)
 
76
        wt = self.create_test_bundle()
42
77
 
43
 
    def tearDown(self):
44
 
        self._transport = None
45
 
        self._server.tearDown()
46
 
        super(TestReadBundleFromURL, self).tearDown()
47
 
        
48
 
    def get_transport(self):
49
 
        """Return a connected transport to the local directory."""
50
 
        base_url = self._server.get_url()
51
 
        t = bzrlib.transport.get_transport(base_url)
52
 
        if not isinstance(t, self.transport_class):
53
 
            # we want to make sure to construct one particular class, even if
54
 
            # there are several available implementations of this transport;
55
 
            # therefore construct it by hand rather than through the regular
56
 
            # get_transport method
57
 
            t = self.transport_class(base_url)
58
 
        return t
 
78
    def read_mergeable_from_url(self, url):
 
79
        return bzrlib.bundle.read_mergeable_from_url(
 
80
            url, possible_transports=self.possible_transports)
59
81
 
60
82
    def get_url(self, relpath=''):
61
83
        return bzrlib.urlutils.join(self._server.get_url(), relpath)
62
84
 
63
85
    def create_test_bundle(self):
64
 
        # Can't use self.get_transport() because that asserts that 
65
 
        # it is not readonly, so just skip tests where the server is readonly
66
 
        self._transport = self.get_transport()
67
 
        #if isinstance(self._transport, MemoryTransport):
68
 
        #    return None
69
 
        self.build_tree(['tree/', 'tree/a', 'tree/subdir/'])
70
 
 
71
 
        format = bzrlib.bzrdir.BzrDirFormat.get_default_format()
72
 
 
73
 
 
74
 
        bzrdir = format.initialize('tree')
75
 
        repo = bzrdir.create_repository()
76
 
        branch = repo.bzrdir.create_branch()
77
 
        wt = branch.bzrdir.create_workingtree()
78
 
 
79
 
        wt.add(['a', 'subdir/'])
80
 
        wt.commit('new project', rev_id='commit-1')
81
 
 
82
 
        out = cStringIO.StringIO()
83
 
        rev_ids = write_bundle(wt.branch.repository,
84
 
                               wt.last_revision(), None, out)
85
 
        out.seek(0)
86
 
        if self._transport.is_readonly():
87
 
            f = open('test_bundle', 'wb')
88
 
            f.write(out.getvalue())
89
 
            f.close()
 
86
        out, wt = create_bundle_file(self)
 
87
        if self.get_transport().is_readonly():
 
88
            self.build_tree_contents([(self.bundle_name, out.getvalue())])
90
89
        else:
91
 
            self._transport.put('test_bundle', out)
92
 
            self.log('Put to: %s', self.get_url('test_bundle'))
 
90
            self.get_transport().put_file(self.bundle_name, out)
 
91
            self.log('Put to: %s', self.get_url(self.bundle_name))
93
92
        return wt
94
93
 
95
 
    def test_read_bundle_from_url(self):
96
 
        wt = self.create_test_bundle()
97
 
        if wt is None:
98
 
            return
99
 
 
100
 
        info = bzrlib.bundle.read_bundle_from_url(
101
 
                    self.get_url('test_bundle'))
102
 
        bundle_tree = info.revision_tree(wt.branch.repository, info.target)
103
 
        self.assertEqual('commit-1', bundle_tree.revision_id)
 
94
    def test_read_mergeable_from_url(self):
 
95
        info = self.read_mergeable_from_url(
 
96
            unicode(self.get_url(self.bundle_name)))
 
97
        revision = info.real_revisions[-1]
 
98
        self.assertEqual('commit-1', revision.revision_id)
104
99
 
105
100
    def test_read_fail(self):
106
101
        # Trying to read from a directory, or non-bundle file
107
102
        # should fail with NotABundle
108
 
        wt = self.create_test_bundle()
109
 
        if wt is None:
110
 
            return
 
103
        self.assertRaises(errors.NotABundle,
 
104
                          self.read_mergeable_from_url, self.get_url('tree'))
 
105
        self.assertRaises(errors.NotABundle,
 
106
                          self.read_mergeable_from_url, self.get_url('tree/a'))
111
107
 
112
 
        self.assertRaises(errors.NotABundle, 
113
 
            bzrlib.bundle.read_bundle_from_url, 
114
 
            self.get_url('tree'))
115
 
        self.assertRaises(errors.NotABundle, 
116
 
            bzrlib.bundle.read_bundle_from_url, 
117
 
            self.get_url('tree/a'))
 
108
    def test_read_mergeable_respects_possible_transports(self):
 
109
        if not isinstance(self.get_transport(self.bundle_name),
 
110
                          bzrlib.transport.ConnectedTransport):
 
111
            # There is no point testing transport reuse for not connected
 
112
            # transports (the test will fail even).
 
113
            raise tests.TestSkipped(
 
114
                'Need a ConnectedTransport to test transport reuse')
 
115
        url = unicode(self.get_url(self.bundle_name))
 
116
        info = self.read_mergeable_from_url(url)
 
117
        self.assertEqual(1, len(self.possible_transports))