115
120
tree = self.make_branch_and_tree('.')
116
121
tree.add(['sub1', 'sub1/sub2', 'sub1/hello.txt'])
118
os.chdir('sub1/sub2')
119
self.run_bzr('mv ../hello.txt .')
120
self.failUnlessExists('./hello.txt')
123
self.run_bzr('mv ../hello.txt .', working_dir='sub1/sub2')
124
self.assertPathExists('sub1/sub2/hello.txt')
123
self.run_bzr('mv sub2/hello.txt .')
126
self.run_bzr('mv sub2/hello.txt .', working_dir='sub1')
125
127
self.assertMoved('sub1/sub2/hello.txt','sub1/hello.txt')
129
def test_mv_change_case_file(self):
130
# test for bug #77740 (mv unable change filename case on Windows)
131
tree = self.make_branch_and_tree('.')
132
self.build_tree(['test.txt'])
133
tree.add(['test.txt'])
134
self.run_bzr('mv test.txt Test.txt')
135
# we can't use failUnlessExists on case-insensitive filesystem
136
# so try to check shape of the tree
137
shape = sorted(os.listdir(u'.'))
138
self.assertEqual(['.bzr', 'Test.txt'], shape)
139
self.assertInWorkingTree('Test.txt')
140
self.assertNotInWorkingTree('test.txt')
142
def test_mv_change_case_dir(self):
143
tree = self.make_branch_and_tree('.')
144
self.build_tree(['foo/'])
146
self.run_bzr('mv foo Foo')
147
# we can't use failUnlessExists on case-insensitive filesystem
148
# so try to check shape of the tree
149
shape = sorted(os.listdir(u'.'))
150
self.assertEqual(['.bzr', 'Foo'], shape)
151
self.assertInWorkingTree('Foo')
152
self.assertNotInWorkingTree('foo')
154
def test_mv_change_case_dir_w_files(self):
155
tree = self.make_branch_and_tree('.')
156
self.build_tree(['foo/', 'foo/bar'])
158
self.run_bzr('mv foo Foo')
159
# we can't use failUnlessExists on case-insensitive filesystem
160
# so try to check shape of the tree
161
shape = sorted(os.listdir(u'.'))
162
self.assertEqual(['.bzr', 'Foo'], shape)
163
self.assertInWorkingTree('Foo')
164
self.assertNotInWorkingTree('foo')
166
def test_mv_file_to_wrong_case_dir(self):
167
self.requireFeature(CaseInsensitiveFilesystemFeature)
168
tree = self.make_branch_and_tree('.')
169
self.build_tree(['foo/', 'bar'])
170
tree.add(['foo', 'bar'])
171
out, err = self.run_bzr('mv bar Foo', retcode=3)
172
self.assertEquals('', out)
174
'bzr: ERROR: Could not move to Foo: Foo is not versioned.\n',
127
177
def test_mv_smoke_aliases(self):
128
178
# just test that aliases for mv exist, if their behaviour is changed in
129
179
# the future, then extend the tests.
351
408
self.build_tree(['a2']) #touch a2
353
410
self.run_bzr('mv a1 a2 sub --after')
354
self.failUnlessExists('a1')
355
self.failUnlessExists('a2')
356
self.failUnlessExists('sub/a1')
357
self.failUnlessExists('sub/a2')
411
self.assertPathExists('a1')
412
self.assertPathExists('a2')
413
self.assertPathExists('sub/a1')
414
self.assertPathExists('sub/a2')
358
415
self.assertInWorkingTree('sub/a1')
359
416
self.assertInWorkingTree('sub/a2')
418
def test_mv_already_moved_directory(self):
419
"""Use `bzr mv a b` to mark a directory as renamed.
421
https://bugs.launchpad.net/bzr/+bug/107967/
423
self.build_tree(['a/', 'c/'])
424
tree = self.make_branch_and_tree('.')
426
osutils.rename('a', 'b')
427
osutils.rename('c', 'd')
428
# mv a b should work just like it does for already renamed files
429
self.run_bzr('mv a b')
430
self.assertPathDoesNotExist('a')
431
self.assertNotInWorkingTree('a')
432
self.assertPathExists('b')
433
self.assertInWorkingTree('b')
434
# and --after should work, too (technically it's ignored)
435
self.run_bzr('mv --after c d')
436
self.assertPathDoesNotExist('c')
437
self.assertNotInWorkingTree('c')
438
self.assertPathExists('d')
439
self.assertInWorkingTree('d')
441
def make_abcd_tree(self):
442
tree = self.make_branch_and_tree('tree')
443
self.build_tree(['tree/a', 'tree/c'])
445
tree.commit('record old names')
446
osutils.rename('tree/a', 'tree/b')
447
osutils.rename('tree/c', 'tree/d')
450
def test_mv_auto(self):
451
self.make_abcd_tree()
452
out, err = self.run_bzr('mv --auto', working_dir='tree')
453
self.assertEqual(out, '')
454
self.assertEqual(err, 'a => b\nc => d\n')
455
tree = workingtree.WorkingTree.open('tree')
456
self.assertIsNot(None, tree.path2id('b'))
457
self.assertIsNot(None, tree.path2id('d'))
459
def test_mv_auto_one_path(self):
460
self.make_abcd_tree()
461
out, err = self.run_bzr('mv --auto tree')
462
self.assertEqual(out, '')
463
self.assertEqual(err, 'a => b\nc => d\n')
464
tree = workingtree.WorkingTree.open('tree')
465
self.assertIsNot(None, tree.path2id('b'))
466
self.assertIsNot(None, tree.path2id('d'))
468
def test_mv_auto_two_paths(self):
469
self.make_abcd_tree()
470
out, err = self.run_bzr('mv --auto tree tree2', retcode=3)
471
self.assertEqual('bzr: ERROR: Only one path may be specified to'
474
def test_mv_auto_dry_run(self):
475
self.make_abcd_tree()
476
out, err = self.run_bzr('mv --auto --dry-run', working_dir='tree')
477
self.assertEqual(out, '')
478
self.assertEqual(err, 'a => b\nc => d\n')
479
tree = workingtree.WorkingTree.open('tree')
480
self.assertIsNot(None, tree.path2id('a'))
481
self.assertIsNot(None, tree.path2id('c'))
483
def test_mv_no_auto_dry_run(self):
484
self.make_abcd_tree()
485
out, err = self.run_bzr('mv c d --dry-run',
486
working_dir='tree', retcode=3)
487
self.assertEqual('bzr: ERROR: --dry-run requires --auto.\n', err)
489
def test_mv_auto_after(self):
490
self.make_abcd_tree()
491
out, err = self.run_bzr('mv --auto --after', working_dir='tree',
493
self.assertEqual('bzr: ERROR: --after cannot be specified with'
496
def test_mv_quiet(self):
497
tree = self.make_branch_and_tree('.')
498
self.build_tree(['aaa'])
500
out, err = self.run_bzr('mv --quiet aaa bbb')
501
self.assertEqual(out, '')
502
self.assertEqual(err, '')
504
def test_mv_readonly_lightweight_checkout(self):
505
branch = self.make_branch('foo')
506
branch = bzrlib.branch.Branch.open(self.get_readonly_url('foo'))
507
tree = branch.create_checkout('tree', lightweight=True)
508
self.build_tree(['tree/path'])
510
# If this fails, the tree is trying to acquire a branch lock, which it
512
self.run_bzr(['mv', 'tree/path', 'tree/path2'])
514
def test_mv_unversioned_non_ascii(self):
515
"""Clear error on mv of an unversioned non-ascii file, see lp:707954"""
516
self.requireFeature(UnicodeFilenameFeature)
517
tree = self.make_branch_and_tree(".")
518
self.build_tree([u"\xA7"])
519
out, err = self.run_bzr_error(["Could not rename", "not versioned"],
520
["mv", u"\xA7", "b"])
522
def test_mv_removed_non_ascii(self):
523
"""Clear error on mv of a removed non-ascii file, see lp:898541"""
524
self.requireFeature(UnicodeFilenameFeature)
525
tree = self.make_branch_and_tree(".")
526
self.build_tree([u"\xA7"])
528
tree.commit(u"Adding \xA7")
530
out, err = self.run_bzr_error(["Could not rename", "not exist"],
531
["mv", u"\xA7", "b"])