/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
915 by Martin Pool
- add simple test case for bzr status
1
# Copyright (C) 2005 by Canonical Ltd
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
18
"""Tests of status command.
19
20
Most of these depend on the particular formatting used.
21
"""
22
23
1185.33.71 by Martin Pool
Status tests include unicode character.
24
from cStringIO import StringIO
25
from os import mkdir
26
from tempfile import TemporaryFile
27
import codecs
28
1185.31.25 by John Arbash Meinel
Renamed all of the tests from selftest/foo.py to tests/test_foo.py
29
from bzrlib.tests import TestCaseInTempDir
1185.1.35 by Robert Collins
Heikki Paajanen's status -r patch
30
from bzrlib.revisionspec import RevisionSpec
1185.12.27 by Aaron Bentley
Use line log for pending merges
31
from bzrlib.merge import merge
32
from bzrlib.status import show_status
33
from bzrlib.branch import Branch
34
from bzrlib.clone import copy_branch
915 by Martin Pool
- add simple test case for bzr status
35
1141 by Martin Pool
- rename FunctionalTest to TestCaseInTempDir
36
class BranchStatus(TestCaseInTempDir):
1102 by Martin Pool
- merge test refactoring from robertc
37
    
38
    def test_branch_status(self): 
1399 by Robert Collins
Patch from Heikki Paajanen testing status on specific files
39
        """Test basic branch status"""
915 by Martin Pool
- add simple test case for bzr status
40
        from bzrlib.status import show_status
41
        from bzrlib.branch import Branch
42
        
1185.33.66 by Martin Pool
[patch] use unicode literals for all hardcoded paths (Alexander Belchenko)
43
        b = Branch.initialize(u'.')
915 by Martin Pool
- add simple test case for bzr status
44
45
        # status with nothing
46
        tof = StringIO()
47
        show_status(b, to_file=tof)
48
        self.assertEquals(tof.getvalue(), "")
49
50
        tof = StringIO()
51
        self.build_tree(['hello.c', 'bye.c'])
1457.1.15 by Robert Collins
Move add_pending_merge to WorkingTree.
52
        b.working_tree().add_pending_merge('pending@pending-0-0')
915 by Martin Pool
- add simple test case for bzr status
53
        show_status(b, to_file=tof)
54
        tof.seek(0)
55
        self.assertEquals(tof.readlines(),
56
                          ['unknown:\n',
57
                           '  bye.c\n',
58
                           '  hello.c\n',
974.1.48 by Aaron Bentley
Status command shows pending merges
59
                           'pending merges:\n',
60
                           '  pending@pending-0-0\n'
915 by Martin Pool
- add simple test case for bzr status
61
                           ])
62
1185.1.35 by Robert Collins
Heikki Paajanen's status -r patch
63
    def test_branch_status_revisions(self):
64
        """Tests branch status with revisions"""
65
        
1185.33.66 by Martin Pool
[patch] use unicode literals for all hardcoded paths (Alexander Belchenko)
66
        b = Branch.initialize(u'.')
1185.1.35 by Robert Collins
Heikki Paajanen's status -r patch
67
68
        tof = StringIO()
69
        self.build_tree(['hello.c', 'bye.c'])
1508.1.5 by Robert Collins
Move add from Branch to WorkingTree.
70
        b.working_tree().add('hello.c')
71
        b.working_tree().add('bye.c')
1457.1.17 by Robert Collins
Branch.commit() has moved to WorkingTree.commit(). (Robert Collins)
72
        b.working_tree().commit('Test message')
1185.1.35 by Robert Collins
Heikki Paajanen's status -r patch
73
74
        tof = StringIO()
75
        revs =[]
76
        revs.append(RevisionSpec(0))
77
        
78
        show_status(b, to_file=tof, revision=revs)
79
        
80
        tof.seek(0)
81
        self.assertEquals(tof.readlines(),
82
                          ['added:\n',
83
                           '  bye.c\n',
84
                           '  hello.c\n'])
85
86
        self.build_tree(['more.c'])
1508.1.5 by Robert Collins
Move add from Branch to WorkingTree.
87
        b.working_tree().add('more.c')
1457.1.17 by Robert Collins
Branch.commit() has moved to WorkingTree.commit(). (Robert Collins)
88
        b.working_tree().commit('Another test message')
1185.1.35 by Robert Collins
Heikki Paajanen's status -r patch
89
        
90
        tof = StringIO()
91
        revs.append(RevisionSpec(1))
92
        
93
        show_status(b, to_file=tof, revision=revs)
94
        
95
        tof.seek(0)
96
        self.assertEquals(tof.readlines(),
97
                          ['added:\n',
98
                           '  bye.c\n',
99
                           '  hello.c\n'])
100
1185.12.27 by Aaron Bentley
Use line log for pending merges
101
    def status_string(self, branch):
1185.33.71 by Martin Pool
Status tests include unicode character.
102
        # use a real file rather than StringIO because it doesn't handle
103
        # Unicode very well.
104
        tof = codecs.getwriter('utf-8')(TemporaryFile())
1185.12.27 by Aaron Bentley
Use line log for pending merges
105
        show_status(branch, to_file=tof)
106
        tof.seek(0)
1185.33.71 by Martin Pool
Status tests include unicode character.
107
        return tof.read().decode('utf-8')
1185.12.27 by Aaron Bentley
Use line log for pending merges
108
109
    def test_pending(self):
1185.33.71 by Martin Pool
Status tests include unicode character.
110
        """Pending merges display works, including Unicode"""
1185.12.27 by Aaron Bentley
Use line log for pending merges
111
        mkdir("./branch")
112
        b = Branch.initialize('./branch')
1457.1.17 by Robert Collins
Branch.commit() has moved to WorkingTree.commit(). (Robert Collins)
113
        b.working_tree().commit("Empty commit 1")
1185.12.27 by Aaron Bentley
Use line log for pending merges
114
        b_2 = copy_branch(b, './copy')
1185.33.71 by Martin Pool
Status tests include unicode character.
115
        b.working_tree().commit(u"\N{TIBETAN DIGIT TWO} Empty commit 2")
1185.12.27 by Aaron Bentley
Use line log for pending merges
116
        merge(["./branch", -1], [None, None], this_dir = './copy')
117
        message = self.status_string(b_2)
1185.16.145 by Martin Pool
Remove all assert statements from test cases.
118
        self.assert_(message.startswith("pending merges:\n"))
119
        self.assert_(message.endswith("Empty commit 2\n")) 
1457.1.17 by Robert Collins
Branch.commit() has moved to WorkingTree.commit(). (Robert Collins)
120
        b_2.working_tree().commit("merged")
1185.16.88 by mbp at sourcefrog
Make commit message long enough in test for pending merges
121
        # must be long to make sure we see elipsis at the end
1185.33.71 by Martin Pool
Status tests include unicode character.
122
        b.working_tree().commit("Empty commit 3 " + 
123
                                "blah blah blah blah " * 10)
1185.12.27 by Aaron Bentley
Use line log for pending merges
124
        merge(["./branch", -1], [None, None], this_dir = './copy')
125
        message = self.status_string(b_2)
1185.16.145 by Martin Pool
Remove all assert statements from test cases.
126
        self.assert_(message.startswith("pending merges:\n"))
127
        self.assert_("Empty commit 3" in message)
128
        self.assert_(message.endswith("...\n")) 
1185.12.27 by Aaron Bentley
Use line log for pending merges
129
1399 by Robert Collins
Patch from Heikki Paajanen testing status on specific files
130
    def test_branch_status_specific_files(self): 
131
        """Tests branch status with given specific files"""
132
        from cStringIO import StringIO
133
        from bzrlib.status import show_status
134
        from bzrlib.branch import Branch
135
        
1185.33.66 by Martin Pool
[patch] use unicode literals for all hardcoded paths (Alexander Belchenko)
136
        b = Branch.initialize(u'.')
1399 by Robert Collins
Patch from Heikki Paajanen testing status on specific files
137
138
        self.build_tree(['directory/','directory/hello.c', 'bye.c','test.c','dir2/'])
1508.1.5 by Robert Collins
Move add from Branch to WorkingTree.
139
        b.working_tree().add('directory')
140
        b.working_tree().add('test.c')
1457.1.17 by Robert Collins
Branch.commit() has moved to WorkingTree.commit(). (Robert Collins)
141
        b.working_tree().commit('testing')
1399 by Robert Collins
Patch from Heikki Paajanen testing status on specific files
142
        
143
        tof = StringIO()
144
        show_status(b, to_file=tof)
145
        tof.seek(0)
146
        self.assertEquals(tof.readlines(),
147
                          ['unknown:\n',
148
                           '  bye.c\n',
149
                           '  dir2\n',
150
                           '  directory/hello.c\n'
151
                           ])
152
153
        tof = StringIO()
154
        show_status(b, specific_files=['bye.c','test.c','absent.c'], to_file=tof)
155
        tof.seek(0)
156
        self.assertEquals(tof.readlines(),
157
                          ['unknown:\n',
158
                           '  bye.c\n'
159
                           ])
160
        
161
        tof = StringIO()
162
        show_status(b, specific_files=['directory'], to_file=tof)
163
        tof.seek(0)
164
        self.assertEquals(tof.readlines(),
165
                          ['unknown:\n',
166
                           '  directory/hello.c\n'
167
                           ])
168
        tof = StringIO()
169
        show_status(b, specific_files=['dir2'], to_file=tof)
170
        tof.seek(0)
171
        self.assertEquals(tof.readlines(),
172
                          ['unknown:\n',
173
                           '  dir2\n'
174
                           ])