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):
28
"""Basic 'bzr mkdir' operation"""
29
from cStringIO import StringIO
30
from bzrlib.status import show_status
31
from bzrlib.branch import Branch
33
b = Branch('.', init=True)
27
from cStringIO import StringIO
29
from tempfile import TemporaryFile
32
from bzrlib.branch import Branch
33
from bzrlib.builtins import merge
34
from bzrlib.revisionspec import RevisionSpec
35
from bzrlib.status import show_status
36
from bzrlib.tests import TestCaseInTempDir
37
from bzrlib.workingtree import WorkingTree
40
class BranchStatus(TestCaseInTempDir):
42
def test_branch_status(self):
43
"""Test basic branch status"""
44
wt = WorkingTree.create_standalone('.')
35
47
# status with nothing
41
53
self.build_tree(['hello.c', 'bye.c'])
54
wt.add_pending_merge('pending@pending-0-0')
42
55
show_status(b, to_file=tof)
44
57
self.assertEquals(tof.readlines(),
62
' pending@pending-0-0\n'
65
def test_branch_status_revisions(self):
66
"""Tests branch status with revisions"""
67
wt = WorkingTree.create_standalone('.')
71
self.build_tree(['hello.c', 'bye.c'])
74
wt.commit('Test message')
78
revs.append(RevisionSpec(0))
80
show_status(b, to_file=tof, revision=revs)
83
self.assertEquals(tof.readlines(),
88
self.build_tree(['more.c'])
90
wt.commit('Another test message')
93
revs.append(RevisionSpec(1))
95
show_status(b, to_file=tof, revision=revs)
98
self.assertEquals(tof.readlines(),
103
def status_string(self, branch):
104
# use a real file rather than StringIO because it doesn't handle
106
tof = codecs.getwriter('utf-8')(TemporaryFile())
107
show_status(branch, to_file=tof)
109
return tof.read().decode('utf-8')
111
def test_pending(self):
112
"""Pending merges display works, including Unicode"""
114
wt = WorkingTree.create_standalone('branch')
116
wt.commit("Empty commit 1")
117
b_2 = b.clone('./copy')
118
wt2 = WorkingTree('copy', b_2)
119
wt.commit(u"\N{TIBETAN DIGIT TWO} Empty commit 2")
120
merge(["./branch", -1], [None, None], this_dir = './copy')
121
message = self.status_string(b_2)
122
self.assert_(message.startswith("pending merges:\n"))
123
self.assert_(message.endswith("Empty commit 2\n"))
125
# must be long to make sure we see elipsis at the end
126
wt.commit("Empty commit 3 " +
127
"blah blah blah blah " * 10)
128
merge(["./branch", -1], [None, None], this_dir = './copy')
129
message = self.status_string(b_2)
130
self.assert_(message.startswith("pending merges:\n"))
131
self.assert_("Empty commit 3" in message)
132
self.assert_(message.endswith("...\n"))
134
def test_branch_status_specific_files(self):
135
"""Tests branch status with given specific files"""
136
wt = WorkingTree.create_standalone('.')
139
self.build_tree(['directory/','directory/hello.c', 'bye.c','test.c','dir2/'])
145
show_status(b, to_file=tof)
147
self.assertEquals(tof.readlines(),
151
' directory/hello.c\n'
155
show_status(b, specific_files=['bye.c','test.c','absent.c'], to_file=tof)
157
self.assertEquals(tof.readlines(),
163
show_status(b, specific_files=['directory'], to_file=tof)
165
self.assertEquals(tof.readlines(),
167
' directory/hello.c\n'
170
show_status(b, specific_files=['dir2'], to_file=tof)
172
self.assertEquals(tof.readlines(),