/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to breezy/tests/test_read_bundle.py

  • Committer: Jelmer Vernooij
  • Date: 2020-04-05 19:11:34 UTC
  • mto: (7490.7.16 work)
  • mto: This revision was merged to the branch mainline in revision 7501.
  • Revision ID: jelmer@jelmer.uk-20200405191134-0aebh8ikiwygxma5
Populate the .gitignore file.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2006 Canonical Ltd
 
1
# Copyright (C) 2006-2011 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
16
16
 
17
17
"""Test read_bundle works properly across various transports."""
18
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
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
30
 
import bzrlib.transport
31
 
from bzrlib.transport.memory import MemoryTransport
32
 
import bzrlib.urlutils
33
 
 
34
 
 
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, tests.condition_isinstance(TestReadBundleFromURL))
39
 
    return tests.multiply_tests(transport_tests, transport_test_permutations(),
40
 
        remaining_tests)
 
19
import breezy.mergeable
 
20
from ..bzr.bundle.serializer import write_bundle
 
21
import breezy.bzr.bzrdir
 
22
from .. import errors
 
23
from ..sixish import (
 
24
    BytesIO,
 
25
    text_type,
 
26
    )
 
27
from .. import tests
 
28
from .test_transport import TestTransportImplementation
 
29
from .per_transport import transport_test_permutations
 
30
import breezy.transport
 
31
import breezy.urlutils
 
32
from .scenarios import load_tests_apply_scenarios
 
33
 
 
34
 
 
35
load_tests = load_tests_apply_scenarios
41
36
 
42
37
 
43
38
def create_bundle_file(test_case):
44
39
    test_case.build_tree(['tree/', 'tree/a', 'tree/subdir/'])
45
40
 
46
 
    format = bzrlib.bzrdir.BzrDirFormat.get_default_format()
 
41
    format = breezy.bzr.bzrdir.BzrDirFormat.get_default_format()
47
42
 
48
43
    bzrdir = format.initialize('tree')
49
44
    repo = bzrdir.create_repository()
50
 
    branch = repo.bzrdir.create_branch()
51
 
    wt = branch.bzrdir.create_workingtree()
 
45
    branch = repo.controldir.create_branch()
 
46
    wt = branch.controldir.create_workingtree()
52
47
 
53
48
    wt.add(['a', 'subdir/'])
54
 
    wt.commit('new project', rev_id='commit-1')
 
49
    wt.commit('new project', rev_id=b'commit-1')
55
50
 
56
 
    out = cStringIO.StringIO()
57
 
    rev_ids = write_bundle(wt.branch.repository,
58
 
                           wt.get_parent_ids()[0], 'null:', out)
 
51
    out = BytesIO()
 
52
    write_bundle(wt.branch.repository, wt.get_parent_ids()[0], b'null:', out)
59
53
    out.seek(0)
60
54
    return out, wt
61
55
 
62
56
 
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')
68
 
        try:
69
 
            f.write(out.getvalue())
70
 
        finally:
71
 
            f.close()
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
 
 
84
 
class TestReadBundleFromURL(TestTransportImplementation):
 
57
class TestReadMergeableBundleFromURL(TestTransportImplementation):
85
58
    """Test that read_bundle works properly across multiple transports"""
86
59
 
 
60
    scenarios = transport_test_permutations()
 
61
 
87
62
    def setUp(self):
88
 
        super(TestReadBundleFromURL, self).setUp()
 
63
        super(TestReadMergeableBundleFromURL, self).setUp()
89
64
        self.bundle_name = 'test_bundle'
90
65
        # read_mergeable_from_url will invoke get_transport which may *not*
91
66
        # respect self._transport (i.e. returns a transport that is different
92
67
        # from the one we want to test, so we must inject a correct transport
93
68
        # into possible_transports first).
94
69
        self.possible_transports = [self.get_transport(self.bundle_name)]
95
 
        self._captureVar('BZR_NO_SMART_VFS', None)
96
 
        wt = self.create_test_bundle()
 
70
        self.overrideEnv('BRZ_NO_SMART_VFS', None)
 
71
        self.create_test_bundle()
97
72
 
98
73
    def read_mergeable_from_url(self, url):
99
 
        return bzrlib.bundle.read_mergeable_from_url(
 
74
        return breezy.mergeable.read_mergeable_from_url(
100
75
            url, possible_transports=self.possible_transports)
101
76
 
102
77
    def get_url(self, relpath=''):
103
 
        return bzrlib.urlutils.join(self._server.get_url(), relpath)
 
78
        return breezy.urlutils.join(self._server.get_url(), relpath)
104
79
 
105
80
    def create_test_bundle(self):
106
81
        out, wt = create_bundle_file(self)
113
88
 
114
89
    def test_read_mergeable_from_url(self):
115
90
        info = self.read_mergeable_from_url(
116
 
            unicode(self.get_url(self.bundle_name)))
 
91
            text_type(self.get_url(self.bundle_name)))
117
92
        revision = info.real_revisions[-1]
118
 
        self.assertEqual('commit-1', revision.revision_id)
 
93
        self.assertEqual(b'commit-1', revision.revision_id)
119
94
 
120
95
    def test_read_fail(self):
121
96
        # Trying to read from a directory, or non-bundle file
127
102
 
128
103
    def test_read_mergeable_respects_possible_transports(self):
129
104
        if not isinstance(self.get_transport(self.bundle_name),
130
 
                          bzrlib.transport.ConnectedTransport):
 
105
                          breezy.transport.ConnectedTransport):
131
106
            # There is no point testing transport reuse for not connected
132
107
            # transports (the test will fail even).
133
108
            raise tests.TestSkipped(
134
109
                'Need a ConnectedTransport to test transport reuse')
135
 
        url = unicode(self.get_url(self.bundle_name))
136
 
        info = self.read_mergeable_from_url(url)
 
110
        url = text_type(self.get_url(self.bundle_name))
 
111
        self.read_mergeable_from_url(url)
137
112
        self.assertEqual(1, len(self.possible_transports))