~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/blackbox/test_mv.py

merge bzr.dev.

Show diffs side-by-side

added added

removed removed

Lines of Context:
12
12
#
13
13
# You should have received a copy of the GNU General Public License
14
14
# along with this program; if not, write to the Free Software
15
 
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
16
 
17
17
"""Test for 'bzr mv'"""
18
18
 
24
24
    )
25
25
 
26
26
from bzrlib.tests import (
 
27
    CaseInsensitiveFilesystemFeature,
 
28
    SymlinkFeature,
27
29
    TestCaseWithTransport,
28
 
    TestSkipped,
29
30
    )
30
31
 
31
32
 
65
66
        self.build_tree(['unversioned.txt'])
66
67
        self.run_bzr_error(
67
68
            ["^bzr: ERROR: Could not rename unversioned.txt => elsewhere."
68
 
             " .*unversioned.txt is not versioned$"],
 
69
             " .*unversioned.txt is not versioned\.$"],
69
70
            'mv unversioned.txt elsewhere')
70
71
 
71
72
    def test_mv_nonexisting(self):
72
73
        self.run_bzr_error(
73
74
            ["^bzr: ERROR: Could not rename doesnotexist => somewhereelse."
74
 
             " .*doesnotexist is not versioned$"],
 
75
             " .*doesnotexist is not versioned\.$"],
75
76
            'mv doesnotexist somewhereelse')
76
77
 
77
78
    def test_mv_unqualified(self):
78
79
        self.run_bzr_error(['^bzr: ERROR: missing file argument$'], 'mv')
79
 
        
 
80
 
80
81
    def test_mv_invalid(self):
81
82
        tree = self.make_branch_and_tree('.')
82
83
        self.build_tree(['test.txt', 'sub1/'])
83
84
        tree.add(['test.txt'])
84
85
 
85
86
        self.run_bzr_error(
86
 
            ["^bzr: ERROR: Could not move to sub1: sub1 is not versioned$"],
 
87
            ["^bzr: ERROR: Could not move to sub1: sub1 is not versioned\.$"],
87
88
            'mv test.txt sub1')
88
89
 
89
90
        self.run_bzr_error(
90
91
            ["^bzr: ERROR: Could not move test.txt => .*hello.txt: "
91
 
             "sub1 is not versioned$"],
 
92
             "sub1 is not versioned\.$"],
92
93
            'mv test.txt sub1/hello.txt')
93
 
        
 
94
 
94
95
    def test_mv_dirs(self):
95
96
        tree = self.make_branch_and_tree('.')
96
97
        self.build_tree(['hello.txt', 'sub1/'])
124
125
        os.chdir('..')
125
126
        self.assertMoved('sub1/sub2/hello.txt','sub1/hello.txt')
126
127
 
 
128
    def test_mv_change_case_file(self):
 
129
        # test for bug #77740 (mv unable change filename case on Windows)
 
130
        tree = self.make_branch_and_tree('.')
 
131
        self.build_tree(['test.txt'])
 
132
        tree.add(['test.txt'])
 
133
        self.run_bzr('mv test.txt Test.txt')
 
134
        # we can't use failUnlessExists on case-insensitive filesystem
 
135
        # so try to check shape of the tree
 
136
        shape = sorted(os.listdir(u'.'))
 
137
        self.assertEqual(['.bzr', 'Test.txt'], shape)
 
138
        self.assertInWorkingTree('Test.txt')
 
139
        self.assertNotInWorkingTree('test.txt')
 
140
 
 
141
    def test_mv_change_case_dir(self):
 
142
        tree = self.make_branch_and_tree('.')
 
143
        self.build_tree(['foo/'])
 
144
        tree.add(['foo'])
 
145
        self.run_bzr('mv foo Foo')
 
146
        # we can't use failUnlessExists on case-insensitive filesystem
 
147
        # so try to check shape of the tree
 
148
        shape = sorted(os.listdir(u'.'))
 
149
        self.assertEqual(['.bzr', 'Foo'], shape)
 
150
        self.assertInWorkingTree('Foo')
 
151
        self.assertNotInWorkingTree('foo')
 
152
 
 
153
    def test_mv_change_case_dir_w_files(self):
 
154
        tree = self.make_branch_and_tree('.')
 
155
        self.build_tree(['foo/', 'foo/bar'])
 
156
        tree.add(['foo'])
 
157
        self.run_bzr('mv foo Foo')
 
158
        # we can't use failUnlessExists on case-insensitive filesystem
 
159
        # so try to check shape of the tree
 
160
        shape = sorted(os.listdir(u'.'))
 
161
        self.assertEqual(['.bzr', 'Foo'], shape)
 
162
        self.assertInWorkingTree('Foo')
 
163
        self.assertNotInWorkingTree('foo')
 
164
 
 
165
    def test_mv_file_to_wrong_case_dir(self):
 
166
        self.requireFeature(CaseInsensitiveFilesystemFeature)
 
167
        tree = self.make_branch_and_tree('.')
 
168
        self.build_tree(['foo/', 'bar'])
 
169
        tree.add(['foo', 'bar'])
 
170
        out, err = self.run_bzr('mv bar Foo', retcode=3)
 
171
        self.assertEquals('', out)
 
172
        self.assertEquals(
 
173
            'bzr: ERROR: Could not move to Foo: Foo is not versioned.\n',
 
174
            err)
 
175
 
127
176
    def test_mv_smoke_aliases(self):
128
177
        # just test that aliases for mv exist, if their behaviour is changed in
129
178
        # the future, then extend the tests.
135
184
        self.run_bzr('rename b a')
136
185
 
137
186
    def test_mv_through_symlinks(self):
138
 
        if not osutils.has_symlinks():
139
 
            raise TestSkipped('Symlinks are not supported on this platform')
 
187
        self.requireFeature(SymlinkFeature)
140
188
        tree = self.make_branch_and_tree('.')
141
189
        self.build_tree(['a/', 'a/b'])
142
190
        os.symlink('a', 'c')
177
225
        os.remove('b')
178
226
        osutils.rename('a', 'b')
179
227
        self.run_bzr_error(
180
 
            ["^bzr: ERROR: Could not move a => b. b is already versioned$"],
 
228
            ["^bzr: ERROR: Could not move a => b. b is already versioned\.$"],
181
229
            'mv a b')
182
230
        #check that nothing changed
183
231
        self.failIfExists('a')
213
261
 
214
262
        osutils.rename('a', 'sub/a')
215
263
        self.run_bzr_error(
216
 
            ["^bzr: ERROR: Could not move a => a: sub is not versioned$"],
 
264
            ["^bzr: ERROR: Could not move a => a: sub is not versioned\.$"],
217
265
            'mv a sub/a')
218
266
        self.failIfExists('a')
219
267
        self.failUnlessExists('sub/a')
249
297
 
250
298
        osutils.rename('a1', 'sub/a1')
251
299
        self.run_bzr_error(
252
 
            ["^bzr: ERROR: Could not move to sub. sub is not versioned$"],
 
300
            ["^bzr: ERROR: Could not move to sub. sub is not versioned\.$"],
253
301
            'mv a1 a2 sub')
254
302
        self.failIfExists('a1')
255
303
        self.failUnlessExists('sub/a1')
273
321
        self.build_tree(['a']) #touch a
274
322
        self.run_bzr_error(
275
323
            ["^bzr: ERROR: Could not rename a => b because both files exist."
276
 
             " \(Use --after to update the Bazaar id\)$"],
 
324
             " \(Use --after to tell bzr about a rename that has already"
 
325
             " happened\)$"],
277
326
            'mv a b')
278
327
        self.failUnlessExists('a')
279
328
        self.failUnlessExists('b')
321
370
        self.build_tree(['a2']) #touch a2
322
371
 
323
372
        self.run_bzr_error(
324
 
            ["^bzr: ERROR: Could not rename a1 => sub/a1 because both files exist."
325
 
             " \(Use --after to update the Bazaar id\)$"],
 
373
            ["^bzr: ERROR: Could not rename a1 => sub/a1 because both files"
 
374
             " exist. \(Use --after to tell bzr about a rename that has already"
 
375
             " happened\)$"],
326
376
            'mv a1 a2 sub')
327
377
        self.failUnlessExists('a1')
328
378
        self.failUnlessExists('a2')
357
407
        self.failUnlessExists('sub/a2')
358
408
        self.assertInWorkingTree('sub/a1')
359
409
        self.assertInWorkingTree('sub/a2')
 
410
 
 
411
    def test_mv_already_moved_directory(self):
 
412
        """Use `bzr mv a b` to mark a directory as renamed.
 
413
 
 
414
        https://bugs.launchpad.net/bzr/+bug/107967/
 
415
        """
 
416
        self.build_tree(['a/', 'c/'])
 
417
        tree = self.make_branch_and_tree('.')
 
418
        tree.add(['a', 'c'])
 
419
        osutils.rename('a', 'b')
 
420
        osutils.rename('c', 'd')
 
421
        # mv a b should work just like it does for already renamed files
 
422
        self.run_bzr('mv a b')
 
423
        self.failIfExists('a')
 
424
        self.assertNotInWorkingTree('a')
 
425
        self.failUnlessExists('b')
 
426
        self.assertInWorkingTree('b')
 
427
        # and --after should work, too (technically it's ignored)
 
428
        self.run_bzr('mv --after c d')
 
429
        self.failIfExists('c')
 
430
        self.assertNotInWorkingTree('c')
 
431
        self.failUnlessExists('d')
 
432
        self.assertInWorkingTree('d')
 
433
 
 
434
    def make_abcd_tree(self):
 
435
        tree = self.make_branch_and_tree('tree')
 
436
        self.build_tree(['tree/a', 'tree/c'])
 
437
        tree.add(['a', 'c'])
 
438
        tree.commit('record old names')
 
439
        osutils.rename('tree/a', 'tree/b')
 
440
        osutils.rename('tree/c', 'tree/d')
 
441
        return tree
 
442
 
 
443
    def test_mv_auto(self):
 
444
        self.make_abcd_tree()
 
445
        out, err = self.run_bzr('mv --auto', working_dir='tree')
 
446
        self.assertEqual(out, '')
 
447
        self.assertEqual(err, 'a => b\nc => d\n')
 
448
        tree = workingtree.WorkingTree.open('tree')
 
449
        self.assertIsNot(None, tree.path2id('b'))
 
450
        self.assertIsNot(None, tree.path2id('d'))
 
451
 
 
452
    def test_mv_auto_one_path(self):
 
453
        self.make_abcd_tree()
 
454
        out, err = self.run_bzr('mv --auto tree')
 
455
        self.assertEqual(out, '')
 
456
        self.assertEqual(err, 'a => b\nc => d\n')
 
457
        tree = workingtree.WorkingTree.open('tree')
 
458
        self.assertIsNot(None, tree.path2id('b'))
 
459
        self.assertIsNot(None, tree.path2id('d'))
 
460
 
 
461
    def test_mv_auto_two_paths(self):
 
462
        self.make_abcd_tree()
 
463
        out, err = self.run_bzr('mv --auto tree tree2', retcode=3)
 
464
        self.assertEqual('bzr: ERROR: Only one path may be specified to'
 
465
                         ' --auto.\n', err)
 
466
 
 
467
    def test_mv_auto_dry_run(self):
 
468
        self.make_abcd_tree()
 
469
        out, err = self.run_bzr('mv --auto --dry-run', working_dir='tree')
 
470
        self.assertEqual(out, '')
 
471
        self.assertEqual(err, 'a => b\nc => d\n')
 
472
        tree = workingtree.WorkingTree.open('tree')
 
473
        self.assertIsNot(None, tree.path2id('a'))
 
474
        self.assertIsNot(None, tree.path2id('c'))
 
475
 
 
476
    def test_mv_no_auto_dry_run(self):
 
477
        self.make_abcd_tree()
 
478
        out, err = self.run_bzr('mv c d --dry-run',
 
479
                                working_dir='tree', retcode=3)
 
480
        self.assertEqual('bzr: ERROR: --dry-run requires --auto.\n', err)
 
481
 
 
482
    def test_mv_auto_after(self):
 
483
        self.make_abcd_tree()
 
484
        out, err = self.run_bzr('mv --auto --after', working_dir='tree',
 
485
                                retcode=3)
 
486
        self.assertEqual('bzr: ERROR: --after cannot be specified with'
 
487
                         ' --auto.\n', err)