~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/per_branch/test_stacking.py

  • Committer: Vincent Ladeuil
  • Date: 2012-03-13 17:25:29 UTC
  • mfrom: (6499 +trunk)
  • mto: This revision was merged to the branch mainline in revision 6501.
  • Revision ID: v.ladeuil+lp@free.fr-20120313172529-i0suyjnepsor25i7
Merge trunk

Show diffs side-by-side

added added

removed removed

Lines of Context:
18
18
 
19
19
from bzrlib import (
20
20
    branch,
21
 
    bzrdir,
 
21
    controldir,
22
22
    check,
23
23
    errors,
24
24
    )
107
107
 
108
108
    def assertRevisionInRepository(self, repo_path, revid):
109
109
        """Check that a revision is in a repository, disregarding stacking."""
110
 
        repo = bzrdir.BzrDir.open(repo_path).open_repository()
 
110
        repo = controldir.ControlDir.open(repo_path).open_repository()
111
111
        self.assertTrue(repo.has_revision(revid))
112
112
 
113
113
    def assertRevisionNotInRepository(self, repo_path, revid):
114
114
        """Check that a revision is not in a repository, disregarding stacking."""
115
 
        repo = bzrdir.BzrDir.open(repo_path).open_repository()
 
115
        repo = controldir.ControlDir.open(repo_path).open_repository()
116
116
        self.assertFalse(repo.has_revision(revid))
117
117
 
118
118
    def test_get_graph_stacked(self):
150
150
        self.assertRevisionNotInRepository('newbranch', trunk_revid)
151
151
        tree = new_dir.open_branch().create_checkout('local')
152
152
        new_branch_revid = tree.commit('something local')
153
 
        self.assertRevisionNotInRepository('mainline', new_branch_revid)
 
153
        self.assertRevisionNotInRepository(
 
154
            trunk_tree.branch.base, new_branch_revid)
154
155
        self.assertRevisionInRepository('newbranch', new_branch_revid)
155
156
 
156
157
    def test_sprout_stacked_from_smart_server(self):
164
165
            raise TestNotApplicable(e)
165
166
        # Now serve the original mainline from a smart server
166
167
        remote_transport = self.make_smart_server('mainline')
167
 
        remote_bzrdir = bzrdir.BzrDir.open_from_transport(remote_transport)
 
168
        remote_bzrdir = controldir.ControlDir.open_from_transport(remote_transport)
168
169
        # and make branch from the smart server which is stacked
169
170
        new_dir = remote_bzrdir.sprout('newbranch', stacked=True)
170
171
        # stacked repository
171
172
        self.assertRevisionNotInRepository('newbranch', trunk_revid)
172
173
        tree = new_dir.open_branch().create_checkout('local')
173
174
        new_branch_revid = tree.commit('something local')
174
 
        self.assertRevisionNotInRepository('mainline', new_branch_revid)
 
175
        self.assertRevisionNotInRepository(trunk_tree.branch.user_url,
 
176
            new_branch_revid)
175
177
        self.assertRevisionInRepository('newbranch', new_branch_revid)
176
178
 
177
179
    def test_unstack_fetches(self):
482
484
        rtree = target.repository.revision_tree('rev2')
483
485
        rtree.lock_read()
484
486
        self.addCleanup(rtree.unlock)
485
 
        self.assertEqual('new content', rtree.get_file_by_path('a').read())
 
487
        self.assertEqual(
 
488
            'new content',
 
489
            rtree.get_file_text(rtree.path2id('a'), 'a'))
486
490
        self.check_lines_added_or_present(target, 'rev2')
487
491
 
488
492
    def test_transform_fallback_location_hook(self):
511
515
            repo = self.make_repository('repo', shared=True)
512
516
        except errors.IncompatibleFormat:
513
517
            raise TestNotApplicable()
 
518
        if not repo._format.supports_nesting_repositories:
 
519
            raise TestNotApplicable()
514
520
        # Avoid make_branch, which produces standalone branches.
515
521
        bzrdir = self.make_bzrdir('repo/stack-on')
516
522
        try:
546
552
        self.assertEqual({}, repo.get_parent_map(['rev1']))
547
553
        # revision_history should work, even though the history is spread over
548
554
        # multiple repositories.
549
 
        self.assertLength(2, stacked.branch.revision_history())
 
555
        self.assertEquals((2, 'rev2'), stacked.branch.last_revision_info())
550
556
 
551
557
 
552
558
class TestStackingConnections(
568
574
        stacked.set_last_revision_info(1, 'rev-base')
569
575
        stacked_relative = self.make_branch('stacked_relative',
570
576
                                            format=self.bzrdir_format)
571
 
        stacked_relative.set_stacked_on_url('../base')
 
577
        stacked_relative.set_stacked_on_url(base_tree.branch.user_url)
572
578
        stacked.set_last_revision_info(1, 'rev-base')
573
579
        self.start_logging_connections()
574
580