41
41
class BranchStatus(TestCaseWithTransport):
43
def assertStatus(self, output_lines, working_tree,
44
revision=None, short=False):
45
"""Run status in working_tree and look for output.
47
:param output_lines: The lines to look for.
48
:param working_tree: The tree to run status in.
50
output_string = self.status_string(working_tree, revision, short)
51
self.assertEqual(output_lines, output_string.splitlines(True))
53
def status_string(self, wt, revision=None, short=False):
54
# use a real file rather than StringIO because it doesn't handle
56
tof = codecs.getwriter('utf-8')(TemporaryFile())
57
show_tree_status(wt, to_file=tof, revision=revision, short=short)
59
return tof.read().decode('utf-8')
61
43
def test_branch_status(self):
62
44
"""Test basic branch status"""
63
45
wt = self.make_branch_and_tree('.')
65
# status with no commits or files - it must
66
# work and show no output. We do this with no
67
# commits to be sure that it's not going to fail
69
self.assertStatus([], wt)
48
ignores._set_user_ignores(['./.bazaar'])
52
show_tree_status(wt, to_file=tof)
53
self.assertEquals(tof.getvalue(), "")
71
56
self.build_tree(['hello.c', 'bye.c'])
84
# add a commit to allow showing pending merges.
85
wt.commit('create a parent to allow testing merge output')
87
wt.add_parent_tree_id('pending@pending-0-0')
93
' pending@pending-0-0\n',
99
'P pending@pending-0-0\n',
57
wt.add_pending_merge('pending@pending-0-0')
58
show_tree_status(wt, to_file=tof)
60
self.assertEquals(tof.readlines(),
65
' pending@pending-0-0\n'
103
68
def test_branch_status_revisions(self):
104
69
"""Tests branch status with revisions"""
105
70
wt = self.make_branch_and_tree('.')
73
ignores._set_user_ignores(['./.bazaar'])
107
76
self.build_tree(['hello.c', 'bye.c'])
110
79
wt.commit('Test message')
112
revs = [RevisionSpec.from_string('0')]
83
revs.append(RevisionSpec(0))
85
show_tree_status(wt, to_file=tof, revision=revs)
88
self.assertEquals(tof.readlines(),
121
93
self.build_tree(['more.c'])
123
95
wt.commit('Another test message')
125
revs.append(RevisionSpec.from_string('1'))
98
revs.append(RevisionSpec(1))
100
show_tree_status(wt, to_file=tof, revision=revs)
103
self.assertEquals(tof.readlines(),
108
def status_string(self, wt):
109
# use a real file rather than StringIO because it doesn't handle
111
tof = codecs.getwriter('utf-8')(TemporaryFile())
112
show_tree_status(wt, to_file=tof)
114
return tof.read().decode('utf-8')
134
116
def test_pending(self):
135
117
"""Pending merges display works, including Unicode"""
160
142
wt = self.make_branch_and_tree('.')
145
ignores._set_user_ignores(['./.bazaar'])
163
147
self.build_tree(['directory/','directory/hello.c', 'bye.c','test.c','dir2/'])
164
148
wt.add('directory')
166
150
wt.commit('testing')
172
' directory/hello.c\n'
179
'? directory/hello.c\n'
153
show_tree_status(wt, to_file=tof)
155
self.assertEquals(tof.readlines(),
159
' directory/hello.c\n'
184
162
self.assertRaises(errors.PathsDoNotExist,
185
163
show_tree_status,
186
164
wt, specific_files=['bye.c','test.c','absent.c'],
194
172
' directory/hello.c\n'
197
show_tree_status(wt, specific_files=['directory'], to_file=tof,
200
self.assertEquals(tof.readlines(), ['? directory/hello.c\n'])
203
175
show_tree_status(wt, specific_files=['dir2'], to_file=tof)
205
177
self.assertEquals(tof.readlines(),
210
show_tree_status(wt, specific_files=['dir2'], to_file=tof, short=True)
212
self.assertEquals(tof.readlines(), ['? dir2\n'])
214
182
def test_status_nonexistent_file(self):
215
183
# files that don't exist in either the basis tree or working tree
218
186
out, err = self.run_bzr('status', 'does-not-exist', retcode=3)
219
187
self.assertContainsRe(err, r'do not exist.*does-not-exist')
221
def test_status_out_of_date(self):
222
"""Simulate status of out-of-date tree after remote push"""
223
tree = self.make_branch_and_tree('.')
224
self.build_tree_contents([('a', 'foo\n')])
228
tree.commit('add test file')
229
# simulate what happens after a remote push
230
tree.set_last_revision("0")
231
out, err = self.run_bzr('status')
232
self.assertEqual("working tree is out of date, run 'bzr update'\n",
238
190
class CheckoutStatus(BranchStatus):
252
204
class TestStatus(TestCaseWithTransport):
254
206
def test_status(self):
207
ignores._set_user_ignores(['./.bazaar'])
255
209
self.run_bzr("init")
257
210
self.build_tree(['hello.txt'])
258
211
result = self.run_bzr("status")[0]
259
212
self.assert_("unknown:\n hello.txt\n" in result, result)
260
result = self.run_bzr("status","--short")[0]
261
self.assert_("? hello.txt\n" in result, result)
263
213
self.run_bzr("add", "hello.txt")
264
214
result = self.run_bzr("status")[0]
265
215
self.assert_("added:\n hello.txt\n" in result, result)
266
result = self.run_bzr("status","--short")[0]
267
self.assert_("A hello.txt\n" in result, result)
269
216
self.run_bzr("commit", "-m", "added")
270
217
result = self.run_bzr("status", "-r", "0..1")[0]
271
218
self.assert_("added:\n hello.txt\n" in result, result)
272
result = self.run_bzr("status", "--short", "-r", "0..1")[0]
273
self.assert_("A hello.txt\n" in result, result)
275
219
self.build_tree(['world.txt'])
276
220
result = self.run_bzr("status", "-r", "0")[0]
277
221
self.assert_("added:\n hello.txt\n" \
278
222
"unknown:\n world.txt\n" in result, result)
279
224
result2 = self.run_bzr("status", "-r", "0..")[0]
280
225
self.assertEquals(result2, result)
281
result = self.run_bzr("status", "--short", "-r", "0")[0]
282
self.assert_("A hello.txt\n" \
283
"? world.txt\n" in result, result)
284
result2 = self.run_bzr("status", "--short", "-r", "0..")[0]
285
self.assertEquals(result2, result)
288
228
class TestStatusEncodings(TestCaseWithTransport):