~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/test_status.py

  • Committer: John Arbash Meinel
  • Date: 2006-05-27 01:54:40 UTC
  • mto: (1711.2.26 jam-integration)
  • mto: This revision was merged to the branch mainline in revision 1734.
  • Revision ID: john@arbash-meinel.com-20060527015440-1a10495d8e56ed5f
deprecating appendpath, it does exactly what pathjoin does

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005 Canonical Ltd
 
1
# Copyright (C) 2005 by Canonical Development 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
17
17
 
18
18
from StringIO import StringIO
19
19
 
20
 
from bzrlib import config
21
 
from bzrlib.revisionspec import RevisionSpec
22
 
from bzrlib.status import show_pending_merges, show_tree_status
23
 
from bzrlib.tests import TestCaseWithTransport
24
 
 
25
 
 
26
 
class TestStatus(TestCaseWithTransport):
 
20
from bzrlib.bzrdir import BzrDir
 
21
from bzrlib.status import show_pending_merges
 
22
from bzrlib.tests import TestCaseInTempDir
 
23
 
 
24
 
 
25
class TestStatus(TestCaseInTempDir):
27
26
 
28
27
    def test_pending_none(self):
29
28
        # Test whether show_pending_merges works in a tree with no commits
30
 
        tree = self.make_branch_and_tree('a')
 
29
        tree = BzrDir.create_standalone_workingtree('a')
31
30
        tree.commit('empty commit')
32
 
        tree2 = self.make_branch_and_tree('b')
33
 
        # set a left most parent that is not a present commit
34
 
        tree2.add_parent_tree_id('some-ghost', allow_leftmost_as_ghost=True)
35
 
        # do a merge
36
 
        tree2.merge_from_branch(tree.branch)
 
31
        tree2 = BzrDir.create_standalone_workingtree('b')
 
32
        tree2.branch.fetch(tree.branch)
 
33
        tree2.set_pending_merges([tree.last_revision()])
37
34
        output = StringIO()
38
 
        tree2.lock_read()
39
 
        try:
40
 
            show_pending_merges(tree2, output)
41
 
        finally:
42
 
            tree2.unlock()
 
35
        show_pending_merges(tree2, output)
43
36
        self.assertContainsRe(output.getvalue(), 'empty commit')
44
 
 
45
 
    def test_multiple_pending(self):
46
 
        config.GlobalConfig().set_user_option('email', 'Joe Foo <joe@foo.com>')
47
 
        tree = self.make_branch_and_tree('a')
48
 
        tree.commit('commit 1', timestamp=1196796819, timezone=0)
49
 
        tree2 = tree.bzrdir.clone('b').open_workingtree()
50
 
        tree.commit('commit 2', timestamp=1196796819, timezone=0)
51
 
        tree2.commit('commit 2b', timestamp=1196796819, timezone=0)
52
 
        tree3 = tree2.bzrdir.clone('c').open_workingtree()
53
 
        tree2.commit('commit 3b', timestamp=1196796819, timezone=0)
54
 
        tree3.commit('commit 3c', timestamp=1196796819, timezone=0)
55
 
        tree.merge_from_branch(tree2.branch)
56
 
        tree.merge_from_branch(tree3.branch)
57
 
        output = StringIO()
58
 
        tree.lock_read()
59
 
        self.addCleanup(tree.unlock)
60
 
        show_pending_merges(tree, output)
61
 
        # Even though 2b is in the ancestry of 3c, it should only be displayed
62
 
        # under the first merge parent.
63
 
        self.assertEqualDiff('pending merges:\n'
64
 
                             '  Joe Foo 2007-12-04 commit 3b\n'
65
 
                             '    Joe Foo 2007-12-04 commit 2b\n'
66
 
                             '  Joe Foo 2007-12-04 commit 3c\n',
67
 
                             output.getvalue())
68
 
 
69
 
    def test_with_pending_ghost(self):
70
 
        """Test when a pending merge is itself a ghost"""
71
 
        tree = self.make_branch_and_tree('a')
72
 
        tree.commit('first')
73
 
        tree.add_parent_tree_id('a-ghost-revision')
74
 
        tree.lock_read()
75
 
        self.addCleanup(tree.unlock)
76
 
        output = StringIO()
77
 
        show_pending_merges(tree, output)
78
 
        self.assertEqualDiff('pending merges:\n'
79
 
                             '  (ghost) a-ghost-revision\n',
80
 
                             output.getvalue())
81
 
 
82
 
    def test_pending_with_ghosts(self):
83
 
        """Test when a pending merge's ancestry includes ghosts."""
84
 
        config.GlobalConfig().set_user_option('email', 'Joe Foo <joe@foo.com>')
85
 
        tree = self.make_branch_and_tree('a')
86
 
        tree.commit('empty commit')
87
 
        tree2 = tree.bzrdir.clone('b').open_workingtree()
88
 
        tree2.commit('a non-ghost', timestamp=1196796819, timezone=0)
89
 
        tree2.add_parent_tree_id('a-ghost-revision')
90
 
        tree2.commit('commit with ghost', timestamp=1196796819, timezone=0)
91
 
        tree2.commit('another non-ghost', timestamp=1196796819, timezone=0)
92
 
        tree.merge_from_branch(tree2.branch)
93
 
        tree.lock_read()
94
 
        self.addCleanup(tree.unlock)
95
 
        output = StringIO()
96
 
        show_pending_merges(tree, output)
97
 
        self.assertEqualDiff('pending merges:\n'
98
 
                             '  Joe Foo 2007-12-04 another non-ghost\n'
99
 
                             '    Joe Foo 2007-12-04 commit with ghost\n'
100
 
                             '    (ghost) a-ghost-revision\n'
101
 
                             '    Joe Foo 2007-12-04 a non-ghost\n',
102
 
                             output.getvalue())
103
 
 
104
 
    def tests_revision_to_revision(self):
105
 
        """doing a status between two revision trees should work."""
106
 
        tree = self.make_branch_and_tree('.')
107
 
        r1_id = tree.commit('one', allow_pointless=True)
108
 
        r2_id = tree.commit('two', allow_pointless=True)
109
 
        r2_tree = tree.branch.repository.revision_tree(r2_id)
110
 
        output = StringIO()
111
 
        show_tree_status(tree, to_file=output,
112
 
                     revision=[RevisionSpec.from_string("revid:%s" % r1_id),
113
 
                               RevisionSpec.from_string("revid:%s" % r2_id)])
114
 
        # return does not matter as long as it did not raise.