18
18
"""Tests of status command.
20
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.
24
from bzrlib.selftest import InTempDir
26
class BranchStatus(InTempDir):
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):
28
41
def test_branch_status(self):
29
"""Basic 'bzr mkdir' operation"""
30
from cStringIO import StringIO
31
from bzrlib.status import show_status
32
from bzrlib.branch import Branch
34
b = Branch('.', init=True)
42
"""Test basic branch status"""
43
wt = WorkingTree.create_standalone('.')
36
46
# status with nothing
42
52
self.build_tree(['hello.c', 'bye.c'])
53
wt.add_pending_merge('pending@pending-0-0')
43
54
show_status(b, to_file=tof)
45
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)