53
53
def test_diff(self):
54
54
self.make_example_branch()
55
55
file('hello', 'wt').write('hello world!')
56
self.run_bzr('commit -m fixing hello')
57
output = self.run_bzr('diff -r 2..3', retcode=1)[0]
56
self.runbzr('commit -m fixing hello')
57
output = self.runbzr('diff -r 2..3', backtick=1, retcode=1)
58
58
self.assert_('\n+hello world!' in output)
59
output = self.run_bzr('diff -r last:3..last:1',
59
output = self.runbzr('diff -r last:3..last:1', backtick=1, retcode=1)
61
60
self.assert_('\n+baz' in output)
62
self.build_tree(['moo'])
63
self.run_bzr('add moo')
61
file('moo', 'wb').write('moo')
62
self.runbzr('add moo')
67
66
def test_diff_prefix(self):
68
67
"""diff --prefix appends to filenames in output"""
69
68
self.make_example_branch()
70
69
file('hello', 'wb').write('hello world!\n')
71
out, err = self.run_bzr('diff --prefix old/:new/', retcode=1)
70
out, err = self.runbzr('diff --prefix old/:new/', retcode=1)
72
71
self.assertEquals(err, '')
73
72
self.assertEqualDiff(subst_dates(out), '''\
74
73
=== modified file 'hello'
90
89
"""diff -p1 produces lkml-style diffs"""
91
90
self.make_example_branch()
92
91
file('hello', 'wb').write('hello world!\n')
93
out, err = self.run_bzr('diff -p1', retcode=1)
92
out, err = self.runbzr('diff -p1', retcode=1)
94
93
self.assertEquals(err, '')
95
94
self.assertEqualDiff(subst_dates(out), '''\
96
95
=== modified file 'hello'
106
105
"""diff -p0 produces diffs with no prefix"""
107
106
self.make_example_branch()
108
107
file('hello', 'wb').write('hello world!\n')
109
out, err = self.run_bzr('diff -p0', retcode=1)
108
out, err = self.runbzr('diff -p0', retcode=1)
110
109
self.assertEquals(err, '')
111
110
self.assertEqualDiff(subst_dates(out), '''\
112
111
=== modified file 'hello'
122
121
# Get an error from a file that does not exist at all
124
123
self.make_example_branch()
125
out, err = self.run_bzr('diff does-not-exist', retcode=3)
124
out, err = self.runbzr('diff does-not-exist', retcode=3)
126
125
self.assertContainsRe(err, 'not versioned.*does-not-exist')
128
127
def test_diff_illegal_revision_specifiers(self):
129
out, err = self.run_bzr('diff -r 1..23..123', retcode=3)
128
out, err = self.runbzr('diff -r 1..23..123', retcode=3)
130
129
self.assertContainsRe(err, 'one or two revision specifiers')
132
131
def test_diff_unversioned(self):
135
134
self.make_example_branch()
136
135
self.build_tree(['unversioned-file'])
137
out, err = self.run_bzr('diff unversioned-file', retcode=3)
136
out, err = self.runbzr('diff unversioned-file', retcode=3)
138
137
self.assertContainsRe(err, 'not versioned.*unversioned-file')
140
139
# TODO: What should diff say for a file deleted in working tree?
142
141
def example_branches(self):
143
142
self.build_tree(['branch1/', 'branch1/file'], line_endings='binary')
144
self.run_bzr('init branch1')[0]
145
self.run_bzr('add branch1/file')[0]
146
self.run_bzr(['commit', '-m', 'add file', 'branch1'])
147
self.run_bzr('branch branch1 branch2')[0]
148
self.build_tree_contents([('branch2/file', 'new content\n')])
149
self.run_bzr(['commit', '-m', 'update file', 'branch2'])
143
self.capture('init branch1')
144
self.capture('add branch1/file')
145
self.run_bzr_captured(['commit', '-m', 'add file', 'branch1'])
146
self.capture('branch branch1 branch2')
147
print >> open('branch2/file', 'wb'), 'new content'
148
self.run_bzr_captured(['commit', '-m', 'update file', 'branch2'])
151
150
def test_diff_branches(self):
152
151
self.example_branches()
153
152
# should open branch1 and diff against branch2,
154
out, err = self.run_bzr('diff -r branch:branch2 branch1',
153
out, err = self.run_bzr_captured(['diff', '-r', 'branch:branch2',
156
156
self.assertEquals('', err)
157
157
self.assertEquals("=== modified file 'file'\n"
158
158
"--- file\tYYYY-MM-DD HH:MM:SS +ZZZZ\n"
175
175
def test_diff_revno_branches(self):
176
176
self.example_branches()
177
177
print >> open('branch2/file', 'wb'), 'even newer content'
178
self.run_bzr(['commit', '-m',
179
'update file once more', 'branch2'])
178
self.run_bzr_captured(['commit', '-m',
179
'update file once more', 'branch2'])
181
out, err = self.run_bzr('diff -r revno:1:branch2..revno:1:branch1',
181
out, err = self.run_bzr_captured(['diff', '-r',
182
'revno:1:branch2..revno:1:branch1'],
183
184
self.assertEquals('', err)
184
185
self.assertEquals('', out)
185
out, err = self.run_bzr('diff -r revno:2:branch2..revno:1:branch1',
186
out, err = self.run_bzr_captured(['diff', '-r',
187
'revno:2:branch2..revno:1:branch1'],
187
189
self.assertEquals('', err)
188
190
self.assertEqualDiff("=== modified file 'file'\n"
189
191
"--- file\tYYYY-MM-DD HH:MM:SS +ZZZZ\n"
196
198
def example_branch2(self):
197
199
self.build_tree(['branch1/', 'branch1/file1'], line_endings='binary')
198
self.run_bzr('init branch1')[0]
199
self.run_bzr('add branch1/file1')[0]
200
self.capture('init branch1')
201
self.capture('add branch1/file1')
200
202
print >> open('branch1/file1', 'wb'), 'original line'
201
self.run_bzr(['commit', '-m', 'first commit', 'branch1'])
203
self.run_bzr_captured(['commit', '-m', 'first commit', 'branch1'])
203
205
print >> open('branch1/file1', 'wb'), 'repo line'
204
self.run_bzr(['commit', '-m', 'second commit', 'branch1'])
206
self.run_bzr_captured(['commit', '-m', 'second commit', 'branch1'])
206
208
def test_diff_to_working_tree(self):
207
209
self.example_branch2()
209
211
print >> open('branch1/file1', 'wb'), 'new line'
210
output = self.run_bzr('diff -r 1.. branch1',
212
output = self.run_bzr_captured(['diff', '-r', '1..', 'branch1'],
212
214
self.assertTrue('\n-original line\n+new line\n' in output[0])
214
216
def test_diff_across_rename(self):
215
217
"""The working tree path should always be considered for diffing"""
216
218
self.make_example_branch()
217
self.run_bzr('diff -r 0..1 hello', retcode=1)
219
self.run_bzr('diff', '-r', '0..1', 'hello', retcode=1)
218
220
wt = workingtree.WorkingTree.open_containing('.')[0]
219
221
wt.rename_one('hello', 'hello1')
220
self.run_bzr('diff hello1', retcode=1)
221
self.run_bzr('diff -r 0..1 hello1', retcode=1)
222
self.run_bzr('diff', 'hello1', retcode=1)
223
self.run_bzr('diff', '-r', '0..1', 'hello1', retcode=1)
224
226
class TestCheckoutDiff(TestDiff):
226
228
def make_example_branch(self):
227
229
super(TestCheckoutDiff, self).make_example_branch()
228
self.run_bzr('checkout . checkout')
230
self.runbzr('checkout . checkout')
229
231
os.chdir('checkout')
231
233
def example_branch2(self):
232
234
super(TestCheckoutDiff, self).example_branch2()
233
235
os.mkdir('checkouts')
234
self.run_bzr('checkout branch1 checkouts/branch1')
236
self.runbzr('checkout branch1 checkouts/branch1')
235
237
os.chdir('checkouts')
237
239
def example_branches(self):
238
240
super(TestCheckoutDiff, self).example_branches()
239
241
os.mkdir('checkouts')
240
self.run_bzr('checkout branch1 checkouts/branch1')
241
self.run_bzr('checkout branch2 checkouts/branch2')
242
self.runbzr('checkout branch1 checkouts/branch1')
243
self.runbzr('checkout branch2 checkouts/branch2')
242
244
os.chdir('checkouts')
247
249
def test_diff_label_removed(self):
248
250
super(TestDiffLabels, self).make_example_branch()
249
self.run_bzr('remove hello')
250
diff = self.run_bzr('diff', retcode=1)
251
self.runbzr('remove hello')
252
diff = self.run_bzr_captured(['diff'], retcode=1)
251
253
self.assertTrue("=== removed file 'hello'" in diff[0])
253
255
def test_diff_label_added(self):
254
256
super(TestDiffLabels, self).make_example_branch()
255
257
file('barbar', 'wt').write('barbar')
256
self.run_bzr('add barbar')
257
diff = self.run_bzr('diff', retcode=1)
258
self.runbzr('add barbar')
259
diff = self.run_bzr_captured(['diff'], retcode=1)
258
260
self.assertTrue("=== added file 'barbar'" in diff[0])
260
262
def test_diff_label_modified(self):
261
263
super(TestDiffLabels, self).make_example_branch()
262
264
file('hello', 'wt').write('barbar')
263
diff = self.run_bzr('diff', retcode=1)
265
diff = self.run_bzr_captured(['diff'], retcode=1)
264
266
self.assertTrue("=== modified file 'hello'" in diff[0])
266
268
def test_diff_label_renamed(self):
267
269
super(TestDiffLabels, self).make_example_branch()
268
self.run_bzr('rename hello gruezi')
269
diff = self.run_bzr('diff', retcode=1)
270
self.runbzr('rename hello gruezi')
271
diff = self.run_bzr_captured(['diff'], retcode=1)
270
272
self.assertTrue("=== renamed file 'hello' => 'gruezi'" in diff[0])