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