blob: 7b56081137396680df58c887ffe7919d98f6480c [file] [log] [blame]
Alex Riesen8bf2c692005-11-29 23:10:24 +01001#!/bin/sh
2
Junio C Hamano5be60072007-07-02 22:52:14 -07003test_description='git mv in subdirs'
Alex Riesen8bf2c692005-11-29 23:10:24 +01004. ./test-lib.sh
5
6test_expect_success \
7 'prepare reference tree' \
8 'mkdir path0 path1 &&
Junio C Hamanobfdbee92008-08-08 02:26:28 -07009 cp "$TEST_DIRECTORY"/../COPYING path0/COPYING &&
Junio C Hamano5be60072007-07-02 22:52:14 -070010 git add path0/COPYING &&
Nanako Shiraishid592b312008-09-03 17:59:31 +090011 git commit -m add -a'
Alex Riesen8bf2c692005-11-29 23:10:24 +010012
13test_expect_success \
Josef Weidendorfer90924d52006-03-03 17:23:32 +010014 'moving the file out of subdirectory' \
Junio C Hamano5be60072007-07-02 22:52:14 -070015 'cd path0 && git mv COPYING ../path1/COPYING'
Alex Riesen8bf2c692005-11-29 23:10:24 +010016
17# in path0 currently
18test_expect_success \
19 'commiting the change' \
Nanako Shiraishid592b312008-09-03 17:59:31 +090020 'cd .. && git commit -m move-out -a'
Alex Riesen8bf2c692005-11-29 23:10:24 +010021
22test_expect_success \
23 'checking the commit' \
Junio C Hamano5be60072007-07-02 22:52:14 -070024 'git diff-tree -r -M --name-status HEAD^ HEAD | \
Miklos Vajna90ed6c02008-01-05 05:06:48 +010025 grep "^R100..*path0/COPYING..*path1/COPYING"'
Alex Riesen8bf2c692005-11-29 23:10:24 +010026
Josef Weidendorfer90924d52006-03-03 17:23:32 +010027test_expect_success \
28 'moving the file back into subdirectory' \
Junio C Hamano5be60072007-07-02 22:52:14 -070029 'cd path0 && git mv ../path1/COPYING COPYING'
Josef Weidendorfer90924d52006-03-03 17:23:32 +010030
31# in path0 currently
32test_expect_success \
33 'commiting the change' \
Nanako Shiraishid592b312008-09-03 17:59:31 +090034 'cd .. && git commit -m move-in -a'
Josef Weidendorfer90924d52006-03-03 17:23:32 +010035
36test_expect_success \
37 'checking the commit' \
Junio C Hamano5be60072007-07-02 22:52:14 -070038 'git diff-tree -r -M --name-status HEAD^ HEAD | \
Miklos Vajna90ed6c02008-01-05 05:06:48 +010039 grep "^R100..*path1/COPYING..*path0/COPYING"'
Josef Weidendorfer90924d52006-03-03 17:23:32 +010040
Josef Weidendorferafd22292006-07-26 15:44:08 +020041test_expect_success \
Michael J Gruber37729232009-01-14 18:03:21 +010042 'checking -k on non-existing file' \
43 'git mv -k idontexist path0'
44
45test_expect_success \
46 'checking -k on untracked file' \
47 'touch untracked1 &&
48 git mv -k untracked1 path0 &&
49 test -f untracked1 &&
50 test ! -f path0/untracked1'
51
Michael J Gruberbe172622009-01-14 18:03:22 +010052test_expect_success \
Michael J Gruber37729232009-01-14 18:03:21 +010053 'checking -k on multiple untracked files' \
54 'touch untracked2 &&
55 git mv -k untracked1 untracked2 path0 &&
56 test -f untracked1 &&
57 test -f untracked2 &&
Matthieu Moy720ec6b2009-02-04 10:32:06 +010058 test ! -f path0/untracked1 &&
Michael J Gruber37729232009-01-14 18:03:21 +010059 test ! -f path0/untracked2'
60
Matthieu Moy5aed3c62009-02-04 10:32:08 +010061test_expect_success \
Matthieu Moyc8ba6b12009-02-04 10:32:07 +010062 'checking -f on untracked file with existing target' \
63 'touch path0/untracked1 &&
Elijah Newrena2b1e532010-10-03 14:00:10 -060064 test_must_fail git mv -f untracked1 path0 &&
Matthieu Moyc8ba6b12009-02-04 10:32:07 +010065 test ! -f .git/index.lock &&
66 test -f untracked1 &&
67 test -f path0/untracked1'
68
Michael J Gruber37729232009-01-14 18:03:21 +010069# clean up the mess in case bad things happen
70rm -f idontexist untracked1 untracked2 \
71 path0/idontexist path0/untracked1 path0/untracked2 \
72 .git/index.lock
Matthieu Moyc57f6282013-12-03 09:32:04 +010073rmdir path1
74
75test_expect_success \
76 'moving to absent target with trailing slash' \
77 'test_must_fail git mv path0/COPYING no-such-dir/ &&
78 test_must_fail git mv path0/COPYING no-such-dir// &&
79 git mv path0/ no-such-dir/ &&
80 test_path_is_dir no-such-dir'
81
82test_expect_success \
83 'clean up' \
84 'git reset --hard'
85
86test_expect_success \
87 'moving to existing untracked target with trailing slash' \
88 'mkdir path1 &&
89 git mv path0/ path1/ &&
90 test_path_is_dir path1/path0/'
91
92test_expect_success \
93 'moving to existing tracked target with trailing slash' \
94 'mkdir path2 &&
95 >path2/file && git add path2/file &&
96 git mv path1/path0/ path2/ &&
97 test_path_is_dir path2/path0/'
98
99test_expect_success \
100 'clean up' \
101 'git reset --hard'
Michael J Gruber37729232009-01-14 18:03:21 +0100102
103test_expect_success \
Josef Weidendorferafd22292006-07-26 15:44:08 +0200104 'adding another file' \
Junio C Hamanobfdbee92008-08-08 02:26:28 -0700105 'cp "$TEST_DIRECTORY"/../README path0/README &&
Junio C Hamano5be60072007-07-02 22:52:14 -0700106 git add path0/README &&
Nanako Shiraishid592b312008-09-03 17:59:31 +0900107 git commit -m add2 -a'
Josef Weidendorferafd22292006-07-26 15:44:08 +0200108
109test_expect_success \
110 'moving whole subdirectory' \
Junio C Hamano5be60072007-07-02 22:52:14 -0700111 'git mv path0 path2'
Josef Weidendorferafd22292006-07-26 15:44:08 +0200112
113test_expect_success \
114 'commiting the change' \
Nanako Shiraishid592b312008-09-03 17:59:31 +0900115 'git commit -m dir-move -a'
Josef Weidendorferafd22292006-07-26 15:44:08 +0200116
117test_expect_success \
118 'checking the commit' \
Junio C Hamano5be60072007-07-02 22:52:14 -0700119 'git diff-tree -r -M --name-status HEAD^ HEAD | \
Miklos Vajna90ed6c02008-01-05 05:06:48 +0100120 grep "^R100..*path0/COPYING..*path2/COPYING" &&
Junio C Hamano5be60072007-07-02 22:52:14 -0700121 git diff-tree -r -M --name-status HEAD^ HEAD | \
Miklos Vajna90ed6c02008-01-05 05:06:48 +0100122 grep "^R100..*path0/README..*path2/README"'
Josef Weidendorferafd22292006-07-26 15:44:08 +0200123
Johannes Schindelina1dad602006-07-26 19:41:05 +0200124test_expect_success \
Johannes Schindelin1d6249e2006-08-16 02:20:32 +0200125 'succeed when source is a prefix of destination' \
Junio C Hamano5be60072007-07-02 22:52:14 -0700126 'git mv path2/COPYING path2/COPYING-renamed'
Johannes Schindelin1d6249e2006-08-16 02:20:32 +0200127
128test_expect_success \
Johannes Schindelina1dad602006-07-26 19:41:05 +0200129 'moving whole subdirectory into subdirectory' \
Junio C Hamano5be60072007-07-02 22:52:14 -0700130 'git mv path2 path1'
Johannes Schindelina1dad602006-07-26 19:41:05 +0200131
132test_expect_success \
133 'commiting the change' \
Nanako Shiraishid592b312008-09-03 17:59:31 +0900134 'git commit -m dir-move -a'
Johannes Schindelina1dad602006-07-26 19:41:05 +0200135
136test_expect_success \
137 'checking the commit' \
Junio C Hamano5be60072007-07-02 22:52:14 -0700138 'git diff-tree -r -M --name-status HEAD^ HEAD | \
Miklos Vajna90ed6c02008-01-05 05:06:48 +0100139 grep "^R100..*path2/COPYING..*path1/path2/COPYING" &&
Junio C Hamano5be60072007-07-02 22:52:14 -0700140 git diff-tree -r -M --name-status HEAD^ HEAD | \
Miklos Vajna90ed6c02008-01-05 05:06:48 +0100141 grep "^R100..*path2/README..*path1/path2/README"'
Johannes Schindelina1dad602006-07-26 19:41:05 +0200142
Junio C Hamano41ac4142008-02-01 01:50:53 -0800143test_expect_success \
Johannes Schindelinac64a722006-07-26 19:47:54 +0200144 'do not move directory over existing directory' \
Stephan Beyerd492b312008-07-12 17:47:52 +0200145 'mkdir path0 && mkdir path0/path2 && test_must_fail git mv path2 path0'
Johannes Schindelinac64a722006-07-26 19:47:54 +0200146
Johannes Schindelinc5203bd2006-08-18 12:42:39 +0200147test_expect_success \
148 'move into "."' \
Junio C Hamano5be60072007-07-02 22:52:14 -0700149 'git mv path1/path2/ .'
Johannes Schindelinc5203bd2006-08-18 12:42:39 +0200150
Junio C Hamano4fddf572006-10-01 22:22:07 -0700151test_expect_success "Michael Cassar's test case" '
152 rm -fr .git papers partA &&
Nicolas Pitre5c94f872007-01-12 16:01:46 -0500153 git init &&
Junio C Hamano4fddf572006-10-01 22:22:07 -0700154 mkdir -p papers/unsorted papers/all-papers partA &&
155 echo a > papers/unsorted/Thesis.pdf &&
156 echo b > partA/outline.txt &&
157 echo c > papers/unsorted/_another &&
158 git add papers partA &&
159 T1=`git write-tree` &&
160
161 git mv papers/unsorted/Thesis.pdf papers/all-papers/moo-blah.pdf &&
162
163 T=`git write-tree` &&
Jeff Kinga167ece2015-03-20 06:09:00 -0400164 git ls-tree -r $T | verbose grep partA/outline.txt
Junio C Hamano4fddf572006-10-01 22:22:07 -0700165'
166
Johannes Schindelinaca085e2006-12-03 20:42:47 +0100167rm -fr papers partA path?
168
169test_expect_success "Sergey Vlasov's test case" '
170 rm -fr .git &&
Nicolas Pitre5c94f872007-01-12 16:01:46 -0500171 git init &&
Johannes Schindelinaca085e2006-12-03 20:42:47 +0100172 mkdir ab &&
173 date >ab.c &&
174 date >ab/d &&
175 git add ab.c ab &&
176 git commit -m 'initial' &&
177 git mv ab a
178'
179
Junio C Hamano744dacd2008-02-03 23:59:17 -0800180test_expect_success 'absolute pathname' '(
181
182 rm -fr mine &&
183 mkdir mine &&
184 cd mine &&
185 test_create_repo one &&
186 cd one &&
187 mkdir sub &&
188 >sub/file &&
189 git add sub/file &&
190
191 git mv sub "$(pwd)/in" &&
192 ! test -d sub &&
193 test -d in &&
194 git ls-files --error-unmatch in/file
195
196
197)'
198
199test_expect_success 'absolute pathname outside should fail' '(
200
201 rm -fr mine &&
202 mkdir mine &&
203 cd mine &&
204 out=$(pwd) &&
205 test_create_repo one &&
206 cd one &&
207 mkdir sub &&
208 >sub/file &&
209 git add sub/file &&
210
Stephan Beyerd492b312008-07-12 17:47:52 +0200211 test_must_fail git mv sub "$out/out" &&
Junio C Hamano744dacd2008-02-03 23:59:17 -0800212 test -d sub &&
213 ! test -d ../in &&
214 git ls-files --error-unmatch sub/file
215
216)'
217
Junio C Hamanoaf825592010-01-22 14:17:06 -0800218test_expect_success 'git mv to move multiple sources into a directory' '
219 rm -fr .git && git init &&
220 mkdir dir other &&
221 >dir/a.txt &&
222 >dir/b.txt &&
223 git add dir/?.txt &&
224 git mv dir/a.txt dir/b.txt other &&
225 git ls-files >actual &&
226 { echo other/a.txt; echo other/b.txt; } >expect &&
227 test_cmp expect actual
228'
229
Petr Baudis81dc2302008-07-21 02:25:56 +0200230test_expect_success 'git mv should not change sha1 of moved cache entry' '
231
232 rm -fr .git &&
233 git init &&
234 echo 1 >dirty &&
235 git add dirty &&
Jonathan Nieder2dec68c2010-10-31 02:30:58 -0500236 entry="$(git ls-files --stage dirty | cut -f 1)" &&
Petr Baudis81dc2302008-07-21 02:25:56 +0200237 git mv dirty dirty2 &&
238 [ "$entry" = "$(git ls-files --stage dirty2 | cut -f 1)" ] &&
239 echo 2 >dirty2 &&
240 git mv dirty2 dirty &&
241 [ "$entry" = "$(git ls-files --stage dirty | cut -f 1)" ]
242
243'
244
245rm -f dirty dirty2
246
Johannes Sixt889c6f02013-06-07 22:53:28 +0200247test_expect_success 'git mv should overwrite symlink to a file' '
Petr Baudis81dc2302008-07-21 02:25:56 +0200248
249 rm -fr .git &&
250 git init &&
251 echo 1 >moved &&
Johannes Sixt889c6f02013-06-07 22:53:28 +0200252 test_ln_s_add moved symlink &&
253 git add moved &&
Petr Baudis81dc2302008-07-21 02:25:56 +0200254 test_must_fail git mv moved symlink &&
255 git mv -f moved symlink &&
256 ! test -e moved &&
257 test -f symlink &&
258 test "$(cat symlink)" = 1 &&
Junio C Hamano65c35b22008-07-28 22:27:39 -0700259 git update-index --refresh &&
Petr Baudis81dc2302008-07-21 02:25:56 +0200260 git diff-files --quiet
261
262'
263
264rm -f moved symlink
265
Johannes Sixt889c6f02013-06-07 22:53:28 +0200266test_expect_success 'git mv should overwrite file with a symlink' '
Petr Baudis81dc2302008-07-21 02:25:56 +0200267
268 rm -fr .git &&
269 git init &&
270 echo 1 >moved &&
Johannes Sixt889c6f02013-06-07 22:53:28 +0200271 test_ln_s_add moved symlink &&
272 git add moved &&
Petr Baudis81dc2302008-07-21 02:25:56 +0200273 test_must_fail git mv symlink moved &&
274 git mv -f symlink moved &&
275 ! test -e symlink &&
Junio C Hamano65c35b22008-07-28 22:27:39 -0700276 git update-index --refresh &&
Petr Baudis81dc2302008-07-21 02:25:56 +0200277 git diff-files --quiet
278
279'
280
Johannes Sixt889c6f02013-06-07 22:53:28 +0200281test_expect_success SYMLINKS 'check moved symlink' '
282
283 test -h moved
284'
285
Petr Baudis81dc2302008-07-21 02:25:56 +0200286rm -f moved symlink
287
Jens Lehmann11502462013-07-30 21:49:25 +0200288test_expect_success 'setup submodule' '
289 git commit -m initial &&
290 git reset --hard &&
291 git submodule add ./. sub &&
292 echo content >file &&
293 git add file &&
brian m. carlsonfb8a4e82014-03-15 18:56:52 +0000294 git commit -m "added sub and file" &&
295 git branch submodule
Jens Lehmann11502462013-07-30 21:49:25 +0200296'
297
298test_expect_success 'git mv cannot move a submodule in a file' '
299 test_must_fail git mv sub file
300'
301
302test_expect_success 'git mv moves a submodule with a .git directory and no .gitmodules' '
303 entry="$(git ls-files --stage sub | cut -f 1)" &&
304 git rm .gitmodules &&
305 (
306 cd sub &&
307 rm -f .git &&
Kyle J. McKay00764ca2014-04-11 01:24:02 -0700308 cp -R -P -p ../.git/modules/sub .git &&
Jens Lehmann11502462013-07-30 21:49:25 +0200309 GIT_WORK_TREE=. git config --unset core.worktree
310 ) &&
311 mkdir mod &&
312 git mv sub mod/sub &&
313 ! test -e sub &&
314 [ "$entry" = "$(git ls-files --stage mod/sub | cut -f 1)" ] &&
315 (
316 cd mod/sub &&
317 git status
318 ) &&
319 git update-index --refresh &&
320 git diff-files --quiet
321'
322
Jens Lehmann04c1ee52013-10-13 13:52:05 +0200323test_expect_success 'git mv moves a submodule with a .git directory and .gitmodules' '
324 rm -rf mod &&
325 git reset --hard &&
326 git submodule update &&
327 entry="$(git ls-files --stage sub | cut -f 1)" &&
328 (
329 cd sub &&
330 rm -f .git &&
Kyle J. McKay00764ca2014-04-11 01:24:02 -0700331 cp -R -P -p ../.git/modules/sub .git &&
Jens Lehmann04c1ee52013-10-13 13:52:05 +0200332 GIT_WORK_TREE=. git config --unset core.worktree
333 ) &&
334 mkdir mod &&
335 git mv sub mod/sub &&
336 ! test -e sub &&
337 [ "$entry" = "$(git ls-files --stage mod/sub | cut -f 1)" ] &&
338 (
339 cd mod/sub &&
340 git status
341 ) &&
342 echo mod/sub >expected &&
343 git config -f .gitmodules submodule.sub.path >actual &&
344 test_cmp expected actual &&
345 git update-index --refresh &&
346 git diff-files --quiet
347'
348
Jens Lehmanna88c9152013-07-30 21:50:03 +0200349test_expect_success 'git mv moves a submodule with gitfile' '
Jonathan Nieder2b2b1e42014-09-10 14:01:46 -0700350 rm -rf mod &&
Jens Lehmanna88c9152013-07-30 21:50:03 +0200351 git reset --hard &&
352 git submodule update &&
353 entry="$(git ls-files --stage sub | cut -f 1)" &&
Jonathan Nieder2b2b1e42014-09-10 14:01:46 -0700354 mkdir mod &&
Jens Lehmanna88c9152013-07-30 21:50:03 +0200355 (
356 cd mod &&
357 git mv ../sub/ .
358 ) &&
359 ! test -e sub &&
360 [ "$entry" = "$(git ls-files --stage mod/sub | cut -f 1)" ] &&
361 (
362 cd mod/sub &&
363 git status
364 ) &&
Jens Lehmann06567812013-08-06 21:15:11 +0200365 echo mod/sub >expected &&
366 git config -f .gitmodules submodule.sub.path >actual &&
367 test_cmp expected actual &&
Jens Lehmanna88c9152013-07-30 21:50:03 +0200368 git update-index --refresh &&
369 git diff-files --quiet
370'
371
Jens Lehmann06567812013-08-06 21:15:11 +0200372test_expect_success 'mv does not complain when no .gitmodules file is found' '
Jonathan Nieder2b2b1e42014-09-10 14:01:46 -0700373 rm -rf mod &&
Jens Lehmann06567812013-08-06 21:15:11 +0200374 git reset --hard &&
375 git submodule update &&
376 git rm .gitmodules &&
377 entry="$(git ls-files --stage sub | cut -f 1)" &&
Jonathan Nieder2b2b1e42014-09-10 14:01:46 -0700378 mkdir mod &&
Jens Lehmann06567812013-08-06 21:15:11 +0200379 git mv sub mod/sub 2>actual.err &&
380 ! test -s actual.err &&
381 ! test -e sub &&
382 [ "$entry" = "$(git ls-files --stage mod/sub | cut -f 1)" ] &&
383 (
384 cd mod/sub &&
385 git status
386 ) &&
387 git update-index --refresh &&
388 git diff-files --quiet
389'
390
391test_expect_success 'mv will error out on a modified .gitmodules file unless staged' '
Jonathan Nieder2b2b1e42014-09-10 14:01:46 -0700392 rm -rf mod &&
Jens Lehmann06567812013-08-06 21:15:11 +0200393 git reset --hard &&
394 git submodule update &&
395 git config -f .gitmodules foo.bar true &&
396 entry="$(git ls-files --stage sub | cut -f 1)" &&
Jonathan Nieder2b2b1e42014-09-10 14:01:46 -0700397 mkdir mod &&
Jens Lehmann06567812013-08-06 21:15:11 +0200398 test_must_fail git mv sub mod/sub 2>actual.err &&
399 test -s actual.err &&
400 test -e sub &&
401 git diff-files --quiet -- sub &&
402 git add .gitmodules &&
403 git mv sub mod/sub 2>actual.err &&
404 ! test -s actual.err &&
405 ! test -e sub &&
406 [ "$entry" = "$(git ls-files --stage mod/sub | cut -f 1)" ] &&
407 (
408 cd mod/sub &&
409 git status
410 ) &&
411 git update-index --refresh &&
412 git diff-files --quiet
413'
414
415test_expect_success 'mv issues a warning when section is not found in .gitmodules' '
Jonathan Nieder2b2b1e42014-09-10 14:01:46 -0700416 rm -rf mod &&
Jens Lehmann06567812013-08-06 21:15:11 +0200417 git reset --hard &&
418 git submodule update &&
419 git config -f .gitmodules --remove-section submodule.sub &&
420 git add .gitmodules &&
421 entry="$(git ls-files --stage sub | cut -f 1)" &&
422 echo "warning: Could not find section in .gitmodules where path=sub" >expect.err &&
Jonathan Nieder2b2b1e42014-09-10 14:01:46 -0700423 mkdir mod &&
Jens Lehmann06567812013-08-06 21:15:11 +0200424 git mv sub mod/sub 2>actual.err &&
425 test_i18ncmp expect.err actual.err &&
426 ! test -e sub &&
427 [ "$entry" = "$(git ls-files --stage mod/sub | cut -f 1)" ] &&
428 (
429 cd mod/sub &&
430 git status
431 ) &&
432 git update-index --refresh &&
433 git diff-files --quiet
434'
435
436test_expect_success 'mv --dry-run does not touch the submodule or .gitmodules' '
Jonathan Nieder2b2b1e42014-09-10 14:01:46 -0700437 rm -rf mod &&
Jens Lehmann06567812013-08-06 21:15:11 +0200438 git reset --hard &&
439 git submodule update &&
Jonathan Nieder2b2b1e42014-09-10 14:01:46 -0700440 mkdir mod &&
Jens Lehmann06567812013-08-06 21:15:11 +0200441 git mv -n sub mod/sub 2>actual.err &&
442 test -f sub/.git &&
443 git diff-index --exit-code HEAD &&
444 git update-index --refresh &&
445 git diff-files --quiet -- sub .gitmodules
446'
447
Jens Lehmann1cbd1832014-01-07 22:31:32 +0100448test_expect_success 'checking out a commit before submodule moved needs manual updates' '
449 git mv sub sub2 &&
450 git commit -m "moved sub to sub2" &&
451 git checkout -q HEAD^ 2>actual &&
Charles Bailey11b53902014-03-29 15:39:01 +0000452 test_i18ngrep "^warning: unable to rmdir sub2:" actual &&
Jens Lehmann1cbd1832014-01-07 22:31:32 +0100453 git status -s sub2 >actual &&
454 echo "?? sub2/" >expected &&
455 test_cmp expected actual &&
456 ! test -f sub/.git &&
457 test -f sub2/.git &&
458 git submodule update &&
459 test -f sub/.git &&
460 rm -rf sub2 &&
461 git diff-index --exit-code HEAD &&
462 git update-index --refresh &&
463 git diff-files --quiet -- sub .gitmodules &&
464 git status -s sub2 >actual &&
465 ! test -s actual
466'
467
brian m. carlsonfb8a4e82014-03-15 18:56:52 +0000468test_expect_success 'mv -k does not accidentally destroy submodules' '
469 git checkout submodule &&
470 mkdir dummy dest &&
471 git mv -k dummy sub dest &&
472 git status --porcelain >actual &&
473 grep "^R sub -> dest/sub" actual &&
474 git reset --hard &&
475 git checkout .
476'
477
Alex Riesen8bf2c692005-11-29 23:10:24 +0100478test_done