76
69
def test_unexpected_prompt_failure(self):
77
70
tree = self.create_shelvable_tree()
78
tree.lock_tree_write()
79
self.addCleanup(tree.unlock)
80
71
shelver = ExpectShelver(tree, tree.basis_tree())
81
self.addCleanup(shelver.finalize)
82
72
e = self.assertRaises(AssertionError, shelver.run)
83
73
self.assertEqual('Unexpected prompt: Shelve? [yNfq?]', str(e))
85
75
def test_wrong_prompt_failure(self):
86
76
tree = self.create_shelvable_tree()
87
tree.lock_tree_write()
88
self.addCleanup(tree.unlock)
89
77
shelver = ExpectShelver(tree, tree.basis_tree())
90
self.addCleanup(shelver.finalize)
91
78
shelver.expect('foo', 'y')
92
79
e = self.assertRaises(AssertionError, shelver.run)
93
80
self.assertEqual('Wrong prompt: Shelve? [yNfq?]', str(e))
95
82
def test_shelve_not_diff(self):
96
83
tree = self.create_shelvable_tree()
97
tree.lock_tree_write()
98
self.addCleanup(tree.unlock)
99
84
shelver = ExpectShelver(tree, tree.basis_tree())
100
self.addCleanup(shelver.finalize)
101
85
shelver.expect('Shelve? [yNfq?]', 'n')
102
86
shelver.expect('Shelve? [yNfq?]', 'n')
103
87
# No final shelving prompt because no changes were selected
236
190
def test_shelve_quit(self):
237
191
tree = self.create_shelvable_tree()
238
tree.lock_tree_write()
239
self.addCleanup(tree.unlock)
240
192
shelver = ExpectShelver(tree, tree.basis_tree())
241
self.addCleanup(shelver.finalize)
242
193
shelver.expect('Shelve? [yNfq?]', 'q')
243
194
self.assertRaises(errors.UserAbort, shelver.run)
244
195
self.assertFileEqual(LINES_ZY, 'tree/foo')
246
197
def test_shelve_all(self):
247
198
tree = self.create_shelvable_tree()
248
shelver = ExpectShelver.from_args(sys.stdout, all=True,
199
ExpectShelver.from_args(sys.stdout, all=True, directory='tree').run()
254
200
self.assertFileEqual(LINES_AJ, 'tree/foo')
256
202
def test_shelve_filename(self):
257
203
tree = self.create_shelvable_tree()
258
204
self.build_tree(['tree/bar'])
260
tree.lock_tree_write()
261
self.addCleanup(tree.unlock)
262
206
shelver = ExpectShelver(tree, tree.basis_tree(), file_list=['bar'])
263
self.addCleanup(shelver.finalize)
264
207
shelver.expect('Shelve adding file "bar"? [yNfq?]', 'y')
265
208
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
268
211
def test_shelve_help(self):
269
212
tree = self.create_shelvable_tree()
270
tree.lock_tree_write()
271
self.addCleanup(tree.unlock)
272
213
shelver = ExpectShelver(tree, tree.basis_tree())
273
self.addCleanup(shelver.finalize)
274
214
shelver.expect('Shelve? [yNfq?]', '?')
275
215
shelver.expect('Shelve? [(y)es, (N)o, (f)inish, or (q)uit]', 'f')
276
216
shelver.expect('Shelve 2 change(s)? [yNfq?]', 'y')
279
def test_shelve_destroy(self):
219
def test_shelve_distroy(self):
280
220
tree = self.create_shelvable_tree()
281
221
shelver = shelf_ui.Shelver.from_args(sys.stdout, all=True,
282
222
directory='tree', destroy=True)
283
self.addCleanup(shelver.finalize)
285
224
self.assertIs(None, tree.get_shelf_manager().last_shelf())
286
225
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,
330
228
class TestApplyReporter(TestShelver):
332
230
def test_shelve_not_diff(self):
333
231
tree = self.create_shelvable_tree()
334
tree.lock_tree_write()
335
self.addCleanup(tree.unlock)
336
232
shelver = ExpectShelver(tree, tree.basis_tree(),
337
233
reporter=shelf_ui.ApplyReporter())
338
self.addCleanup(shelver.finalize)
339
234
shelver.expect('Apply change? [yNfq?]', 'n')
340
235
shelver.expect('Apply change? [yNfq?]', 'n')
341
236
# No final shelving prompt because no changes were selected
461
332
def create_tree_with_shelf(self):
462
333
tree = self.make_branch_and_tree('tree')
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)
334
self.build_tree_contents([('tree/foo', LINES_AJ)])
335
tree.add('foo', 'foo-id')
336
tree.commit('added foo')
337
self.build_tree_contents([('tree/foo', LINES_ZY)])
338
shelf_ui.Shelver(tree, tree.basis_tree(), auto_apply=True,
479
342
def test_unshelve(self):
487
350
def test_unshelve_args(self):
488
351
tree = self.create_tree_with_shelf()
489
unshelver = shelf_ui.Unshelver.from_args(directory='tree')
493
unshelver.tree.unlock()
352
shelf_ui.Unshelver.from_args(directory='tree').run()
494
353
self.assertFileEqual(LINES_ZY, 'tree/foo')
495
354
self.assertIs(None, tree.get_shelf_manager().last_shelf())
497
356
def test_unshelve_args_dry_run(self):
498
357
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):])
358
shelf_ui.Unshelver.from_args(directory='tree', action='dry-run').run()
359
self.assertFileEqual(LINES_AJ, 'tree/foo')
360
self.assertEqual(1, tree.get_shelf_manager().last_shelf())
540
362
def test_unshelve_args_delete_only(self):
541
363
tree = self.make_branch_and_tree('tree')
564
383
self.assertRaises(errors.InvalidShelfId,
565
384
shelf_ui.Unshelver.from_args, directory='tree',
566
385
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".