~bzr-pqm/bzr/bzr.dev

2052.3.1 by John Arbash Meinel
Add tests to cleanup the copyright of all source files
1
# Copyright (C) 2005 Canonical Ltd
1551.6.20 by Aaron Bentley
Add copyright and whitespace
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
1551.6.19 by Aaron Bentley
Fix pending merge status on empty trees
18
from StringIO import StringIO
19
3074.3.2 by John Arbash Meinel
update the ignore list in one-go.
20
from bzrlib import config
1948.4.33 by John Arbash Meinel
Switch from get_revision_spec() to RevisionSpec.from_string() (as advised by Martin)
21
from bzrlib.revisionspec import RevisionSpec
1852.2.1 by Robert Collins
General cleanups - status, add a status test with two revision trees, and commands.py importing of bzrlib.trace.
22
from bzrlib.status import show_pending_merges, show_tree_status
23
from bzrlib.tests import TestCaseWithTransport
24
25
26
class TestStatus(TestCaseWithTransport):
1551.6.20 by Aaron Bentley
Add copyright and whitespace
27
1551.6.19 by Aaron Bentley
Fix pending merge status on empty trees
28
    def test_pending_none(self):
1551.6.20 by Aaron Bentley
Add copyright and whitespace
29
        # Test whether show_pending_merges works in a tree with no commits
1852.2.1 by Robert Collins
General cleanups - status, add a status test with two revision trees, and commands.py importing of bzrlib.trace.
30
        tree = self.make_branch_and_tree('a')
1908.6.7 by Robert Collins
Remove all users of set_pending_merges and add_pending_merge except tests that they work correctly.
31
        tree.commit('empty commit')
1852.2.1 by Robert Collins
General cleanups - status, add a status test with two revision trees, and commands.py importing of bzrlib.trace.
32
        tree2 = self.make_branch_and_tree('b')
1979.2.1 by Robert Collins
(robertc) adds a convenience method "merge_from_branch" to WorkingTree.
33
        # set a left most parent that is not a present commit
1908.6.11 by Robert Collins
Remove usage of tree.pending_merges().
34
        tree2.add_parent_tree_id('some-ghost', allow_leftmost_as_ghost=True)
1908.6.7 by Robert Collins
Remove all users of set_pending_merges and add_pending_merge except tests that they work correctly.
35
        # do a merge
1979.2.1 by Robert Collins
(robertc) adds a convenience method "merge_from_branch" to WorkingTree.
36
        tree2.merge_from_branch(tree.branch)
1551.6.19 by Aaron Bentley
Fix pending merge status on empty trees
37
        output = StringIO()
3074.3.1 by John Arbash Meinel
Fix bug #172657, use Graph.find_difference() rather than ancestry set operations.
38
        tree2.lock_read()
39
        try:
40
            show_pending_merges(tree2, output)
41
        finally:
42
            tree2.unlock()
1551.6.19 by Aaron Bentley
Fix pending merge status on empty trees
43
        self.assertContainsRe(output.getvalue(), 'empty commit')
1852.2.1 by Robert Collins
General cleanups - status, add a status test with two revision trees, and commands.py importing of bzrlib.trace.
44
3074.3.2 by John Arbash Meinel
update the ignore list in one-go.
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)
3377.3.37 by John Arbash Meinel
Ian's first review comments.
52
        tree3 = tree2.bzrdir.clone('c').open_workingtree()
3074.3.2 by John Arbash Meinel
update the ignore list in one-go.
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
        try:
60
            show_pending_merges(tree, output)
61
        finally:
62
            tree.unlock()
3377.3.37 by John Arbash Meinel
Ian's first review comments.
63
        # Even though 2b is in the ancestry of 3c, it should only be displayed
64
        # under the first merge parent.
3074.3.2 by John Arbash Meinel
update the ignore list in one-go.
65
        self.assertEqual('pending merges:\n'
66
                         '  Joe Foo 2007-12-04 commit 3b\n'
67
                         '    Joe Foo 2007-12-04 commit 2b\n'
68
                         '  Joe Foo 2007-12-04 commit 3c\n',
69
                         output.getvalue())
70
1852.2.1 by Robert Collins
General cleanups - status, add a status test with two revision trees, and commands.py importing of bzrlib.trace.
71
    def tests_revision_to_revision(self):
72
        """doing a status between two revision trees should work."""
73
        tree = self.make_branch_and_tree('.')
74
        r1_id = tree.commit('one', allow_pointless=True)
75
        r2_id = tree.commit('two', allow_pointless=True)
76
        r2_tree = tree.branch.repository.revision_tree(r2_id)
77
        output = StringIO()
1948.4.29 by John Arbash Meinel
Remove a few more direct references to RevisionSpec
78
        show_tree_status(tree, to_file=output,
1948.4.33 by John Arbash Meinel
Switch from get_revision_spec() to RevisionSpec.from_string() (as advised by Martin)
79
                     revision=[RevisionSpec.from_string("revid:%s" % r1_id),
80
                               RevisionSpec.from_string("revid:%s" % r2_id)])
1852.2.1 by Robert Collins
General cleanups - status, add a status test with two revision trees, and commands.py importing of bzrlib.trace.
81
        # return does not matter as long as it did not raise.
3298.1.1 by John Arbash Meinel
Only show pending merges when not given a list of specific files.
82
83
    def test_pending_specific_files(self):
84
        """With a specific file list, pending merges are not shown."""
85
        tree = self.make_branch_and_tree('tree')
86
        self.build_tree_contents([('tree/a', 'content of a\n')])
87
        tree.add('a')
88
        r1_id = tree.commit('one')
89
        alt = tree.bzrdir.sprout('alt').open_workingtree()
90
        self.build_tree_contents([('alt/a', 'content of a\nfrom alt\n')])
91
        alt_id = alt.commit('alt')
92
        tree.merge_from_branch(alt.branch)
93
        output = StringIO()
94
        show_tree_status(tree, to_file=output)
95
        self.assertContainsRe(output.getvalue(), 'pending merges:')
96
        output = StringIO()
97
        show_tree_status(tree, to_file=output, specific_files=['a'])
98
        self.assertNotContainsRe(output.getvalue(), 'pending merges:')