76
64
self.build_tree_contents([('tree/foo', LINES_ZY)])
80
class TestShelver(ShelfTestCase):
82
67
def test_unexpected_prompt_failure(self):
83
68
tree = self.create_shelvable_tree()
84
tree.lock_tree_write()
85
self.addCleanup(tree.unlock)
86
69
shelver = ExpectShelver(tree, tree.basis_tree())
87
self.addCleanup(shelver.finalize)
88
70
e = self.assertRaises(AssertionError, shelver.run)
89
self.assertEqual('Unexpected prompt: Shelve? [yNfq?]', str(e))
71
self.assertEqual('Unexpected prompt: Shelve? [yNfq]', str(e))
91
73
def test_wrong_prompt_failure(self):
92
74
tree = self.create_shelvable_tree()
93
tree.lock_tree_write()
94
self.addCleanup(tree.unlock)
95
75
shelver = ExpectShelver(tree, tree.basis_tree())
96
self.addCleanup(shelver.finalize)
97
76
shelver.expect('foo', 'y')
98
77
e = self.assertRaises(AssertionError, shelver.run)
99
self.assertEqual('Wrong prompt: Shelve? [yNfq?]', str(e))
78
self.assertEqual('Wrong prompt: Shelve? [yNfq]', str(e))
101
80
def test_shelve_not_diff(self):
102
81
tree = self.create_shelvable_tree()
103
tree.lock_tree_write()
104
self.addCleanup(tree.unlock)
105
82
shelver = ExpectShelver(tree, tree.basis_tree())
106
self.addCleanup(shelver.finalize)
107
shelver.expect('Shelve? [yNfq?]', 'n')
108
shelver.expect('Shelve? [yNfq?]', 'n')
83
shelver.expect('Shelve? [yNfq]', 'n')
84
shelver.expect('Shelve? [yNfq]', 'n')
109
85
# No final shelving prompt because no changes were selected
111
87
self.assertFileEqual(LINES_ZY, 'tree/foo')
113
89
def test_shelve_diff_no(self):
114
90
tree = self.create_shelvable_tree()
115
tree.lock_tree_write()
116
self.addCleanup(tree.unlock)
117
91
shelver = ExpectShelver(tree, tree.basis_tree())
118
self.addCleanup(shelver.finalize)
119
shelver.expect('Shelve? [yNfq?]', 'y')
120
shelver.expect('Shelve? [yNfq?]', 'y')
121
shelver.expect('Shelve 2 change(s)? [yNfq?]', 'n')
92
shelver.expect('Shelve? [yNfq]', 'y')
93
shelver.expect('Shelve? [yNfq]', 'y')
94
shelver.expect('Shelve 2 change(s)? [yNfq]', 'n')
123
96
self.assertFileEqual(LINES_ZY, 'tree/foo')
125
98
def test_shelve_diff(self):
126
99
tree = self.create_shelvable_tree()
127
tree.lock_tree_write()
128
self.addCleanup(tree.unlock)
129
100
shelver = ExpectShelver(tree, tree.basis_tree())
130
self.addCleanup(shelver.finalize)
131
shelver.expect('Shelve? [yNfq?]', 'y')
132
shelver.expect('Shelve? [yNfq?]', 'y')
133
shelver.expect('Shelve 2 change(s)? [yNfq?]', 'y')
101
shelver.expect('Shelve? [yNfq]', 'y')
102
shelver.expect('Shelve? [yNfq]', 'y')
103
shelver.expect('Shelve 2 change(s)? [yNfq]', 'y')
135
105
self.assertFileEqual(LINES_AJ, 'tree/foo')
137
107
def test_shelve_one_diff(self):
138
108
tree = self.create_shelvable_tree()
139
tree.lock_tree_write()
140
self.addCleanup(tree.unlock)
141
109
shelver = ExpectShelver(tree, tree.basis_tree())
142
self.addCleanup(shelver.finalize)
143
shelver.expect('Shelve? [yNfq?]', 'y')
144
shelver.expect('Shelve? [yNfq?]', 'n')
145
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
110
shelver.expect('Shelve? [yNfq]', 'y')
111
shelver.expect('Shelve? [yNfq]', 'n')
112
shelver.expect('Shelve 1 change(s)? [yNfq]', 'y')
147
114
self.assertFileEqual(LINES_AY, 'tree/foo')
149
116
def test_shelve_binary_change(self):
150
117
tree = self.create_shelvable_tree()
151
118
self.build_tree_contents([('tree/foo', '\x00')])
152
tree.lock_tree_write()
153
self.addCleanup(tree.unlock)
154
119
shelver = ExpectShelver(tree, tree.basis_tree())
155
self.addCleanup(shelver.finalize)
156
shelver.expect('Shelve binary changes? [yNfq?]', 'y')
157
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
120
shelver.expect('Shelve binary changes? [yNfq]', 'y')
121
shelver.expect('Shelve 1 change(s)? [yNfq]', 'y')
159
123
self.assertFileEqual(LINES_AJ, 'tree/foo')
161
125
def test_shelve_rename(self):
162
126
tree = self.create_shelvable_tree()
163
127
tree.rename_one('foo', 'bar')
164
tree.lock_tree_write()
165
self.addCleanup(tree.unlock)
166
128
shelver = ExpectShelver(tree, tree.basis_tree())
167
self.addCleanup(shelver.finalize)
168
shelver.expect('Shelve renaming "foo" => "bar"? [yNfq?]', 'y')
169
shelver.expect('Shelve? [yNfq?]', 'y')
170
shelver.expect('Shelve? [yNfq?]', 'y')
171
shelver.expect('Shelve 3 change(s)? [yNfq?]', 'y')
129
shelver.expect('Shelve renaming "foo" => "bar"? [yNfq]', 'y')
130
shelver.expect('Shelve? [yNfq]', 'y')
131
shelver.expect('Shelve? [yNfq]', 'y')
132
shelver.expect('Shelve 3 change(s)? [yNfq]', 'y')
173
134
self.assertFileEqual(LINES_AJ, 'tree/foo')
175
136
def test_shelve_deletion(self):
176
137
tree = self.create_shelvable_tree()
177
138
os.unlink('tree/foo')
178
tree.lock_tree_write()
179
self.addCleanup(tree.unlock)
180
139
shelver = ExpectShelver(tree, tree.basis_tree())
181
self.addCleanup(shelver.finalize)
182
shelver.expect('Shelve removing file "foo"? [yNfq?]', 'y')
183
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
140
shelver.expect('Shelve removing file "foo"? [yNfq]', 'y')
141
shelver.expect('Shelve 1 change(s)? [yNfq]', 'y')
185
143
self.assertFileEqual(LINES_AJ, 'tree/foo')
189
147
tree.commit('add tree root')
190
148
self.build_tree(['tree/foo'])
192
tree.lock_tree_write()
193
self.addCleanup(tree.unlock)
194
150
shelver = ExpectShelver(tree, tree.basis_tree())
195
self.addCleanup(shelver.finalize)
196
shelver.expect('Shelve adding file "foo"? [yNfq?]', 'y')
197
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
151
shelver.expect('Shelve adding file "foo"? [yNfq]', 'y')
152
shelver.expect('Shelve 1 change(s)? [yNfq]', 'y')
199
self.assertPathDoesNotExist('tree/foo')
154
self.failIfExists('tree/foo')
201
156
def test_shelve_kind_change(self):
202
157
tree = self.create_shelvable_tree()
203
158
os.unlink('tree/foo')
204
159
os.mkdir('tree/foo')
205
tree.lock_tree_write()
206
self.addCleanup(tree.unlock)
207
160
shelver = ExpectShelver(tree, tree.basis_tree())
208
self.addCleanup(shelver.finalize)
209
shelver.expect('Shelve changing "foo" from file to directory? [yNfq?]',
161
shelver.expect('Shelve changing "foo" from file to directory? [yNfq]',
211
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
213
def test_shelve_modify_target(self):
214
self.requireFeature(features.SymlinkFeature)
215
tree = self.create_shelvable_tree()
216
os.symlink('bar', 'tree/baz')
217
tree.add('baz', 'baz-id')
218
tree.commit("Add symlink")
219
os.unlink('tree/baz')
220
os.symlink('vax', 'tree/baz')
221
tree.lock_tree_write()
222
self.addCleanup(tree.unlock)
223
shelver = ExpectShelver(tree, tree.basis_tree())
224
self.addCleanup(shelver.finalize)
225
shelver.expect('Shelve changing target of "baz" from "bar" to '
226
'"vax"? [yNfq?]', 'y')
227
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
229
self.assertEqual('bar', os.readlink('tree/baz'))
163
shelver.expect('Shelve 1 change(s)? [yNfq]', 'y')
231
165
def test_shelve_finish(self):
232
166
tree = self.create_shelvable_tree()
233
tree.lock_tree_write()
234
self.addCleanup(tree.unlock)
235
167
shelver = ExpectShelver(tree, tree.basis_tree())
236
self.addCleanup(shelver.finalize)
237
shelver.expect('Shelve? [yNfq?]', 'f')
238
shelver.expect('Shelve 2 change(s)? [yNfq?]', 'y')
168
shelver.expect('Shelve? [yNfq]', 'f')
169
shelver.expect('Shelve 2 change(s)? [yNfq]', 'y')
240
171
self.assertFileEqual(LINES_AJ, 'tree/foo')
242
173
def test_shelve_quit(self):
243
174
tree = self.create_shelvable_tree()
244
tree.lock_tree_write()
245
self.addCleanup(tree.unlock)
246
175
shelver = ExpectShelver(tree, tree.basis_tree())
247
self.addCleanup(shelver.finalize)
248
shelver.expect('Shelve? [yNfq?]', 'q')
176
shelver.expect('Shelve? [yNfq]', 'q')
249
177
self.assertRaises(errors.UserAbort, shelver.run)
250
178
self.assertFileEqual(LINES_ZY, 'tree/foo')
252
180
def test_shelve_all(self):
253
181
tree = self.create_shelvable_tree()
254
shelver = ExpectShelver.from_args(sys.stdout, all=True,
182
ExpectShelver.from_args(sys.stdout, all=True, directory='tree').run()
260
183
self.assertFileEqual(LINES_AJ, 'tree/foo')
262
185
def test_shelve_filename(self):
263
186
tree = self.create_shelvable_tree()
264
187
self.build_tree(['tree/bar'])
266
tree.lock_tree_write()
267
self.addCleanup(tree.unlock)
268
189
shelver = ExpectShelver(tree, tree.basis_tree(), file_list=['bar'])
269
self.addCleanup(shelver.finalize)
270
shelver.expect('Shelve adding file "bar"? [yNfq?]', 'y')
271
shelver.expect('Shelve 1 change(s)? [yNfq?]', 'y')
274
def test_shelve_help(self):
275
tree = self.create_shelvable_tree()
276
tree.lock_tree_write()
277
self.addCleanup(tree.unlock)
278
shelver = ExpectShelver(tree, tree.basis_tree())
279
self.addCleanup(shelver.finalize)
280
shelver.expect('Shelve? [yNfq?]', '?')
281
shelver.expect('Shelve? [(y)es, (N)o, (f)inish, or (q)uit]', 'f')
282
shelver.expect('Shelve 2 change(s)? [yNfq?]', 'y')
285
def test_shelve_destroy(self):
286
tree = self.create_shelvable_tree()
287
shelver = shelf_ui.Shelver.from_args(sys.stdout, all=True,
288
directory='tree', destroy=True)
289
self.addCleanup(shelver.finalize)
291
self.assertIs(None, tree.get_shelf_manager().last_shelf())
292
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):
346
def test_shelve_not_diff(self):
347
tree = self.create_shelvable_tree()
348
tree.lock_tree_write()
349
self.addCleanup(tree.unlock)
350
shelver = ExpectShelver(tree, tree.basis_tree(),
351
reporter=shelf_ui.ApplyReporter())
352
self.addCleanup(shelver.finalize)
353
shelver.expect('Apply change? [yNfq?]', 'n')
354
shelver.expect('Apply change? [yNfq?]', 'n')
355
# No final shelving prompt because no changes were selected
357
self.assertFileEqual(LINES_ZY, 'tree/foo')
359
def test_shelve_diff_no(self):
360
tree = self.create_shelvable_tree()
361
tree.lock_tree_write()
362
self.addCleanup(tree.unlock)
363
shelver = ExpectShelver(tree, tree.basis_tree(),
364
reporter=shelf_ui.ApplyReporter())
365
self.addCleanup(shelver.finalize)
366
shelver.expect('Apply change? [yNfq?]', 'y')
367
shelver.expect('Apply change? [yNfq?]', 'y')
368
shelver.expect('Apply 2 change(s)? [yNfq?]', 'n')
370
self.assertFileEqual(LINES_ZY, 'tree/foo')
372
def test_shelve_diff(self):
373
tree = self.create_shelvable_tree()
374
tree.lock_tree_write()
375
self.addCleanup(tree.unlock)
376
shelver = ExpectShelver(tree, tree.basis_tree(),
377
reporter=shelf_ui.ApplyReporter())
378
self.addCleanup(shelver.finalize)
379
shelver.expect('Apply change? [yNfq?]', 'y')
380
shelver.expect('Apply change? [yNfq?]', 'y')
381
shelver.expect('Apply 2 change(s)? [yNfq?]', 'y')
383
self.assertFileEqual(LINES_AJ, 'tree/foo')
385
def test_shelve_binary_change(self):
386
tree = self.create_shelvable_tree()
387
self.build_tree_contents([('tree/foo', '\x00')])
388
tree.lock_tree_write()
389
self.addCleanup(tree.unlock)
390
shelver = ExpectShelver(tree, tree.basis_tree(),
391
reporter=shelf_ui.ApplyReporter())
392
self.addCleanup(shelver.finalize)
393
shelver.expect('Apply binary changes? [yNfq?]', 'y')
394
shelver.expect('Apply 1 change(s)? [yNfq?]', 'y')
396
self.assertFileEqual(LINES_AJ, 'tree/foo')
398
def test_shelve_rename(self):
399
tree = self.create_shelvable_tree()
400
tree.rename_one('foo', 'bar')
401
tree.lock_tree_write()
402
self.addCleanup(tree.unlock)
403
shelver = ExpectShelver(tree, tree.basis_tree(),
404
reporter=shelf_ui.ApplyReporter())
405
self.addCleanup(shelver.finalize)
406
shelver.expect('Rename "bar" => "foo"? [yNfq?]', 'y')
407
shelver.expect('Apply change? [yNfq?]', 'y')
408
shelver.expect('Apply change? [yNfq?]', 'y')
409
shelver.expect('Apply 3 change(s)? [yNfq?]', 'y')
411
self.assertFileEqual(LINES_AJ, 'tree/foo')
413
def test_shelve_deletion(self):
414
tree = self.create_shelvable_tree()
415
os.unlink('tree/foo')
416
tree.lock_tree_write()
417
self.addCleanup(tree.unlock)
418
shelver = ExpectShelver(tree, tree.basis_tree(),
419
reporter=shelf_ui.ApplyReporter())
420
self.addCleanup(shelver.finalize)
421
shelver.expect('Add file "foo"? [yNfq?]', 'y')
422
shelver.expect('Apply 1 change(s)? [yNfq?]', 'y')
424
self.assertFileEqual(LINES_AJ, 'tree/foo')
426
def test_shelve_creation(self):
427
tree = self.make_branch_and_tree('tree')
428
tree.commit('add tree root')
429
self.build_tree(['tree/foo'])
431
tree.lock_tree_write()
432
self.addCleanup(tree.unlock)
433
shelver = ExpectShelver(tree, tree.basis_tree(),
434
reporter=shelf_ui.ApplyReporter())
435
self.addCleanup(shelver.finalize)
436
shelver.expect('Delete file "foo"? [yNfq?]', 'y')
437
shelver.expect('Apply 1 change(s)? [yNfq?]', 'y')
439
self.assertPathDoesNotExist('tree/foo')
441
def test_shelve_kind_change(self):
442
tree = self.create_shelvable_tree()
443
os.unlink('tree/foo')
445
tree.lock_tree_write()
446
self.addCleanup(tree.unlock)
447
shelver = ExpectShelver(tree, tree.basis_tree(),
448
reporter=shelf_ui.ApplyReporter())
449
self.addCleanup(shelver.finalize)
450
shelver.expect('Change "foo" from directory to a file? [yNfq?]', 'y')
451
shelver.expect('Apply 1 change(s)? [yNfq?]', 'y')
453
def test_shelve_modify_target(self):
454
self.requireFeature(features.SymlinkFeature)
455
tree = self.create_shelvable_tree()
456
os.symlink('bar', 'tree/baz')
457
tree.add('baz', 'baz-id')
458
tree.commit("Add symlink")
459
os.unlink('tree/baz')
460
os.symlink('vax', 'tree/baz')
461
tree.lock_tree_write()
462
self.addCleanup(tree.unlock)
463
shelver = ExpectShelver(tree, tree.basis_tree(),
464
reporter=shelf_ui.ApplyReporter())
465
self.addCleanup(shelver.finalize)
466
shelver.expect('Change target of "baz" from "vax" to "bar"? [yNfq?]',
468
shelver.expect('Apply 1 change(s)? [yNfq?]', 'y')
470
self.assertEqual('bar', os.readlink('tree/baz'))
190
shelver.expect('Shelve adding file "bar"? [yNfq]', 'y')
191
shelver.expect('Shelve 1 change(s)? [yNfq]', 'y')
473
195
class TestUnshelver(tests.TestCaseWithTransport):
475
197
def create_tree_with_shelf(self):
476
198
tree = self.make_branch_and_tree('tree')
479
self.build_tree_contents([('tree/foo', LINES_AJ)])
480
tree.add('foo', 'foo-id')
481
tree.commit('added foo')
482
self.build_tree_contents([('tree/foo', LINES_ZY)])
483
shelver = shelf_ui.Shelver(tree, tree.basis_tree(),
484
auto_apply=True, auto=True)
199
self.build_tree_contents([('tree/foo', LINES_AJ)])
200
tree.add('foo', 'foo-id')
201
tree.commit('added foo')
202
self.build_tree_contents([('tree/foo', LINES_ZY)])
203
shelf_ui.Shelver(tree, tree.basis_tree(), auto_apply=True,
493
207
def test_unshelve(self):