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 TestCaseInTempDir
27
from cStringIO import StringIO
29
from tempfile import TemporaryFile
32
from bzrlib.builtins import merge
25
33
from bzrlib.revisionspec import RevisionSpec
26
from bzrlib.merge import merge
27
from cStringIO import StringIO
28
34
from bzrlib.status import show_status
29
from bzrlib.branch import Branch
31
from bzrlib.clone import copy_branch
33
class BranchStatus(TestCaseInTempDir):
35
from bzrlib.tests import TestCaseWithTransport
36
from bzrlib.workingtree import WorkingTree
39
class BranchStatus(TestCaseWithTransport):
35
41
def test_branch_status(self):
36
42
"""Test basic branch status"""
37
from cStringIO import StringIO
38
from bzrlib.status import show_status
39
from bzrlib.branch import Branch
41
b = Branch.initialize('.')
43
wt = self.make_branch_and_tree('.')
43
46
# status with nothing
49
52
self.build_tree(['hello.c', 'bye.c'])
50
b.working_tree().add_pending_merge('pending@pending-0-0')
53
wt.add_pending_merge('pending@pending-0-0')
51
54
show_status(b, to_file=tof)
53
56
self.assertEquals(tof.readlines(),
61
64
def test_branch_status_revisions(self):
62
65
"""Tests branch status with revisions"""
64
b = Branch.initialize('.')
66
wt = self.make_branch_and_tree('.')
67
70
self.build_tree(['hello.c', 'bye.c'])
70
b.working_tree().commit('Test message')
73
wt.commit('Test message')
99
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())
101
106
show_status(branch, to_file=tof)
103
return tof.getvalue()
108
return tof.read().decode('utf-8')
105
110
def test_pending(self):
106
"""Pending merges display works"""
111
"""Pending merges display works, including Unicode"""
107
112
mkdir("./branch")
108
b = Branch.initialize('./branch')
109
b.working_tree().commit("Empty commit 1")
110
b_2 = copy_branch(b, './copy')
111
b.working_tree().commit("Empty commit 2")
113
wt = self.make_branch_and_tree('branch')
115
wt.commit("Empty commit 1")
116
b_2_dir = b.bzrdir.sprout('./copy')
117
b_2 = b_2_dir.open_branch()
118
wt2 = b_2_dir.open_workingtree()
119
wt.commit(u"\N{TIBETAN DIGIT TWO} Empty commit 2")
112
120
merge(["./branch", -1], [None, None], this_dir = './copy')
113
121
message = self.status_string(b_2)
114
122
self.assert_(message.startswith("pending merges:\n"))
115
123
self.assert_(message.endswith("Empty commit 2\n"))
116
b_2.working_tree().commit("merged")
117
125
# must be long to make sure we see elipsis at the end
118
b.working_tree().commit("Empty commit 3 blah blah blah blah blah blah blah blah blah"
119
" blah blah blah blah blah blah bleh")
126
wt.commit("Empty commit 3 " +
127
"blah blah blah blah " * 10)
120
128
merge(["./branch", -1], [None, None], this_dir = './copy')
121
129
message = self.status_string(b_2)
122
130
self.assert_(message.startswith("pending merges:\n"))
126
134
def test_branch_status_specific_files(self):
127
135
"""Tests branch status with given specific files"""
128
from cStringIO import StringIO
129
from bzrlib.status import show_status
130
from bzrlib.branch import Branch
132
b = Branch.initialize('.')
136
wt = self.make_branch_and_tree('.')
134
139
self.build_tree(['directory/','directory/hello.c', 'bye.c','test.c','dir2/'])
137
b.working_tree().commit('testing')
140
145
show_status(b, to_file=tof)
178
class TestStatus(TestCaseWithTransport):
180
def test_status(self):
182
self.build_tree(['hello.txt'])
183
result = self.run_bzr("status")[0]
184
self.assert_("unknown:\n hello.txt\n" in result, result)
185
self.run_bzr("add", "hello.txt")
186
result = self.run_bzr("status")[0]
187
self.assert_("added:\n hello.txt\n" in result, result)
188
self.run_bzr("commit", "-m", "added")
189
result = self.run_bzr("status", "-r", "0..1")[0]
190
self.assert_("added:\n hello.txt\n" in result, result)
191
self.build_tree(['world.txt'])
192
result = self.run_bzr("status", "-r", "0")[0]
193
self.assert_("added:\n hello.txt\n" \
194
"unknown:\n world.txt\n" in result, result)
196
result2 = self.run_bzr("status", "-r", "0..")[0]
197
self.assertEquals(result2, result)