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
28
from os import mkdir, chdir
29
from tempfile import TemporaryFile
33
from bzrlib.builtins import merge
34
import bzrlib.bzrdir as bzrdir
35
from bzrlib.osutils import pathjoin
36
from bzrlib.revisionspec import RevisionSpec
37
from bzrlib.status import show_tree_status
38
from bzrlib.tests import TestCaseWithTransport
39
from bzrlib.workingtree import WorkingTree
42
class BranchStatus(TestCaseWithTransport):
44
def test_branch_status(self):
45
"""Test basic branch status"""
46
wt = self.make_branch_and_tree('.')
35
49
# status with nothing
37
show_status(b, to_file=tof)
51
show_tree_status(wt, to_file=tof)
38
52
self.assertEquals(tof.getvalue(), "")
41
55
self.build_tree(['hello.c', 'bye.c'])
42
show_status(b, to_file=tof)
56
wt.add_pending_merge('pending@pending-0-0')
57
show_tree_status(wt, to_file=tof)
44
59
self.assertEquals(tof.readlines(),
64
' pending@pending-0-0\n'
67
def test_branch_status_revisions(self):
68
"""Tests branch status with revisions"""
69
wt = self.make_branch_and_tree('.')
73
self.build_tree(['hello.c', 'bye.c'])
76
wt.commit('Test message')
80
revs.append(RevisionSpec(0))
82
show_tree_status(wt, to_file=tof, revision=revs)
85
self.assertEquals(tof.readlines(),
90
self.build_tree(['more.c'])
92
wt.commit('Another test message')
95
revs.append(RevisionSpec(1))
97
show_tree_status(wt, to_file=tof, revision=revs)
100
self.assertEquals(tof.readlines(),
105
def status_string(self, wt):
106
# use a real file rather than StringIO because it doesn't handle
108
tof = codecs.getwriter('utf-8')(TemporaryFile())
109
show_tree_status(wt, to_file=tof)
111
return tof.read().decode('utf-8')
113
def test_pending(self):
114
"""Pending merges display works, including Unicode"""
116
wt = self.make_branch_and_tree('branch')
118
wt.commit("Empty commit 1")
119
b_2_dir = b.bzrdir.sprout('./copy')
120
b_2 = b_2_dir.open_branch()
121
wt2 = b_2_dir.open_workingtree()
122
wt.commit(u"\N{TIBETAN DIGIT TWO} Empty commit 2")
123
merge(["./branch", -1], [None, None], this_dir = './copy')
124
message = self.status_string(wt2)
125
self.assert_(message.startswith("pending merges:\n"))
126
self.assert_(message.endswith("Empty commit 2\n"))
128
# must be long to make sure we see elipsis at the end
129
wt.commit("Empty commit 3 " +
130
"blah blah blah blah " * 10)
131
merge(["./branch", -1], [None, None], this_dir = './copy')
132
message = self.status_string(wt2)
133
self.assert_(message.startswith("pending merges:\n"))
134
self.assert_("Empty commit 3" in message)
135
self.assert_(message.endswith("...\n"))
137
def test_branch_status_specific_files(self):
138
"""Tests branch status with given specific files"""
139
wt = self.make_branch_and_tree('.')
142
self.build_tree(['directory/','directory/hello.c', 'bye.c','test.c','dir2/'])
148
show_tree_status(wt, to_file=tof)
150
self.assertEquals(tof.readlines(),
154
' directory/hello.c\n'
158
show_tree_status(wt, specific_files=['bye.c','test.c','absent.c'],
161
self.assertEquals(tof.readlines(),
167
show_tree_status(wt, specific_files=['directory'], to_file=tof)
169
self.assertEquals(tof.readlines(),
171
' directory/hello.c\n'
174
show_tree_status(wt, specific_files=['dir2'], to_file=tof)
176
self.assertEquals(tof.readlines(),
181
class CheckoutStatus(BranchStatus):
184
super(CheckoutStatus, self).setUp()
188
def make_branch_and_tree(self, relpath):
189
source = self.make_branch(pathjoin('..', relpath))
190
checkout = bzrdir.BzrDirMetaFormat1().initialize(relpath)
191
bzrlib.branch.BranchReferenceFormat().initialize(checkout, source)
192
return checkout.create_workingtree()
195
class TestStatus(TestCaseWithTransport):
197
def test_status(self):
199
self.build_tree(['hello.txt'])
200
result = self.run_bzr("status")[0]
201
self.assert_("unknown:\n hello.txt\n" in result, result)
202
self.run_bzr("add", "hello.txt")
203
result = self.run_bzr("status")[0]
204
self.assert_("added:\n hello.txt\n" in result, result)
205
self.run_bzr("commit", "-m", "added")
206
result = self.run_bzr("status", "-r", "0..1")[0]
207
self.assert_("added:\n hello.txt\n" in result, result)
208
self.build_tree(['world.txt'])
209
result = self.run_bzr("status", "-r", "0")[0]
210
self.assert_("added:\n hello.txt\n" \
211
"unknown:\n world.txt\n" in result, result)
213
result2 = self.run_bzr("status", "-r", "0..")[0]
214
self.assertEquals(result2, result)