69
76
def test_unexpected_prompt_failure(self):
70
self.thisFailsStrictLockCheck()
71
77
tree = self.create_shelvable_tree()
78
tree.lock_tree_write()
79
self.addCleanup(tree.unlock)
72
80
shelver = ExpectShelver(tree, tree.basis_tree())
81
self.addCleanup(shelver.finalize)
73
82
e = self.assertRaises(AssertionError, shelver.run)
74
83
self.assertEqual('Unexpected prompt: Shelve? [yNfq?]', str(e))
76
85
def test_wrong_prompt_failure(self):
77
self.thisFailsStrictLockCheck()
78
86
tree = self.create_shelvable_tree()
87
tree.lock_tree_write()
88
self.addCleanup(tree.unlock)
79
89
shelver = ExpectShelver(tree, tree.basis_tree())
90
self.addCleanup(shelver.finalize)
80
91
shelver.expect('foo', 'y')
81
92
e = self.assertRaises(AssertionError, shelver.run)
82
93
self.assertEqual('Wrong prompt: Shelve? [yNfq?]', str(e))
84
95
def test_shelve_not_diff(self):
85
self.thisFailsStrictLockCheck()
86
96
tree = self.create_shelvable_tree()
97
tree.lock_tree_write()
98
self.addCleanup(tree.unlock)
87
99
shelver = ExpectShelver(tree, tree.basis_tree())
100
self.addCleanup(shelver.finalize)
88
101
shelver.expect('Shelve? [yNfq?]', 'n')
89
102
shelver.expect('Shelve? [yNfq?]', 'n')
90
103
# No final shelving prompt because no changes were selected
122
141
self.assertFileEqual(LINES_AY, 'tree/foo')
124
143
def test_shelve_binary_change(self):
125
self.thisFailsStrictLockCheck()
126
144
tree = self.create_shelvable_tree()
127
145
self.build_tree_contents([('tree/foo', '\x00')])
146
tree.lock_tree_write()
147
self.addCleanup(tree.unlock)
128
148
shelver = ExpectShelver(tree, tree.basis_tree())
149
self.addCleanup(shelver.finalize)
129
150
shelver.expect('Shelve binary changes? [yNfq?]', 'y')
130
151
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
132
153
self.assertFileEqual(LINES_AJ, 'tree/foo')
134
155
def test_shelve_rename(self):
135
self.thisFailsStrictLockCheck()
136
156
tree = self.create_shelvable_tree()
137
157
tree.rename_one('foo', 'bar')
158
tree.lock_tree_write()
159
self.addCleanup(tree.unlock)
138
160
shelver = ExpectShelver(tree, tree.basis_tree())
161
self.addCleanup(shelver.finalize)
139
162
shelver.expect('Shelve renaming "foo" => "bar"? [yNfq?]', 'y')
140
163
shelver.expect('Shelve? [yNfq?]', 'y')
141
164
shelver.expect('Shelve? [yNfq?]', 'y')
144
167
self.assertFileEqual(LINES_AJ, 'tree/foo')
146
169
def test_shelve_deletion(self):
147
self.thisFailsStrictLockCheck()
148
170
tree = self.create_shelvable_tree()
149
171
os.unlink('tree/foo')
172
tree.lock_tree_write()
173
self.addCleanup(tree.unlock)
150
174
shelver = ExpectShelver(tree, tree.basis_tree())
175
self.addCleanup(shelver.finalize)
151
176
shelver.expect('Shelve removing file "foo"? [yNfq?]', 'y')
152
177
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
154
179
self.assertFileEqual(LINES_AJ, 'tree/foo')
156
181
def test_shelve_creation(self):
157
self.thisFailsStrictLockCheck()
158
182
tree = self.make_branch_and_tree('tree')
159
183
tree.commit('add tree root')
160
184
self.build_tree(['tree/foo'])
186
tree.lock_tree_write()
187
self.addCleanup(tree.unlock)
162
188
shelver = ExpectShelver(tree, tree.basis_tree())
189
self.addCleanup(shelver.finalize)
163
190
shelver.expect('Shelve adding file "foo"? [yNfq?]', 'y')
164
191
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
166
self.failIfExists('tree/foo')
193
self.assertPathDoesNotExist('tree/foo')
168
195
def test_shelve_kind_change(self):
169
self.thisFailsStrictLockCheck()
170
196
tree = self.create_shelvable_tree()
171
197
os.unlink('tree/foo')
172
198
os.mkdir('tree/foo')
199
tree.lock_tree_write()
200
self.addCleanup(tree.unlock)
173
201
shelver = ExpectShelver(tree, tree.basis_tree())
202
self.addCleanup(shelver.finalize)
174
203
shelver.expect('Shelve changing "foo" from file to directory? [yNfq?]',
176
205
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
178
207
def test_shelve_modify_target(self):
179
self.thisFailsStrictLockCheck()
180
208
self.requireFeature(tests.SymlinkFeature)
181
209
tree = self.create_shelvable_tree()
182
210
os.symlink('bar', 'tree/baz')
192
223
self.assertEqual('bar', os.readlink('tree/baz'))
194
225
def test_shelve_finish(self):
195
self.thisFailsStrictLockCheck()
196
226
tree = self.create_shelvable_tree()
227
tree.lock_tree_write()
228
self.addCleanup(tree.unlock)
197
229
shelver = ExpectShelver(tree, tree.basis_tree())
230
self.addCleanup(shelver.finalize)
198
231
shelver.expect('Shelve? [yNfq?]', 'f')
199
232
shelver.expect('Shelve 2 change(s)? [yNfq?]', 'y')
201
234
self.assertFileEqual(LINES_AJ, 'tree/foo')
203
236
def test_shelve_quit(self):
204
self.thisFailsStrictLockCheck()
205
237
tree = self.create_shelvable_tree()
238
tree.lock_tree_write()
239
self.addCleanup(tree.unlock)
206
240
shelver = ExpectShelver(tree, tree.basis_tree())
241
self.addCleanup(shelver.finalize)
207
242
shelver.expect('Shelve? [yNfq?]', 'q')
208
243
self.assertRaises(errors.UserAbort, shelver.run)
209
244
self.assertFileEqual(LINES_ZY, 'tree/foo')
211
246
def test_shelve_all(self):
212
self.thisFailsStrictLockCheck()
213
247
tree = self.create_shelvable_tree()
214
ExpectShelver.from_args(sys.stdout, all=True, directory='tree').run()
248
shelver = ExpectShelver.from_args(sys.stdout, all=True,
215
254
self.assertFileEqual(LINES_AJ, 'tree/foo')
217
256
def test_shelve_filename(self):
218
self.thisFailsStrictLockCheck()
219
257
tree = self.create_shelvable_tree()
220
258
self.build_tree(['tree/bar'])
260
tree.lock_tree_write()
261
self.addCleanup(tree.unlock)
222
262
shelver = ExpectShelver(tree, tree.basis_tree(), file_list=['bar'])
263
self.addCleanup(shelver.finalize)
223
264
shelver.expect('Shelve adding file "bar"? [yNfq?]', 'y')
224
265
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
227
268
def test_shelve_help(self):
228
self.thisFailsStrictLockCheck()
229
269
tree = self.create_shelvable_tree()
270
tree.lock_tree_write()
271
self.addCleanup(tree.unlock)
230
272
shelver = ExpectShelver(tree, tree.basis_tree())
273
self.addCleanup(shelver.finalize)
231
274
shelver.expect('Shelve? [yNfq?]', '?')
232
275
shelver.expect('Shelve? [(y)es, (N)o, (f)inish, or (q)uit]', 'f')
233
276
shelver.expect('Shelve 2 change(s)? [yNfq?]', 'y')
236
def test_shelve_distroy(self):
237
self.thisFailsStrictLockCheck()
279
def test_shelve_destroy(self):
238
280
tree = self.create_shelvable_tree()
239
281
shelver = shelf_ui.Shelver.from_args(sys.stdout, all=True,
240
282
directory='tree', destroy=True)
283
self.addCleanup(shelver.finalize)
242
285
self.assertIs(None, tree.get_shelf_manager().last_shelf())
243
286
self.assertFileEqual(LINES_AJ, 'tree/foo')
289
def shelve_all(tree, target_revision_id):
292
target = tree.branch.repository.revision_tree(target_revision_id)
293
shelver = shelf_ui.Shelver(tree, target, auto=True,
302
def test_shelve_old_root_deleted(self):
303
tree1 = self.make_branch_and_tree('tree1')
304
tree1.commit('add root')
305
tree2 = self.make_branch_and_tree('tree2')
306
rev2 = tree2.commit('add root')
307
tree1.merge_from_branch(tree2.branch,
308
from_revision=revision.NULL_REVISION)
309
tree1.commit('Replaced root entry')
310
# This is essentially assertNotRaises(InconsistentDelta)
311
self.expectFailure('Cannot shelve replacing a root entry',
312
self.assertRaises, AssertionError,
313
self.assertRaises, errors.InconsistentDelta,
314
self.shelve_all, tree1, rev2)
316
def test_shelve_split(self):
317
outer_tree = self.make_branch_and_tree('outer')
318
outer_tree.commit('Add root')
319
inner_tree = self.make_branch_and_tree('outer/inner')
320
rev2 = inner_tree.commit('Add root')
321
outer_tree.subsume(inner_tree)
322
# This is essentially assertNotRaises(ValueError).
323
# The ValueError is 'None is not a valid file id'.
324
self.expectFailure('Cannot shelve a join back to the inner tree.',
325
self.assertRaises, AssertionError,
326
self.assertRaises, ValueError, self.shelve_all,
246
330
class TestApplyReporter(TestShelver):
248
332
def test_shelve_not_diff(self):
249
self.thisFailsStrictLockCheck()
250
333
tree = self.create_shelvable_tree()
334
tree.lock_tree_write()
335
self.addCleanup(tree.unlock)
251
336
shelver = ExpectShelver(tree, tree.basis_tree(),
252
337
reporter=shelf_ui.ApplyReporter())
338
self.addCleanup(shelver.finalize)
253
339
shelver.expect('Apply change? [yNfq?]', 'n')
254
340
shelver.expect('Apply change? [yNfq?]', 'n')
255
341
# No final shelving prompt because no changes were selected
279
369
self.assertFileEqual(LINES_AJ, 'tree/foo')
281
371
def test_shelve_binary_change(self):
282
self.thisFailsStrictLockCheck()
283
372
tree = self.create_shelvable_tree()
284
373
self.build_tree_contents([('tree/foo', '\x00')])
374
tree.lock_tree_write()
375
self.addCleanup(tree.unlock)
285
376
shelver = ExpectShelver(tree, tree.basis_tree(),
286
377
reporter=shelf_ui.ApplyReporter())
378
self.addCleanup(shelver.finalize)
287
379
shelver.expect('Apply binary changes? [yNfq?]', 'y')
288
380
shelver.expect('Apply 1 change(s)? [yNfq?]', 'y')
290
382
self.assertFileEqual(LINES_AJ, 'tree/foo')
292
384
def test_shelve_rename(self):
293
self.thisFailsStrictLockCheck()
294
385
tree = self.create_shelvable_tree()
295
386
tree.rename_one('foo', 'bar')
387
tree.lock_tree_write()
388
self.addCleanup(tree.unlock)
296
389
shelver = ExpectShelver(tree, tree.basis_tree(),
297
390
reporter=shelf_ui.ApplyReporter())
391
self.addCleanup(shelver.finalize)
298
392
shelver.expect('Rename "bar" => "foo"? [yNfq?]', 'y')
299
393
shelver.expect('Apply change? [yNfq?]', 'y')
300
394
shelver.expect('Apply change? [yNfq?]', 'y')
303
397
self.assertFileEqual(LINES_AJ, 'tree/foo')
305
399
def test_shelve_deletion(self):
306
self.thisFailsStrictLockCheck()
307
400
tree = self.create_shelvable_tree()
308
401
os.unlink('tree/foo')
402
tree.lock_tree_write()
403
self.addCleanup(tree.unlock)
309
404
shelver = ExpectShelver(tree, tree.basis_tree(),
310
405
reporter=shelf_ui.ApplyReporter())
406
self.addCleanup(shelver.finalize)
311
407
shelver.expect('Add file "foo"? [yNfq?]', 'y')
312
408
shelver.expect('Apply 1 change(s)? [yNfq?]', 'y')
314
410
self.assertFileEqual(LINES_AJ, 'tree/foo')
316
412
def test_shelve_creation(self):
317
self.thisFailsStrictLockCheck()
318
413
tree = self.make_branch_and_tree('tree')
319
414
tree.commit('add tree root')
320
415
self.build_tree(['tree/foo'])
417
tree.lock_tree_write()
418
self.addCleanup(tree.unlock)
322
419
shelver = ExpectShelver(tree, tree.basis_tree(),
323
420
reporter=shelf_ui.ApplyReporter())
421
self.addCleanup(shelver.finalize)
324
422
shelver.expect('Delete file "foo"? [yNfq?]', 'y')
325
423
shelver.expect('Apply 1 change(s)? [yNfq?]', 'y')
327
self.failIfExists('tree/foo')
425
self.assertPathDoesNotExist('tree/foo')
329
427
def test_shelve_kind_change(self):
330
self.thisFailsStrictLockCheck()
331
428
tree = self.create_shelvable_tree()
332
429
os.unlink('tree/foo')
333
430
os.mkdir('tree/foo')
431
tree.lock_tree_write()
432
self.addCleanup(tree.unlock)
334
433
shelver = ExpectShelver(tree, tree.basis_tree(),
335
434
reporter=shelf_ui.ApplyReporter())
435
self.addCleanup(shelver.finalize)
336
436
shelver.expect('Change "foo" from directory to a file? [yNfq?]', 'y')
337
437
shelver.expect('Apply 1 change(s)? [yNfq?]', 'y')
339
439
def test_shelve_modify_target(self):
340
self.thisFailsStrictLockCheck()
341
440
self.requireFeature(tests.SymlinkFeature)
342
441
tree = self.create_shelvable_tree()
343
442
os.symlink('bar', 'tree/baz')
359
461
def create_tree_with_shelf(self):
360
462
tree = self.make_branch_and_tree('tree')
361
self.build_tree_contents([('tree/foo', LINES_AJ)])
362
tree.add('foo', 'foo-id')
363
tree.commit('added foo')
364
self.build_tree_contents([('tree/foo', LINES_ZY)])
365
shelf_ui.Shelver(tree, tree.basis_tree(), auto_apply=True,
465
self.build_tree_contents([('tree/foo', LINES_AJ)])
466
tree.add('foo', 'foo-id')
467
tree.commit('added foo')
468
self.build_tree_contents([('tree/foo', LINES_ZY)])
469
shelver = shelf_ui.Shelver(tree, tree.basis_tree(),
470
auto_apply=True, auto=True)
369
479
def test_unshelve(self):
370
self.thisFailsStrictLockCheck()
371
480
tree = self.create_tree_with_shelf()
372
481
tree.lock_write()
373
482
self.addCleanup(tree.unlock)
376
485
self.assertFileEqual(LINES_ZY, 'tree/foo')
378
487
def test_unshelve_args(self):
379
self.thisFailsStrictLockCheck()
380
488
tree = self.create_tree_with_shelf()
381
shelf_ui.Unshelver.from_args(directory='tree').run()
489
unshelver = shelf_ui.Unshelver.from_args(directory='tree')
493
unshelver.tree.unlock()
382
494
self.assertFileEqual(LINES_ZY, 'tree/foo')
383
495
self.assertIs(None, tree.get_shelf_manager().last_shelf())
385
497
def test_unshelve_args_dry_run(self):
386
self.thisFailsStrictLockCheck()
387
tree = self.create_tree_with_shelf()
388
shelf_ui.Unshelver.from_args(directory='tree', action='dry-run').run()
389
self.assertFileEqual(LINES_AJ, 'tree/foo')
390
self.assertEqual(1, tree.get_shelf_manager().last_shelf())
498
tree = self.create_tree_with_shelf()
499
unshelver = shelf_ui.Unshelver.from_args(directory='tree',
504
unshelver.tree.unlock()
505
self.assertFileEqual(LINES_AJ, 'tree/foo')
506
self.assertEqual(1, tree.get_shelf_manager().last_shelf())
508
def test_unshelve_args_preview(self):
509
tree = self.create_tree_with_shelf()
510
write_diff_to = StringIO()
511
unshelver = shelf_ui.Unshelver.from_args(
512
directory='tree', action='preview', write_diff_to=write_diff_to)
516
unshelver.tree.unlock()
517
# The changes were not unshelved.
518
self.assertFileEqual(LINES_AJ, 'tree/foo')
519
self.assertEqual(1, tree.get_shelf_manager().last_shelf())
521
# But the diff was written to write_diff_to.
522
diff = write_diff_to.getvalue()
523
expected = dedent("""\
538
self.assertEqualDiff(expected, diff[-len(expected):])
392
540
def test_unshelve_args_delete_only(self):
393
self.thisFailsStrictLockCheck()
394
541
tree = self.make_branch_and_tree('tree')
395
542
manager = tree.get_shelf_manager()
396
543
shelf_file = manager.new_shelf()[1]
415
564
self.assertRaises(errors.InvalidShelfId,
416
565
shelf_ui.Unshelver.from_args, directory='tree',
417
566
action='delete-only', shelf_id='foo')
569
class TestUnshelveScripts(TestUnshelver,
570
script.TestCaseWithTransportAndScript):
572
def test_unshelve_messages_keep(self):
573
self.create_tree_with_shelf()
576
$ bzr unshelve --keep
577
2>Using changes with id "1".
579
2>All changes applied successfully.
582
def test_unshelve_messages_delete(self):
583
self.create_tree_with_shelf()
586
$ bzr unshelve --delete-only
587
2>Deleted changes with id "1".
590
def test_unshelve_messages_apply(self):
591
self.create_tree_with_shelf()
594
$ bzr unshelve --apply
595
2>Using changes with id "1".
597
2>All changes applied successfully.
598
2>Deleted changes with id "1".
601
def test_unshelve_messages_dry_run(self):
602
self.create_tree_with_shelf()
605
$ bzr unshelve --dry-run
606
2>Using changes with id "1".