/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to bzrlib/tests/test_status.py

First attempt to merge .dev and resolve the conflicts (but tests are 
failing)

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005 by Canonical Development Ltd
 
1
# Copyright (C) 2005 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
17
17
 
18
18
from StringIO import StringIO
19
19
 
 
20
from bzrlib import config
20
21
from bzrlib.revisionspec import RevisionSpec
21
22
from bzrlib.status import show_pending_merges, show_tree_status
22
23
from bzrlib.tests import TestCaseWithTransport
34
35
        # do a merge
35
36
        tree2.merge_from_branch(tree.branch)
36
37
        output = StringIO()
37
 
        show_pending_merges(tree2, output)
 
38
        tree2.lock_read()
 
39
        try:
 
40
            show_pending_merges(tree2, output)
 
41
        finally:
 
42
            tree2.unlock()
38
43
        self.assertContainsRe(output.getvalue(), 'empty commit')
39
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
 
40
104
    def tests_revision_to_revision(self):
41
105
        """doing a status between two revision trees should work."""
42
106
        tree = self.make_branch_and_tree('.')
48
112
                     revision=[RevisionSpec.from_string("revid:%s" % r1_id),
49
113
                               RevisionSpec.from_string("revid:%s" % r2_id)])
50
114
        # return does not matter as long as it did not raise.
 
115
 
 
116
    def test_pending_specific_files(self):
 
117
        """With a specific file list, pending merges are not shown."""
 
118
        tree = self.make_branch_and_tree('tree')
 
119
        self.build_tree_contents([('tree/a', 'content of a\n')])
 
120
        tree.add('a')
 
121
        r1_id = tree.commit('one')
 
122
        alt = tree.bzrdir.sprout('alt').open_workingtree()
 
123
        self.build_tree_contents([('alt/a', 'content of a\nfrom alt\n')])
 
124
        alt_id = alt.commit('alt')
 
125
        tree.merge_from_branch(alt.branch)
 
126
        output = StringIO()
 
127
        show_tree_status(tree, to_file=output)
 
128
        self.assertContainsRe(output.getvalue(), 'pending merges:')
 
129
        output = StringIO()
 
130
        show_tree_status(tree, to_file=output, specific_files=['a'])
 
131
        self.assertNotContainsRe(output.getvalue(), 'pending merges:')