1
# Copyright (C) 2005 by Canonical Ltd
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.
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.
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
18
"""Tests of status command.
20
Most of these depend on the particular formatting used.
21
As such they really are blackbox tests even though some of the
22
tests are not using self.capture. If we add tests for the programmatic
23
interface later, they will be non blackbox tests.
27
from cStringIO import StringIO
29
from tempfile import TemporaryFile
32
from bzrlib.builtins import merge
33
from bzrlib.revisionspec import RevisionSpec
34
from bzrlib.status import show_status
35
from bzrlib.tests import TestCaseInTempDir
36
from bzrlib.workingtree import WorkingTree
39
class BranchStatus(TestCaseInTempDir):
41
def test_branch_status(self):
42
"""Test basic branch status"""
43
wt = WorkingTree.create_standalone('.')
48
show_status(b, to_file=tof)
49
self.assertEquals(tof.getvalue(), "")
52
self.build_tree(['hello.c', 'bye.c'])
53
wt.add_pending_merge('pending@pending-0-0')
54
show_status(b, to_file=tof)
56
self.assertEquals(tof.readlines(),
61
' pending@pending-0-0\n'
64
def test_branch_status_revisions(self):
65
"""Tests branch status with revisions"""
66
wt = WorkingTree.create_standalone('.')
70
self.build_tree(['hello.c', 'bye.c'])
73
wt.commit('Test message')
77
revs.append(RevisionSpec(0))
79
show_status(b, to_file=tof, revision=revs)
82
self.assertEquals(tof.readlines(),
87
self.build_tree(['more.c'])
89
wt.commit('Another test message')
92
revs.append(RevisionSpec(1))
94
show_status(b, to_file=tof, revision=revs)
97
self.assertEquals(tof.readlines(),
102
def status_string(self, branch):
103
# use a real file rather than StringIO because it doesn't handle
105
tof = codecs.getwriter('utf-8')(TemporaryFile())
106
show_status(branch, to_file=tof)
108
return tof.read().decode('utf-8')
110
def test_pending(self):
111
"""Pending merges display works, including Unicode"""
113
wt = WorkingTree.create_standalone('branch')
115
wt.commit("Empty commit 1")
116
b_2 = b.clone('./copy')
117
wt.commit(u"\N{TIBETAN DIGIT TWO} Empty commit 2")
118
merge(["./branch", -1], [None, None], this_dir = './copy')
119
message = self.status_string(b_2)
120
self.assert_(message.startswith("pending merges:\n"))
121
self.assert_(message.endswith("Empty commit 2\n"))
122
b_2.working_tree().commit("merged")
123
# must be long to make sure we see elipsis at the end
124
b.working_tree().commit("Empty commit 3 " +
125
"blah blah blah blah " * 10)
126
merge(["./branch", -1], [None, None], this_dir = './copy')
127
message = self.status_string(b_2)
128
self.assert_(message.startswith("pending merges:\n"))
129
self.assert_("Empty commit 3" in message)
130
self.assert_(message.endswith("...\n"))
132
def test_branch_status_specific_files(self):
133
"""Tests branch status with given specific files"""
134
wt = WorkingTree.create_standalone('.')
137
self.build_tree(['directory/','directory/hello.c', 'bye.c','test.c','dir2/'])
143
show_status(b, to_file=tof)
145
self.assertEquals(tof.readlines(),
149
' directory/hello.c\n'
153
show_status(b, specific_files=['bye.c','test.c','absent.c'], to_file=tof)
155
self.assertEquals(tof.readlines(),
161
show_status(b, specific_files=['directory'], to_file=tof)
163
self.assertEquals(tof.readlines(),
165
' directory/hello.c\n'
168
show_status(b, specific_files=['dir2'], to_file=tof)
170
self.assertEquals(tof.readlines(),
176
class TestStatus(TestCaseInTempDir):
178
def test_status(self):
180
self.build_tree(['hello.txt'])
181
result = self.run_bzr("status")[0]
182
self.assert_("unknown:\n hello.txt\n" in result, result)
183
self.run_bzr("add", "hello.txt")
184
result = self.run_bzr("status")[0]
185
self.assert_("added:\n hello.txt\n" in result, result)
186
self.run_bzr("commit", "-m", "added")
187
result = self.run_bzr("status", "-r", "0..1")[0]
188
self.assert_("added:\n hello.txt\n" in result, result)
189
self.build_tree(['world.txt'])
190
result = self.run_bzr("status", "-r", "0")[0]
191
self.assert_("added:\n hello.txt\n" \
192
"unknown:\n world.txt\n" in result, result)
194
result2 = self.run_bzr("status", "-r", "0..")[0]
195
self.assertEquals(result2, result)