~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/blackbox/test_branch.py

  • Committer: Canonical.com Patch Queue Manager
  • Date: 2007-11-04 18:51:39 UTC
  • mfrom: (2961.1.1 trunk)
  • Revision ID: pqm@pqm.ubuntu.com-20071104185139-kaio3sneodg2kp71
Authentication ring implementation (read-only)

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005, 2006, 2008 Canonical Ltd
 
1
# Copyright (C) 2005, 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
19
19
 
20
20
import os
21
21
 
22
 
from bzrlib import (branch, bzrdir, errors, repository)
 
22
from bzrlib import branch, bzrdir
23
23
from bzrlib.repofmt.knitrepo import RepositoryFormatKnit1
24
24
from bzrlib.tests.blackbox import ExternalBase
25
 
from bzrlib.tests import HardlinkFeature
26
25
from bzrlib.tests.test_sftp_transport import TestCaseWithSFTPServer
27
26
from bzrlib.workingtree import WorkingTree
28
27
 
43
42
        self.example_branch('a')
44
43
        self.run_bzr('branch a b')
45
44
        b = branch.Branch.open('b')
 
45
        self.assertEqual('b\n', b.control_files.get_utf8('branch-name').read())
46
46
        self.run_bzr('branch a c -r 1')
47
 
        # previously was erroneously created by branching
48
 
        self.assertFalse(b._transport.has('branch-name'))
49
47
        b.bzrdir.open_workingtree().commit(message='foo', allow_pointless=True)
50
48
 
51
49
    def test_branch_only_copies_history(self):
86
84
        self.assertFalse(pushed_repo.has_revision('a-2'))
87
85
        self.assertTrue(pushed_repo.has_revision('b-1'))
88
86
 
89
 
    def test_branch_hardlink(self):
90
 
        self.requireFeature(HardlinkFeature)
91
 
        source = self.make_branch_and_tree('source')
92
 
        self.build_tree(['source/file1'])
93
 
        source.add('file1')
94
 
        source.commit('added file')
95
 
        self.run_bzr(['branch', 'source', 'target', '--hardlink'])
96
 
        source_stat = os.stat('source/file1')
97
 
        target_stat = os.stat('target/file1')
98
 
        self.assertEqual(source_stat, target_stat)
99
 
 
100
 
 
101
 
class TestBranchStacked(ExternalBase):
102
 
    """Tests for branch --stacked"""
103
 
 
104
 
    def check_shallow_branch(self, branch_revid, stacked_on):
105
 
        """Assert that the branch 'newbranch' has been published correctly.
106
 
 
107
 
        :param stacked_on: url of a branch this one is stacked upon.
108
 
        :param branch_revid: a revision id that should be the only
109
 
            revision present in the stacked branch, and it should not be in
110
 
            the reference branch.
111
 
        """
112
 
        new_branch = branch.Branch.open('newbranch')
113
 
        # The branch refers to the mainline
114
 
        self.assertEqual(stacked_on, new_branch.get_stacked_on_url())
115
 
        # and the branch's work was pushed
116
 
        self.assertTrue(new_branch.repository.has_revision(branch_revid))
117
 
        # The newly committed revision shoud be present in the stacked branch,
118
 
        # but not in the stacked-on branch.  Because stacking is set up by the
119
 
        # branch object, if we open the stacked branch's repository directly,
120
 
        # bypassing the branch, we see only what's in the stacked repository.
121
 
        stacked_repo = bzrdir.BzrDir.open('newbranch').open_repository()
122
 
        stacked_repo_revisions = set(stacked_repo.all_revision_ids())
123
 
        if len(stacked_repo_revisions) != 1:
124
 
            self.fail("wrong revisions in stacked repository: %r"
125
 
                % (stacked_repo_revisions,))
126
 
 
127
 
    def assertRevisionInRepository(self, repo_path, revid):
128
 
        """Check that a revision is in a repository, disregarding stacking."""
129
 
        repo = bzrdir.BzrDir.open(repo_path).open_repository()
130
 
        self.assertTrue(repo.has_revision(revid))
131
 
 
132
 
    def assertRevisionNotInRepository(self, repo_path, revid):
133
 
        """Check that a revision is not in a repository, disregarding stacking."""
134
 
        repo = bzrdir.BzrDir.open(repo_path).open_repository()
135
 
        self.assertFalse(repo.has_revision(revid))
136
 
 
137
 
    def assertRevisionsInBranchRepository(self, revid_list, branch_path):
138
 
        repo = branch.Branch.open(branch_path).repository
139
 
        self.assertEqual(set(revid_list),
140
 
            repo.has_revisions(revid_list))
141
 
 
142
 
    def test_branch_stacked_branch_not_stacked(self):
143
 
        """Branching a stacked branch is not stacked by default"""
144
 
        # We have a mainline
145
 
        trunk_tree = self.make_branch_and_tree('target',
146
 
            format='development')
147
 
        trunk_tree.commit('mainline')
148
 
        # and a branch from it which is stacked
149
 
        branch_tree = self.make_branch_and_tree('branch',
150
 
            format='development')
151
 
        branch_tree.branch.set_stacked_on_url(trunk_tree.branch.base)
152
 
        # with some work on it
153
 
        branch_tree.commit('moar work plz')
154
 
        # branching our local branch gives us a new stacked branch pointing at
155
 
        # mainline.
156
 
        out, err = self.run_bzr(['branch', 'branch', 'newbranch'])
157
 
        self.assertEqual('', out)
158
 
        self.assertEqual('Branched 1 revision(s).\n',
159
 
            err)
160
 
        # it should have preserved the branch format, and so it should be
161
 
        # capable of supporting stacking, but not actually have a stacked_on
162
 
        # branch configured
163
 
        self.assertRaises(errors.NotStacked,
164
 
            bzrdir.BzrDir.open('newbranch').open_branch().get_stacked_on_url)
165
 
 
166
 
    def test_branch_stacked_branch_stacked(self):
167
 
        """Asking to stack on a stacked branch does work"""
168
 
        # We have a mainline
169
 
        trunk_tree = self.make_branch_and_tree('target',
170
 
            format='development')
171
 
        trunk_revid = trunk_tree.commit('mainline')
172
 
        # and a branch from it which is stacked
173
 
        branch_tree = self.make_branch_and_tree('branch',
174
 
            format='development')
175
 
        branch_tree.branch.set_stacked_on_url(trunk_tree.branch.base)
176
 
        # with some work on it
177
 
        branch_revid = branch_tree.commit('moar work plz')
178
 
        # you can chain branches on from there
179
 
        out, err = self.run_bzr(['branch', 'branch', '--stacked', 'branch2'])
180
 
        self.assertEqual('', out)
181
 
        self.assertEqual('Created new stacked branch referring to %s.\n' %
182
 
            branch_tree.branch.base, err)
183
 
        self.assertEqual(branch_tree.branch.base,
184
 
            branch.Branch.open('branch2').get_stacked_on_url())
185
 
        branch2_tree = WorkingTree.open('branch2')
186
 
        branch2_revid = branch2_tree.commit('work on second stacked branch')
187
 
        self.assertRevisionInRepository('branch2', branch2_revid)
188
 
        self.assertRevisionsInBranchRepository(
189
 
            [trunk_revid, branch_revid, branch2_revid],
190
 
            'branch2')
191
 
 
192
 
    def test_branch_stacked(self):
193
 
        # We have a mainline
194
 
        trunk_tree = self.make_branch_and_tree('mainline',
195
 
            format='development')
196
 
        original_revid = trunk_tree.commit('mainline')
197
 
        self.assertRevisionInRepository('mainline', original_revid)
198
 
        # and a branch from it which is stacked
199
 
        out, err = self.run_bzr(['branch', '--stacked', 'mainline',
200
 
            'newbranch'])
201
 
        self.assertEqual('', out)
202
 
        self.assertEqual('Created new stacked branch referring to %s.\n' %
203
 
            trunk_tree.branch.base, err)
204
 
        self.assertRevisionNotInRepository('newbranch', original_revid)
205
 
        new_tree = WorkingTree.open('newbranch')
206
 
        new_revid = new_tree.commit('new work')
207
 
        self.check_shallow_branch(new_revid, trunk_tree.branch.base)
208
 
 
209
 
    def test_branch_stacked_from_smart_server(self):
210
 
        # We can branch stacking on a smart server
211
 
        from bzrlib.smart.server import SmartTCPServer_for_testing
212
 
        self.transport_server = SmartTCPServer_for_testing
213
 
        trunk = self.make_branch('mainline', format='development')
214
 
        out, err = self.run_bzr(
215
 
            ['branch', '--stacked', self.get_url('mainline'), 'shallow'])
216
 
 
217
 
    def test_branch_stacked_from_non_stacked_format(self):
218
 
        """The origin format doesn't support stacking"""
219
 
        trunk = self.make_branch('trunk', format='pack-0.92')
220
 
        out, err = self.run_bzr(
221
 
            ['branch', '--stacked', 'trunk', 'shallow'])
222
 
        # We should notify the user that we upgraded their format
223
 
        self.assertEqualDiff(
224
 
            'Source format does not support stacking, using format: \'1.6\'\n'
225
 
            '  Packs 5 (adds stacking support, requires bzr 1.6)\n'
226
 
            '\n'
227
 
            'Created new stacked branch referring to %s.\n' % (trunk.base,),
228
 
            err)
229
 
 
230
 
    def test_branch_stacked_from_rich_root_non_stackable(self):
231
 
        trunk = self.make_branch('trunk', format='rich-root-pack')
232
 
        out, err = self.run_bzr(
233
 
            ['branch', '--stacked', 'trunk', 'shallow'])
234
 
        # We should notify the user that we upgraded their format
235
 
        self.assertEqualDiff(
236
 
            'Source format does not support stacking, using format:'
237
 
            ' \'1.6.1-rich-root\'\n'
238
 
            '  Packs 5 rich-root (adds stacking support, requires bzr 1.6.1)\n'
239
 
            '\n'
240
 
            'Created new stacked branch referring to %s.\n' % (trunk.base,),
241
 
            err)
242
 
 
243
 
 
244
87
 
245
88
class TestRemoteBranch(TestCaseWithSFTPServer):
246
89