20
20
from StringIO import StringIO
22
from bzrlib.bundle.read_bundle import BundleReader
22
from bzrlib.bundle.serializer import read_bundle
23
23
from bzrlib.bzrdir import BzrDir
24
24
from bzrlib.tests import TestCaseInTempDir
27
27
class TestBundle(TestCaseInTempDir):
30
grandparent_tree = BzrDir.create_standalone_workingtree('grandparent')
31
grandparent_tree.commit('initial commit', rev_id='revision1')
32
parent_bzrdir = grandparent_tree.bzrdir.sprout('parent')
33
parent_tree = parent_bzrdir.open_workingtree()
34
parent_tree.commit('next commit', rev_id='revision2')
35
branch_tree = parent_tree.bzrdir.sprout('branch').open_workingtree()
36
branch_tree.commit('last commit', rev_id='revision3')
29
38
def test_uses_parent(self):
30
39
"""Parent location is used as a basis by default"""
32
parent_tree = BzrDir.create_standalone_workingtree('parent')
33
parent_tree.commit('initial commit', rev_id='revision1')
41
os.chdir('grandparent')
35
42
errmsg = self.run_bzr('bundle', retcode=3)[1]
36
43
self.assertContainsRe(errmsg, 'No base branch known or specified')
37
branch_tree = parent_tree.bzrdir.sprout('../branch').open_workingtree()
38
branch_tree.commit('next commit', rev_id='revision2')
39
branch_tree.commit('last commit', rev_id='revision3')
40
44
os.chdir('../branch')
41
br = BundleReader(StringIO(self.run_bzr('bundle')[0]))
42
self.assertEqual(br.info.revisions[0].revision_id, 'revision3')
43
self.assertEqual(len(br.info.revisions), 2)
44
self.assertEqual(br.info.revisions[1].revision_id, 'revision2')
45
stdout, stderr = self.run_bzr('bundle')
46
self.assertEqual(stderr.count('Using saved location'), 1)
47
br = read_bundle(StringIO(stdout))
48
self.assertRevisions(br, ['revision3'])
50
def assertRevisions(self, bi, expected):
51
self.assertEqual([r.revision_id for r in bi.revisions], expected)
53
def test_uses_submit(self):
54
"""Submit location can be used and set"""
57
br = read_bundle(StringIO(self.run_bzr('bundle')[0]))
58
self.assertRevisions(br, ['revision3'])
59
br = read_bundle(StringIO(self.run_bzr('bundle', '../grandparent')[0]))
60
self.assertRevisions(br, ['revision3', 'revision2'])
61
# submit location should be auto-remembered
62
br = read_bundle(StringIO(self.run_bzr('bundle')[0]))
63
self.assertRevisions(br, ['revision3', 'revision2'])
64
self.run_bzr('bundle', '../parent')
65
br = read_bundle(StringIO(self.run_bzr('bundle')[0]))
66
self.assertRevisions(br, ['revision3', 'revision2'])
67
self.run_bzr('bundle', '../parent', '--remember')
68
br = read_bundle(StringIO(self.run_bzr('bundle')[0]))
69
self.assertRevisions(br, ['revision3'])
70
err = self.run_bzr('bundle', '--remember', retcode=3)[1]
71
self.assertContainsRe(err,
72
'--remember requires a branch to be specified.')
74
def test_revision_branch_interaction(self):
77
bi = read_bundle(StringIO(self.run_bzr('bundle', '../grandparent')[0]))
78
self.assertRevisions(bi, ['revision3', 'revision2'])
79
out = StringIO(self.run_bzr('bundle', '../grandparent', '-r', '-2')[0])
81
self.assertRevisions(bi, ['revision2'])
82
bi = read_bundle(StringIO(self.run_bzr('bundle', '-r', '-2..-1')[0]))
83
self.assertRevisions(bi, ['revision3'])
84
self.run_bzr('bundle', '../grandparent', '-r', '-2..-1', retcode=3)