76
66
self.build_tree_contents([('tree/foo', LINES_ZY)])
80
class TestShelver(ShelfTestCase):
82
69
def test_unexpected_prompt_failure(self):
83
70
tree = self.create_shelvable_tree()
84
tree.lock_tree_write()
85
self.addCleanup(tree.unlock)
86
71
shelver = ExpectShelver(tree, tree.basis_tree())
87
self.addCleanup(shelver.finalize)
88
72
e = self.assertRaises(AssertionError, shelver.run)
89
73
self.assertEqual('Unexpected prompt: Shelve? [yNfq?]', str(e))
91
75
def test_wrong_prompt_failure(self):
92
76
tree = self.create_shelvable_tree()
93
tree.lock_tree_write()
94
self.addCleanup(tree.unlock)
95
77
shelver = ExpectShelver(tree, tree.basis_tree())
96
self.addCleanup(shelver.finalize)
97
78
shelver.expect('foo', 'y')
98
79
e = self.assertRaises(AssertionError, shelver.run)
99
80
self.assertEqual('Wrong prompt: Shelve? [yNfq?]', str(e))
101
82
def test_shelve_not_diff(self):
102
83
tree = self.create_shelvable_tree()
103
tree.lock_tree_write()
104
self.addCleanup(tree.unlock)
105
84
shelver = ExpectShelver(tree, tree.basis_tree())
106
self.addCleanup(shelver.finalize)
107
85
shelver.expect('Shelve? [yNfq?]', 'n')
108
86
shelver.expect('Shelve? [yNfq?]', 'n')
109
87
# No final shelving prompt because no changes were selected
189
149
tree.commit('add tree root')
190
150
self.build_tree(['tree/foo'])
192
tree.lock_tree_write()
193
self.addCleanup(tree.unlock)
194
152
shelver = ExpectShelver(tree, tree.basis_tree())
195
self.addCleanup(shelver.finalize)
196
153
shelver.expect('Shelve adding file "foo"? [yNfq?]', 'y')
197
154
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
199
self.assertPathDoesNotExist('tree/foo')
156
self.failIfExists('tree/foo')
201
158
def test_shelve_kind_change(self):
202
159
tree = self.create_shelvable_tree()
203
160
os.unlink('tree/foo')
204
161
os.mkdir('tree/foo')
205
tree.lock_tree_write()
206
self.addCleanup(tree.unlock)
207
162
shelver = ExpectShelver(tree, tree.basis_tree())
208
self.addCleanup(shelver.finalize)
209
163
shelver.expect('Shelve changing "foo" from file to directory? [yNfq?]',
211
165
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
213
167
def test_shelve_modify_target(self):
214
self.requireFeature(features.SymlinkFeature)
168
self.requireFeature(tests.SymlinkFeature)
215
169
tree = self.create_shelvable_tree()
216
170
os.symlink('bar', 'tree/baz')
217
171
tree.add('baz', 'baz-id')
218
172
tree.commit("Add symlink")
219
173
os.unlink('tree/baz')
220
174
os.symlink('vax', 'tree/baz')
221
tree.lock_tree_write()
222
self.addCleanup(tree.unlock)
223
175
shelver = ExpectShelver(tree, tree.basis_tree())
224
self.addCleanup(shelver.finalize)
225
176
shelver.expect('Shelve changing target of "baz" from "bar" to '
226
177
'"vax"? [yNfq?]', 'y')
227
178
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
242
190
def test_shelve_quit(self):
243
191
tree = self.create_shelvable_tree()
244
tree.lock_tree_write()
245
self.addCleanup(tree.unlock)
246
192
shelver = ExpectShelver(tree, tree.basis_tree())
247
self.addCleanup(shelver.finalize)
248
193
shelver.expect('Shelve? [yNfq?]', 'q')
249
194
self.assertRaises(errors.UserAbort, shelver.run)
250
195
self.assertFileEqual(LINES_ZY, 'tree/foo')
252
197
def test_shelve_all(self):
253
198
tree = self.create_shelvable_tree()
254
shelver = ExpectShelver.from_args(sys.stdout, all=True,
199
ExpectShelver.from_args(sys.stdout, all=True, directory='tree').run()
260
200
self.assertFileEqual(LINES_AJ, 'tree/foo')
262
202
def test_shelve_filename(self):
263
203
tree = self.create_shelvable_tree()
264
204
self.build_tree(['tree/bar'])
266
tree.lock_tree_write()
267
self.addCleanup(tree.unlock)
268
206
shelver = ExpectShelver(tree, tree.basis_tree(), file_list=['bar'])
269
self.addCleanup(shelver.finalize)
270
207
shelver.expect('Shelve adding file "bar"? [yNfq?]', 'y')
271
208
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
274
211
def test_shelve_help(self):
275
212
tree = self.create_shelvable_tree()
276
tree.lock_tree_write()
277
self.addCleanup(tree.unlock)
278
213
shelver = ExpectShelver(tree, tree.basis_tree())
279
self.addCleanup(shelver.finalize)
280
214
shelver.expect('Shelve? [yNfq?]', '?')
281
215
shelver.expect('Shelve? [(y)es, (N)o, (f)inish, or (q)uit]', 'f')
282
216
shelver.expect('Shelve 2 change(s)? [yNfq?]', 'y')
285
def test_shelve_destroy(self):
219
def test_shelve_distroy(self):
286
220
tree = self.create_shelvable_tree()
287
221
shelver = shelf_ui.Shelver.from_args(sys.stdout, all=True,
288
222
directory='tree', destroy=True)
289
self.addCleanup(shelver.finalize)
291
224
self.assertIs(None, tree.get_shelf_manager().last_shelf())
292
225
self.assertFileEqual(LINES_AJ, 'tree/foo')
295
def shelve_all(tree, target_revision_id):
298
target = tree.branch.repository.revision_tree(target_revision_id)
299
shelver = shelf_ui.Shelver(tree, target, auto=True,
308
def test_shelve_old_root_preserved(self):
309
tree1 = self.make_branch_and_tree('tree1')
310
tree1.commit('add root')
311
tree1_root_id = tree1.get_root_id()
312
tree2 = self.make_branch_and_tree('tree2')
313
rev2 = tree2.commit('add root')
314
self.assertNotEquals(tree1_root_id, tree2.get_root_id())
315
tree1.merge_from_branch(tree2.branch,
316
from_revision=revision.NULL_REVISION)
317
tree1.commit('merging in tree2')
318
self.assertEquals(tree1_root_id, tree1.get_root_id())
319
# This is essentially assertNotRaises(InconsistentDelta)
320
# With testtools 0.9.9, it can be rewritten as:
321
# with ExpectedException(AssertionError,
322
# 'InconsistentDelta not raised'):
323
# with ExpectedException(errors.InconsistentDelta, ''):
324
# self.shelve_all(tree1, rev2)
325
e = self.assertRaises(AssertionError, self.assertRaises,
326
errors.InconsistentDelta, self.shelve_all, tree1,
328
self.assertContainsRe('InconsistentDelta not raised', str(e))
330
def test_shelve_split(self):
331
outer_tree = self.make_branch_and_tree('outer')
332
outer_tree.commit('Add root')
333
inner_tree = self.make_branch_and_tree('outer/inner')
334
rev2 = inner_tree.commit('Add root')
335
outer_tree.subsume(inner_tree)
336
# This is essentially assertNotRaises(ValueError).
337
# The ValueError is 'None is not a valid file id'.
338
self.expectFailure('Cannot shelve a join back to the inner tree.',
339
self.assertRaises, AssertionError,
340
self.assertRaises, ValueError, self.shelve_all,
344
class TestApplyReporter(ShelfTestCase):
228
class TestApplyReporter(TestShelver):
346
230
def test_shelve_not_diff(self):
347
231
tree = self.create_shelvable_tree()
348
tree.lock_tree_write()
349
self.addCleanup(tree.unlock)
350
232
shelver = ExpectShelver(tree, tree.basis_tree(),
351
233
reporter=shelf_ui.ApplyReporter())
352
self.addCleanup(shelver.finalize)
353
234
shelver.expect('Apply change? [yNfq?]', 'n')
354
235
shelver.expect('Apply change? [yNfq?]', 'n')
355
236
# No final shelving prompt because no changes were selected
428
294
tree.commit('add tree root')
429
295
self.build_tree(['tree/foo'])
431
tree.lock_tree_write()
432
self.addCleanup(tree.unlock)
433
297
shelver = ExpectShelver(tree, tree.basis_tree(),
434
298
reporter=shelf_ui.ApplyReporter())
435
self.addCleanup(shelver.finalize)
436
299
shelver.expect('Delete file "foo"? [yNfq?]', 'y')
437
300
shelver.expect('Apply 1 change(s)? [yNfq?]', 'y')
439
self.assertPathDoesNotExist('tree/foo')
302
self.failIfExists('tree/foo')
441
304
def test_shelve_kind_change(self):
442
305
tree = self.create_shelvable_tree()
443
306
os.unlink('tree/foo')
444
307
os.mkdir('tree/foo')
445
tree.lock_tree_write()
446
self.addCleanup(tree.unlock)
447
308
shelver = ExpectShelver(tree, tree.basis_tree(),
448
309
reporter=shelf_ui.ApplyReporter())
449
self.addCleanup(shelver.finalize)
450
310
shelver.expect('Change "foo" from directory to a file? [yNfq?]', 'y')
451
311
shelver.expect('Apply 1 change(s)? [yNfq?]', 'y')
453
313
def test_shelve_modify_target(self):
454
self.requireFeature(features.SymlinkFeature)
314
self.requireFeature(tests.SymlinkFeature)
455
315
tree = self.create_shelvable_tree()
456
316
os.symlink('bar', 'tree/baz')
457
317
tree.add('baz', 'baz-id')
458
318
tree.commit("Add symlink")
459
319
os.unlink('tree/baz')
460
320
os.symlink('vax', 'tree/baz')
461
tree.lock_tree_write()
462
self.addCleanup(tree.unlock)
463
321
shelver = ExpectShelver(tree, tree.basis_tree(),
464
322
reporter=shelf_ui.ApplyReporter())
465
self.addCleanup(shelver.finalize)
466
323
shelver.expect('Change target of "baz" from "vax" to "bar"? [yNfq?]',
468
325
shelver.expect('Apply 1 change(s)? [yNfq?]', 'y')
501
350
def test_unshelve_args(self):
502
351
tree = self.create_tree_with_shelf()
503
unshelver = shelf_ui.Unshelver.from_args(directory='tree')
507
unshelver.tree.unlock()
352
shelf_ui.Unshelver.from_args(directory='tree').run()
508
353
self.assertFileEqual(LINES_ZY, 'tree/foo')
509
354
self.assertIs(None, tree.get_shelf_manager().last_shelf())
511
356
def test_unshelve_args_dry_run(self):
512
357
tree = self.create_tree_with_shelf()
513
unshelver = shelf_ui.Unshelver.from_args(directory='tree',
518
unshelver.tree.unlock()
519
self.assertFileEqual(LINES_AJ, 'tree/foo')
520
self.assertEqual(1, tree.get_shelf_manager().last_shelf())
522
def test_unshelve_args_preview(self):
523
tree = self.create_tree_with_shelf()
524
write_diff_to = StringIO()
525
unshelver = shelf_ui.Unshelver.from_args(
526
directory='tree', action='preview', write_diff_to=write_diff_to)
530
unshelver.tree.unlock()
531
# The changes were not unshelved.
532
self.assertFileEqual(LINES_AJ, 'tree/foo')
533
self.assertEqual(1, tree.get_shelf_manager().last_shelf())
535
# But the diff was written to write_diff_to.
536
diff = write_diff_to.getvalue()
537
expected = dedent("""\
552
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())
554
362
def test_unshelve_args_delete_only(self):
555
363
tree = self.make_branch_and_tree('tree')
578
383
self.assertRaises(errors.InvalidShelfId,
579
384
shelf_ui.Unshelver.from_args, directory='tree',
580
385
action='delete-only', shelf_id='foo')
583
class TestUnshelveScripts(TestUnshelver,
584
script.TestCaseWithTransportAndScript):
586
def test_unshelve_messages_keep(self):
587
self.create_tree_with_shelf()
590
$ bzr unshelve --keep
591
2>Using changes with id "1".
593
2>All changes applied successfully.
596
def test_unshelve_messages_delete(self):
597
self.create_tree_with_shelf()
600
$ bzr unshelve --delete-only
601
2>Deleted changes with id "1".
604
def test_unshelve_messages_apply(self):
605
self.create_tree_with_shelf()
608
$ bzr unshelve --apply
609
2>Using changes with id "1".
611
2>All changes applied successfully.
612
2>Deleted changes with id "1".
615
def test_unshelve_messages_dry_run(self):
616
self.create_tree_with_shelf()
619
$ bzr unshelve --dry-run
620
2>Using changes with id "1".