/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 bzrlib/tests/test_read_bundle.py

Merge bzr.dev r3466

Show diffs side-by-side

added added

removed removed

Lines of Context:
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 import tests
27
27
from bzrlib.tests.test_transport import TestTransportImplementation
 
28
from bzrlib.tests.test_transport_implementations import TransportTestProviderAdapter
28
29
import bzrlib.transport
29
30
from bzrlib.transport.memory import MemoryTransport
30
31
import bzrlib.urlutils
31
32
 
32
33
 
 
34
def load_tests(standard_tests, module, loader):
 
35
    """Multiply tests for tranport implementations."""
 
36
    result = loader.suiteClass()
 
37
    adapter = TransportTestProviderAdapter()
 
38
    for test in tests.iter_suite_tests(standard_tests):
 
39
        result.addTests(adapter.adapt(test))
 
40
    return result
 
41
 
 
42
 
 
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
 
33
63
class TestReadBundleFromURL(TestTransportImplementation):
34
64
    """Test that read_bundle works properly across multiple transports"""
35
65
 
37
67
        return bzrlib.urlutils.join(self._server.get_url(), relpath)
38
68
 
39
69
    def create_test_bundle(self):
40
 
        self.build_tree(['tree/', 'tree/a', 'tree/subdir/'])
41
 
 
42
 
        format = bzrlib.bzrdir.BzrDirFormat.get_default_format()
43
 
 
44
 
        bzrdir = format.initialize('tree')
45
 
        repo = bzrdir.create_repository()
46
 
        branch = repo.bzrdir.create_branch()
47
 
        wt = branch.bzrdir.create_workingtree()
48
 
 
49
 
        wt.add(['a', 'subdir/'])
50
 
        wt.commit('new project', rev_id='commit-1')
51
 
 
52
 
        out = cStringIO.StringIO()
53
 
        rev_ids = write_bundle(wt.branch.repository,
54
 
                               wt.get_parent_ids()[0], 'null:', out)
55
 
        out.seek(0)
 
70
        out, wt = create_bundle_file(self)
56
71
        if self.get_transport().is_readonly():
57
72
            f = open('test_bundle', 'wb')
58
73
            f.write(out.getvalue())
86
101
        self.assertRaises(errors.NotABundle, 
87
102
            bzrlib.bundle.read_bundle_from_url, 
88
103
            self.get_url('tree/a'))
 
104
 
 
105
    def test_read_mergeable_populates_possible_transports(self):
 
106
        self._captureVar('BZR_NO_SMART_VFS', None)
 
107
        wt = self.create_test_bundle()
 
108
        if wt is None:
 
109
            return
 
110
        possible_transports = []
 
111
        url = unicode(self.get_url('test_bundle'))
 
112
        info = bzrlib.bundle.read_mergeable_from_url(url,
 
113
            possible_transports=possible_transports)
 
114
        self.assertEqual(1, len(possible_transports))