45
45
files = self.build_tree(['a', 'c', 'subdir/'])
46
46
tree.add(['a', 'c', 'subdir'])
48
self.run_bzr('mv', 'a', 'b')
48
self.run_bzr('mv a b')
49
49
self.assertMoved('a','b')
51
self.run_bzr('mv', 'b', 'subdir')
51
self.run_bzr('mv b subdir')
52
52
self.assertMoved('b','subdir/b')
54
self.run_bzr('mv', 'subdir/b', 'a')
54
self.run_bzr('mv subdir/b a')
55
55
self.assertMoved('subdir/b','a')
57
self.run_bzr('mv', 'a', 'c', 'subdir')
57
self.run_bzr('mv a c subdir')
58
58
self.assertMoved('a','subdir/a')
59
59
self.assertMoved('c','subdir/c')
61
self.run_bzr('mv', 'subdir/a', 'subdir/newa')
61
self.run_bzr('mv subdir/a subdir/newa')
62
62
self.assertMoved('subdir/a','subdir/newa')
64
64
def test_mv_unversioned(self):
66
66
self.run_bzr_error(
67
67
["^bzr: ERROR: Could not rename unversioned.txt => elsewhere."
68
68
" .*unversioned.txt is not versioned$"],
69
'mv', 'unversioned.txt', 'elsewhere')
69
'mv unversioned.txt elsewhere')
71
71
def test_mv_nonexisting(self):
72
72
self.run_bzr_error(
73
73
["^bzr: ERROR: Could not rename doesnotexist => somewhereelse."
74
74
" .*doesnotexist is not versioned$"],
75
'mv', 'doesnotexist', 'somewhereelse')
75
'mv doesnotexist somewhereelse')
77
77
def test_mv_unqualified(self):
78
78
self.run_bzr_error(['^bzr: ERROR: missing file argument$'], 'mv')
85
85
self.run_bzr_error(
86
86
["^bzr: ERROR: Could not move to sub1: sub1 is not versioned$"],
87
'mv', 'test.txt', 'sub1')
89
89
self.run_bzr_error(
90
90
["^bzr: ERROR: Could not move test.txt => .*hello.txt: "
91
91
"sub1 is not versioned$"],
92
'mv', 'test.txt', 'sub1/hello.txt')
92
'mv test.txt sub1/hello.txt')
94
94
def test_mv_dirs(self):
95
95
tree = self.make_branch_and_tree('.')
96
96
self.build_tree(['hello.txt', 'sub1/'])
97
97
tree.add(['hello.txt', 'sub1'])
99
self.run_bzr('mv', 'sub1', 'sub2')
99
self.run_bzr('mv sub1 sub2')
100
100
self.assertMoved('sub1','sub2')
102
self.run_bzr('mv', 'hello.txt', 'sub2')
102
self.run_bzr('mv hello.txt sub2')
103
103
self.assertMoved('hello.txt','sub2/hello.txt')
105
105
self.build_tree(['sub1/'])
106
106
tree.add(['sub1'])
107
self.run_bzr('mv', 'sub2/hello.txt', 'sub1')
107
self.run_bzr('mv sub2/hello.txt sub1')
108
108
self.assertMoved('sub2/hello.txt','sub1/hello.txt')
110
self.run_bzr('mv', 'sub2', 'sub1')
110
self.run_bzr('mv sub2 sub1')
111
111
self.assertMoved('sub2','sub1/sub2')
113
113
def test_mv_relative(self):
116
116
tree.add(['sub1', 'sub1/sub2', 'sub1/hello.txt'])
118
118
os.chdir('sub1/sub2')
119
self.run_bzr('mv', '../hello.txt', '.')
119
self.run_bzr('mv ../hello.txt .')
120
120
self.failUnlessExists('./hello.txt')
123
self.run_bzr('mv', 'sub2/hello.txt', '.')
123
self.run_bzr('mv sub2/hello.txt .')
125
125
self.assertMoved('sub1/sub2/hello.txt','sub1/hello.txt')
131
131
tree = self.make_branch_and_tree('.')
134
self.run_bzr('move', 'a', 'b')
135
self.run_bzr('rename', 'b', 'a')
134
self.run_bzr('move a b')
135
self.run_bzr('rename b a')
137
137
def test_mv_through_symlinks(self):
138
138
if not osutils.has_symlinks():
142
142
os.symlink('a', 'c')
143
143
os.symlink('.', 'd')
144
144
tree.add(['a', 'a/b', 'c'], ['a-id', 'b-id', 'c-id'])
145
self.run_bzr('mv', 'c/b', 'b')
145
self.run_bzr('mv c/b b')
146
146
tree = workingtree.WorkingTree.open('.')
147
147
self.assertEqual('b-id', tree.path2id('b'))
161
161
osutils.rename('a', 'b')
162
self.run_bzr('mv', 'a', 'b')
162
self.run_bzr('mv a b')
163
163
self.assertMoved('a','b')
165
165
def test_mv_already_moved_file_to_versioned_target(self):
196
196
tree.add(['a', 'sub'])
198
198
osutils.rename('a', 'sub/a')
199
self.run_bzr('mv', 'a', 'sub/a')
199
self.run_bzr('mv a sub/a')
200
200
self.assertMoved('a','sub/a')
202
202
def test_mv_already_moved_file_into_unversioned_subdir(self):
231
231
tree.add(['a1', 'a2', 'sub'])
233
233
osutils.rename('a1', 'sub/a1')
234
self.run_bzr('mv', 'a1', 'a2', 'sub')
234
self.run_bzr('mv a1 a2 sub')
235
235
self.assertMoved('a1','sub/a1')
236
236
self.assertMoved('a2','sub/a2')
250
250
osutils.rename('a1', 'sub/a1')
251
251
self.run_bzr_error(
252
252
["^bzr: ERROR: Could not move to sub. sub is not versioned$"],
253
'mv', 'a1', 'a2', 'sub')
254
254
self.failIfExists('a1')
255
255
self.failUnlessExists('sub/a1')
256
256
self.failUnlessExists('a2')
274
274
self.run_bzr_error(
275
275
["^bzr: ERROR: Could not rename a => b because both files exist."
276
276
" \(Use --after to update the Bazaar id\)$"],
278
278
self.failUnlessExists('a')
279
279
self.failUnlessExists('b')
295
295
osutils.rename('a', 'b')
296
296
self.build_tree(['a']) #touch a
298
self.run_bzr('mv', 'a', 'b', '--after')
298
self.run_bzr('mv a b --after')
299
299
self.failUnlessExists('a')
300
300
self.assertNotInWorkingTree('a')#a should be unknown now.
301
301
self.failUnlessExists('b')
323
323
self.run_bzr_error(
324
324
["^bzr: ERROR: Could not rename a1 => sub/a1 because both files exist."
325
325
" \(Use --after to update the Bazaar id\)$"],
326
'mv', 'a1', 'a2', 'sub')
327
327
self.failUnlessExists('a1')
328
328
self.failUnlessExists('a2')
329
329
self.failUnlessExists('sub/a1')
350
350
self.build_tree(['a1']) #touch a1
351
351
self.build_tree(['a2']) #touch a2
353
self.run_bzr('mv', 'a1', 'a2', 'sub', '--after')
353
self.run_bzr('mv a1 a2 sub --after')
354
354
self.failUnlessExists('a1')
355
355
self.failUnlessExists('a2')
356
356
self.failUnlessExists('sub/a1')