73
66
self.build_tree_contents([('tree/foo', LINES_ZY)])
77
class TestShelver(ShelfTestCase):
79
69
def test_unexpected_prompt_failure(self):
80
70
tree = self.create_shelvable_tree()
81
tree.lock_tree_write()
82
self.addCleanup(tree.unlock)
83
71
shelver = ExpectShelver(tree, tree.basis_tree())
84
self.addCleanup(shelver.finalize)
85
72
e = self.assertRaises(AssertionError, shelver.run)
86
73
self.assertEqual('Unexpected prompt: Shelve? [yNfq?]', str(e))
88
75
def test_wrong_prompt_failure(self):
89
76
tree = self.create_shelvable_tree()
90
tree.lock_tree_write()
91
self.addCleanup(tree.unlock)
92
77
shelver = ExpectShelver(tree, tree.basis_tree())
93
self.addCleanup(shelver.finalize)
94
78
shelver.expect('foo', 'y')
95
79
e = self.assertRaises(AssertionError, shelver.run)
96
80
self.assertEqual('Wrong prompt: Shelve? [yNfq?]', str(e))
98
82
def test_shelve_not_diff(self):
99
83
tree = self.create_shelvable_tree()
100
tree.lock_tree_write()
101
self.addCleanup(tree.unlock)
102
84
shelver = ExpectShelver(tree, tree.basis_tree())
103
self.addCleanup(shelver.finalize)
104
85
shelver.expect('Shelve? [yNfq?]', 'n')
105
86
shelver.expect('Shelve? [yNfq?]', 'n')
106
87
# No final shelving prompt because no changes were selected
186
149
tree.commit('add tree root')
187
150
self.build_tree(['tree/foo'])
189
tree.lock_tree_write()
190
self.addCleanup(tree.unlock)
191
152
shelver = ExpectShelver(tree, tree.basis_tree())
192
self.addCleanup(shelver.finalize)
193
153
shelver.expect('Shelve adding file "foo"? [yNfq?]', 'y')
194
154
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
196
self.assertPathDoesNotExist('tree/foo')
156
self.failIfExists('tree/foo')
198
158
def test_shelve_kind_change(self):
199
159
tree = self.create_shelvable_tree()
200
160
os.unlink('tree/foo')
201
161
os.mkdir('tree/foo')
202
tree.lock_tree_write()
203
self.addCleanup(tree.unlock)
204
162
shelver = ExpectShelver(tree, tree.basis_tree())
205
self.addCleanup(shelver.finalize)
206
163
shelver.expect('Shelve changing "foo" from file to directory? [yNfq?]',
208
165
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
239
190
def test_shelve_quit(self):
240
191
tree = self.create_shelvable_tree()
241
tree.lock_tree_write()
242
self.addCleanup(tree.unlock)
243
192
shelver = ExpectShelver(tree, tree.basis_tree())
244
self.addCleanup(shelver.finalize)
245
193
shelver.expect('Shelve? [yNfq?]', 'q')
246
194
self.assertRaises(errors.UserAbort, shelver.run)
247
195
self.assertFileEqual(LINES_ZY, 'tree/foo')
249
197
def test_shelve_all(self):
250
198
tree = self.create_shelvable_tree()
251
shelver = ExpectShelver.from_args(sys.stdout, all=True,
199
ExpectShelver.from_args(sys.stdout, all=True, directory='tree').run()
257
200
self.assertFileEqual(LINES_AJ, 'tree/foo')
259
202
def test_shelve_filename(self):
260
203
tree = self.create_shelvable_tree()
261
204
self.build_tree(['tree/bar'])
263
tree.lock_tree_write()
264
self.addCleanup(tree.unlock)
265
206
shelver = ExpectShelver(tree, tree.basis_tree(), file_list=['bar'])
266
self.addCleanup(shelver.finalize)
267
207
shelver.expect('Shelve adding file "bar"? [yNfq?]', 'y')
268
208
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
271
211
def test_shelve_help(self):
272
212
tree = self.create_shelvable_tree()
273
tree.lock_tree_write()
274
self.addCleanup(tree.unlock)
275
213
shelver = ExpectShelver(tree, tree.basis_tree())
276
self.addCleanup(shelver.finalize)
277
214
shelver.expect('Shelve? [yNfq?]', '?')
278
215
shelver.expect('Shelve? [(y)es, (N)o, (f)inish, or (q)uit]', 'f')
279
216
shelver.expect('Shelve 2 change(s)? [yNfq?]', 'y')
282
def test_shelve_destroy(self):
219
def test_shelve_distroy(self):
283
220
tree = self.create_shelvable_tree()
284
221
shelver = shelf_ui.Shelver.from_args(sys.stdout, all=True,
285
222
directory='tree', destroy=True)
286
self.addCleanup(shelver.finalize)
288
224
self.assertIs(None, tree.get_shelf_manager().last_shelf())
289
225
self.assertFileEqual(LINES_AJ, 'tree/foo')
292
def shelve_all(tree, target_revision_id):
295
target = tree.branch.repository.revision_tree(target_revision_id)
296
shelver = shelf_ui.Shelver(tree, target, auto=True,
305
def test_shelve_old_root_deleted(self):
306
tree1 = self.make_branch_and_tree('tree1')
307
tree1.commit('add root')
308
tree2 = self.make_branch_and_tree('tree2')
309
rev2 = tree2.commit('add root')
310
tree1.merge_from_branch(tree2.branch,
311
from_revision=revision.NULL_REVISION)
312
tree1.commit('Replaced root entry')
313
# This is essentially assertNotRaises(InconsistentDelta)
314
# With testtools 0.99, it can be rewritten as:
315
# with ExpectedException(AssertionError,
316
# 'InconsistentDelta not raised'):
317
# with ExpectedException(errors.InconsistentDelta, ''):
318
# self.shelve_all(tree1, rev2)
319
e = self.assertRaises(AssertionError, self.assertRaises,
320
errors.InconsistentDelta, self.shelve_all, tree1,
322
self.assertContainsRe('InconsistentDelta not raised', str(e))
324
def test_shelve_split(self):
325
outer_tree = self.make_branch_and_tree('outer')
326
outer_tree.commit('Add root')
327
inner_tree = self.make_branch_and_tree('outer/inner')
328
rev2 = inner_tree.commit('Add root')
329
outer_tree.subsume(inner_tree)
330
# This is essentially assertNotRaises(ValueError).
331
# The ValueError is 'None is not a valid file id'.
332
self.expectFailure('Cannot shelve a join back to the inner tree.',
333
self.assertRaises, AssertionError,
334
self.assertRaises, ValueError, self.shelve_all,
338
class TestApplyReporter(ShelfTestCase):
228
class TestApplyReporter(TestShelver):
340
230
def test_shelve_not_diff(self):
341
231
tree = self.create_shelvable_tree()
342
tree.lock_tree_write()
343
self.addCleanup(tree.unlock)
344
232
shelver = ExpectShelver(tree, tree.basis_tree(),
345
233
reporter=shelf_ui.ApplyReporter())
346
self.addCleanup(shelver.finalize)
347
234
shelver.expect('Apply change? [yNfq?]', 'n')
348
235
shelver.expect('Apply change? [yNfq?]', 'n')
349
236
# No final shelving prompt because no changes were selected
422
294
tree.commit('add tree root')
423
295
self.build_tree(['tree/foo'])
425
tree.lock_tree_write()
426
self.addCleanup(tree.unlock)
427
297
shelver = ExpectShelver(tree, tree.basis_tree(),
428
298
reporter=shelf_ui.ApplyReporter())
429
self.addCleanup(shelver.finalize)
430
299
shelver.expect('Delete file "foo"? [yNfq?]', 'y')
431
300
shelver.expect('Apply 1 change(s)? [yNfq?]', 'y')
433
self.assertPathDoesNotExist('tree/foo')
302
self.failIfExists('tree/foo')
435
304
def test_shelve_kind_change(self):
436
305
tree = self.create_shelvable_tree()
437
306
os.unlink('tree/foo')
438
307
os.mkdir('tree/foo')
439
tree.lock_tree_write()
440
self.addCleanup(tree.unlock)
441
308
shelver = ExpectShelver(tree, tree.basis_tree(),
442
309
reporter=shelf_ui.ApplyReporter())
443
self.addCleanup(shelver.finalize)
444
310
shelver.expect('Change "foo" from directory to a file? [yNfq?]', 'y')
445
311
shelver.expect('Apply 1 change(s)? [yNfq?]', 'y')
495
350
def test_unshelve_args(self):
496
351
tree = self.create_tree_with_shelf()
497
unshelver = shelf_ui.Unshelver.from_args(directory='tree')
501
unshelver.tree.unlock()
352
shelf_ui.Unshelver.from_args(directory='tree').run()
502
353
self.assertFileEqual(LINES_ZY, 'tree/foo')
503
354
self.assertIs(None, tree.get_shelf_manager().last_shelf())
505
356
def test_unshelve_args_dry_run(self):
506
357
tree = self.create_tree_with_shelf()
507
unshelver = shelf_ui.Unshelver.from_args(directory='tree',
512
unshelver.tree.unlock()
513
self.assertFileEqual(LINES_AJ, 'tree/foo')
514
self.assertEqual(1, tree.get_shelf_manager().last_shelf())
516
def test_unshelve_args_preview(self):
517
tree = self.create_tree_with_shelf()
518
write_diff_to = StringIO()
519
unshelver = shelf_ui.Unshelver.from_args(
520
directory='tree', action='preview', write_diff_to=write_diff_to)
524
unshelver.tree.unlock()
525
# The changes were not unshelved.
526
self.assertFileEqual(LINES_AJ, 'tree/foo')
527
self.assertEqual(1, tree.get_shelf_manager().last_shelf())
529
# But the diff was written to write_diff_to.
530
diff = write_diff_to.getvalue()
531
expected = dedent("""\
546
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())
548
362
def test_unshelve_args_delete_only(self):
549
363
tree = self.make_branch_and_tree('tree')
572
383
self.assertRaises(errors.InvalidShelfId,
573
384
shelf_ui.Unshelver.from_args, directory='tree',
574
385
action='delete-only', shelf_id='foo')
577
class TestUnshelveScripts(TestUnshelver,
578
script.TestCaseWithTransportAndScript):
580
def test_unshelve_messages_keep(self):
581
self.create_tree_with_shelf()
584
$ bzr unshelve --keep
585
2>Using changes with id "1".
587
2>All changes applied successfully.
590
def test_unshelve_messages_delete(self):
591
self.create_tree_with_shelf()
594
$ bzr unshelve --delete-only
595
2>Deleted changes with id "1".
598
def test_unshelve_messages_apply(self):
599
self.create_tree_with_shelf()
602
$ bzr unshelve --apply
603
2>Using changes with id "1".
605
2>All changes applied successfully.
606
2>Deleted changes with id "1".
609
def test_unshelve_messages_dry_run(self):
610
self.create_tree_with_shelf()
613
$ bzr unshelve --dry-run
614
2>Using changes with id "1".