/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
3221.11.3 by Robert Collins
Add missing test script.
1
# Copyright (C) 2008 Canonical Ltd
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
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
17
"""Tests for Branch.get_stacked_on and set_stacked_on."""
18
3517.4.12 by Martin Pool
Clearer per-branch-format tests for stacking
19
from bzrlib import (
20
    bzrdir,
21
    errors,
22
    )
23
from bzrlib.revision import NULL_REVISION
3242.3.40 by Aaron Bentley
Turn failing test into KnownFailure
24
from bzrlib.tests import TestNotApplicable, KnownFailure
3221.11.3 by Robert Collins
Add missing test script.
25
from bzrlib.tests.branch_implementations import TestCaseWithBranch
26
27
28
class TestStacking(TestCaseWithBranch):
29
30
    def test_get_set_stacked_on(self):
31
        # branches must either:
32
        # raise UnstackableBranchFormat or
33
        # raise UnstackableRepositoryFormat or
34
        # permit stacking to be done and then return the stacked location.
35
        branch = self.make_branch('branch')
36
        target = self.make_branch('target')
37
        old_format_errors = (
38
            errors.UnstackableBranchFormat,
39
            errors.UnstackableRepositoryFormat,
40
            )
41
        try:
42
            branch.set_stacked_on(target.base)
43
        except old_format_errors:
44
            # if the set failed, so must the get
45
            self.assertRaises(old_format_errors, branch.get_stacked_on)
46
            return
47
        # now we have a stacked branch:
3221.11.6 by Robert Collins
Stackable branch fixes.
48
        self.assertEqual(target.base, branch.get_stacked_on())
3221.11.3 by Robert Collins
Add missing test script.
49
        branch.set_stacked_on(None)
3221.11.6 by Robert Collins
Stackable branch fixes.
50
        self.assertRaises(errors.NotStacked, branch.get_stacked_on)
3221.13.2 by Robert Collins
Add a shallow parameter to bzrdir.sprout, which involved fixing a lateny bug in pack to pack fetching with ghost discovery.
51
3242.5.1 by Jonathan Lange
Allow stacked-on branch locations to be stored as relative URLs.
52
    def test_get_set_stacked_on_relative(self):
53
        # Branches can be stacked on other branches using relative paths.
54
        branch = self.make_branch('branch')
55
        target = self.make_branch('target')
56
        old_format_errors = (
57
            errors.UnstackableBranchFormat,
58
            errors.UnstackableRepositoryFormat,
59
            )
60
        try:
61
            branch.set_stacked_on('../target')
62
        except old_format_errors:
63
            # if the set failed, so must the get
64
            self.assertRaises(old_format_errors, branch.get_stacked_on)
65
            return
66
        self.assertEqual('../target', branch.get_stacked_on())
67
3517.4.12 by Martin Pool
Clearer per-branch-format tests for stacking
68
    def assertRevisionInRepository(self, repo_path, revid):
69
        """Check that a revision is in a repository, disregarding stacking."""
70
        repo = bzrdir.BzrDir.open(repo_path).open_repository()
71
        self.assertTrue(repo.has_revision(revid))
72
73
    def assertRevisionNotInRepository(self, repo_path, revid):
74
        """Check that a revision is not in a repository, disregarding stacking."""
75
        repo = bzrdir.BzrDir.open(repo_path).open_repository()
76
        self.assertFalse(repo.has_revision(revid))
77
78
    def test_get_graph_stacked(self):
79
        """A stacked repository shows the graph of its parent."""
80
        trunk_tree = self.make_branch_and_tree('mainline')
81
        trunk_revid = trunk_tree.commit('mainline')
82
        # make a new branch, and stack on the existing one.  we don't use
83
        # sprout(stacked=True) here because if that is buggy and copies data
84
        # it would cause a false pass of this test.
85
        new_branch = self.make_branch('new_branch')
86
        try:
87
            new_branch.set_stacked_on(trunk_tree.branch.base)
88
        except (errors.UnstackableBranchFormat,
89
            errors.UnstackableRepositoryFormat), e:
90
            raise TestNotApplicable(e)
91
        # reading the graph from the stacked branch's repository should see
92
        # data from the stacked-on branch
93
        new_repo = new_branch.repository
94
        new_repo.lock_read()
95
        try:
96
            self.assertEqual(new_repo.get_parent_map([trunk_revid]),
97
                {trunk_revid: (NULL_REVISION, )})
98
        finally:
99
            new_repo.unlock()
100
101
    def test_sprout_stacked(self):
3221.13.2 by Robert Collins
Add a shallow parameter to bzrdir.sprout, which involved fixing a lateny bug in pack to pack fetching with ghost discovery.
102
        # We have a mainline
103
        trunk_tree = self.make_branch_and_tree('mainline')
104
        trunk_revid = trunk_tree.commit('mainline')
3221.18.4 by Ian Clatworthy
shallow -> stacked
105
        # and make branch from it which is stacked
3221.13.2 by Robert Collins
Add a shallow parameter to bzrdir.sprout, which involved fixing a lateny bug in pack to pack fetching with ghost discovery.
106
        try:
3221.18.4 by Ian Clatworthy
shallow -> stacked
107
            new_dir = trunk_tree.bzrdir.sprout('newbranch', stacked=True)
108
        except (errors.UnstackableBranchFormat,
3517.4.12 by Martin Pool
Clearer per-branch-format tests for stacking
109
            errors.UnstackableRepositoryFormat), e:
110
            raise TestNotApplicable(e)
111
        # stacked repository
112
        self.assertRevisionNotInRepository('newbranch', trunk_revid)
3221.13.2 by Robert Collins
Add a shallow parameter to bzrdir.sprout, which involved fixing a lateny bug in pack to pack fetching with ghost discovery.
113
        new_tree = new_dir.open_workingtree()
114
        new_tree.commit('something local')
115
3242.3.40 by Aaron Bentley
Turn failing test into KnownFailure
116
    def prepare_for_clone(self):
117
        tree = self.make_branch_and_tree('stacked-on')
118
        tree.commit('Added foo')
119
        stacked_bzrdir = tree.branch.bzrdir.sprout(
120
            'stacked', tree.branch.last_revision(), stacked=True)
121
        return stacked_bzrdir
122
123
    def test_clone_from_stacked_branch_preserve_stacking(self):
3242.3.24 by Aaron Bentley
Fix test failures
124
        # We can clone from the bzrdir of a stacked branch. If
125
        # preserve_stacking is True, the cloned branch is stacked on the
126
        # same branch as the original.
3242.3.21 by Jonathan Lange
Preserve stacking in clone
127
        try:
3242.3.40 by Aaron Bentley
Turn failing test into KnownFailure
128
            stacked_bzrdir = self.prepare_for_clone()
3242.3.21 by Jonathan Lange
Preserve stacking in clone
129
        except (errors.UnstackableBranchFormat,
130
                errors.UnstackableRepositoryFormat):
131
            # not a testable combination.
132
            return
3242.3.24 by Aaron Bentley
Fix test failures
133
        cloned_bzrdir = stacked_bzrdir.clone('cloned', preserve_stacking=True)
3242.3.21 by Jonathan Lange
Preserve stacking in clone
134
        try:
135
            self.assertEqual(
136
                stacked_bzrdir.open_branch().get_stacked_on(),
137
                cloned_bzrdir.open_branch().get_stacked_on())
138
        except (errors.UnstackableBranchFormat,
139
                errors.UnstackableRepositoryFormat):
140
            pass
3242.3.40 by Aaron Bentley
Turn failing test into KnownFailure
141
142
    def test_clone_from_stacked_branch_no_preserve_stacking(self):
143
        try:
144
            stacked_bzrdir = self.prepare_for_clone()
145
        except (errors.UnstackableBranchFormat,
146
                errors.UnstackableRepositoryFormat):
147
            # not a testable combination.
148
            return
149
        try:
150
            cloned_unstacked_bzrdir = stacked_bzrdir.clone('cloned-unstacked',
151
                preserve_stacking=False)
152
        except errors.NoSuchRevision:
153
            raise KnownFailure(
154
                'Pack-to-pack fetch does not handle stacking properly.'
155
                ' (#248506)')
156
        else:
157
            self.fail('Expected a failure due to broken fetching.')
3242.3.24 by Aaron Bentley
Fix test failures
158
        unstacked_branch = cloned_unstacked_bzrdir.open_branch()
3242.3.37 by Aaron Bentley
Updates from reviews
159
        self.assertRaises((errors.NotStacked, errors.UnstackableBranchFormat),
160
                          unstacked_branch.get_stacked_on)
161
162
    def test_no_op_preserve_stacking(self):
163
        """With no stacking, preserve_stacking should be a no-op."""
164
        branch = self.make_branch('source')
165
        cloned_bzrdir = branch.bzrdir.clone('cloned', preserve_stacking=True)
166
        self.assertRaises((errors.NotStacked, errors.UnstackableBranchFormat),
167
                          cloned_bzrdir.open_branch().get_stacked_on)
168
169
    def test_sprout_stacking_policy_handling(self):
170
        """Obey policy where possible, ignore otherwise."""
171
        stack_on = self.make_branch('stack-on')
172
        parent_bzrdir = self.make_bzrdir('.', format='default')
173
        parent_bzrdir.get_config().set_default_stack_on('stack-on')
174
        source = self.make_branch('source')
175
        target = source.bzrdir.sprout('target').open_branch()
3242.3.38 by Aaron Bentley
Enhance tests
176
        try:
177
            self.assertEqual('../stack-on', target.get_stacked_on())
178
        except errors.UnstackableBranchFormat:
179
            pass
180
181
    def test_clone_stacking_policy_handling(self):
182
        """Obey policy where possible, ignore otherwise."""
183
        stack_on = self.make_branch('stack-on')
184
        parent_bzrdir = self.make_bzrdir('.', format='default')
185
        parent_bzrdir.get_config().set_default_stack_on('stack-on')
186
        source = self.make_branch('source')
187
        target = source.bzrdir.clone('target').open_branch()
188
        try:
189
            self.assertEqual('../stack-on', target.get_stacked_on())
190
        except errors.UnstackableBranchFormat:
191
            pass