]> git.ipfire.org Git - thirdparty/git.git/blob - t/t2403-worktree-move.sh
The seventh batch
[thirdparty/git.git] / t / t2403-worktree-move.sh
1 #!/bin/sh
2
3 test_description='test git worktree move, remove, lock and unlock'
4
5 TEST_PASSES_SANITIZE_LEAK=true
6 . ./test-lib.sh
7
8 test_expect_success 'setup' '
9 test_commit init &&
10 git worktree add source &&
11 git worktree list --porcelain >out &&
12 grep "^worktree" out >actual &&
13 cat <<-EOF >expected &&
14 worktree $(pwd)
15 worktree $(pwd)/source
16 EOF
17 test_cmp expected actual
18 '
19
20 test_expect_success 'lock main worktree' '
21 test_must_fail git worktree lock .
22 '
23
24 test_expect_success 'lock linked worktree' '
25 git worktree lock --reason hahaha source &&
26 echo hahaha >expected &&
27 test_cmp expected .git/worktrees/source/locked
28 '
29
30 test_expect_success 'lock linked worktree from another worktree' '
31 rm .git/worktrees/source/locked &&
32 git worktree add elsewhere &&
33 git -C elsewhere worktree lock --reason hahaha ../source &&
34 echo hahaha >expected &&
35 test_cmp expected .git/worktrees/source/locked
36 '
37
38 test_expect_success 'lock worktree twice' '
39 test_must_fail git worktree lock source &&
40 echo hahaha >expected &&
41 test_cmp expected .git/worktrees/source/locked
42 '
43
44 test_expect_success 'lock worktree twice (from the locked worktree)' '
45 test_must_fail git -C source worktree lock . &&
46 echo hahaha >expected &&
47 test_cmp expected .git/worktrees/source/locked
48 '
49
50 test_expect_success 'unlock main worktree' '
51 test_must_fail git worktree unlock .
52 '
53
54 test_expect_success 'unlock linked worktree' '
55 git worktree unlock source &&
56 test_path_is_missing .git/worktrees/source/locked
57 '
58
59 test_expect_success 'unlock worktree twice' '
60 test_must_fail git worktree unlock source &&
61 test_path_is_missing .git/worktrees/source/locked
62 '
63
64 test_expect_success 'move non-worktree' '
65 mkdir abc &&
66 test_must_fail git worktree move abc def
67 '
68
69 test_expect_success 'move locked worktree' '
70 git worktree lock source &&
71 test_when_finished "git worktree unlock source" &&
72 test_must_fail git worktree move source destination
73 '
74
75 test_expect_success 'move worktree' '
76 git worktree move source destination &&
77 test_path_is_missing source &&
78 git worktree list --porcelain >out &&
79 grep "^worktree.*/destination$" out &&
80 ! grep "^worktree.*/source$" out &&
81 git -C destination log --format=%s >actual2 &&
82 echo init >expected2 &&
83 test_cmp expected2 actual2
84 '
85
86 test_expect_success 'move main worktree' '
87 test_must_fail git worktree move . def
88 '
89
90 test_expect_success 'move worktree to another dir' '
91 mkdir some-dir &&
92 git worktree move destination some-dir &&
93 test_when_finished "git worktree move some-dir/destination destination" &&
94 test_path_is_missing destination &&
95 git worktree list --porcelain >out &&
96 grep "^worktree.*/some-dir/destination$" out &&
97 git -C some-dir/destination log --format=%s >actual2 &&
98 echo init >expected2 &&
99 test_cmp expected2 actual2
100 '
101
102 test_expect_success 'move locked worktree (force)' '
103 test_when_finished "
104 git worktree unlock flump || :
105 git worktree remove flump || :
106 git worktree unlock ploof || :
107 git worktree remove ploof || :
108 " &&
109 git worktree add --detach flump &&
110 git worktree lock flump &&
111 test_must_fail git worktree move flump ploof" &&
112 test_must_fail git worktree move --force flump ploof" &&
113 git worktree move --force --force flump ploof
114 '
115
116 test_expect_success 'refuse to move worktree atop existing path' '
117 >bobble &&
118 git worktree add --detach beeble &&
119 test_must_fail git worktree move beeble bobble
120 '
121
122 test_expect_success 'move atop existing but missing worktree' '
123 git worktree add --detach gnoo &&
124 git worktree add --detach pneu &&
125 rm -fr pneu &&
126 test_must_fail git worktree move gnoo pneu &&
127 git worktree move --force gnoo pneu &&
128
129 git worktree add --detach nu &&
130 git worktree lock nu &&
131 rm -fr nu &&
132 test_must_fail git worktree move pneu nu &&
133 test_must_fail git worktree --force move pneu nu &&
134 git worktree move --force --force pneu nu
135 '
136
137 test_expect_success 'move a repo with uninitialized submodule' '
138 git init withsub &&
139 (
140 cd withsub &&
141 test_commit initial &&
142 git -c protocol.file.allow=always \
143 submodule add "$PWD"/.git sub &&
144 git commit -m withsub &&
145 git worktree add second HEAD &&
146 git worktree move second third
147 )
148 '
149
150 test_expect_success 'not move a repo with initialized submodule' '
151 (
152 cd withsub &&
153 git -c protocol.file.allow=always -C third submodule update &&
154 test_must_fail git worktree move third forth
155 )
156 '
157
158 test_expect_success 'remove main worktree' '
159 test_must_fail git worktree remove .
160 '
161
162 test_expect_success 'remove locked worktree' '
163 git worktree lock destination &&
164 test_when_finished "git worktree unlock destination" &&
165 test_must_fail git worktree remove destination
166 '
167
168 test_expect_success 'remove worktree with dirty tracked file' '
169 echo dirty >>destination/init.t &&
170 test_when_finished "git -C destination checkout init.t" &&
171 test_must_fail git worktree remove destination
172 '
173
174 test_expect_success 'remove worktree with untracked file' '
175 : >destination/untracked &&
176 test_must_fail git worktree remove destination
177 '
178
179 test_expect_success 'force remove worktree with untracked file' '
180 git worktree remove --force destination &&
181 test_path_is_missing destination
182 '
183
184 test_expect_success 'remove missing worktree' '
185 git worktree add to-be-gone &&
186 test -d .git/worktrees/to-be-gone &&
187 mv to-be-gone gone &&
188 git worktree remove to-be-gone &&
189 test_path_is_missing .git/worktrees/to-be-gone
190 '
191
192 test_expect_success 'NOT remove missing-but-locked worktree' '
193 git worktree add gone-but-locked &&
194 git worktree lock gone-but-locked &&
195 test -d .git/worktrees/gone-but-locked &&
196 mv gone-but-locked really-gone-now &&
197 test_must_fail git worktree remove gone-but-locked &&
198 test_path_is_dir .git/worktrees/gone-but-locked
199 '
200
201 test_expect_success 'proper error when worktree not found' '
202 for i in noodle noodle/bork
203 do
204 test_must_fail git worktree lock $i 2>err &&
205 test_grep "not a working tree" err || return 1
206 done
207 '
208
209 test_expect_success 'remove locked worktree (force)' '
210 git worktree add --detach gumby &&
211 test_when_finished "git worktree remove gumby || :" &&
212 git worktree lock gumby &&
213 test_when_finished "git worktree unlock gumby || :" &&
214 test_must_fail git worktree remove gumby &&
215 test_must_fail git worktree remove --force gumby &&
216 git worktree remove --force --force gumby
217 '
218
219 test_expect_success 'remove cleans up .git/worktrees when empty' '
220 git init moog &&
221 (
222 cd moog &&
223 test_commit bim &&
224 git worktree add --detach goom &&
225 test_path_exists .git/worktrees &&
226 git worktree remove goom &&
227 test_path_is_missing .git/worktrees
228 )
229 '
230
231 test_expect_success 'remove a repo with uninitialized submodule' '
232 test_config_global protocol.file.allow always &&
233 (
234 cd withsub &&
235 git worktree add to-remove HEAD &&
236 git worktree remove to-remove
237 )
238 '
239
240 test_expect_success 'not remove a repo with initialized submodule' '
241 test_config_global protocol.file.allow always &&
242 (
243 cd withsub &&
244 git worktree add to-remove HEAD &&
245 git -C to-remove submodule update &&
246 test_must_fail git worktree remove to-remove
247 )
248 '
249
250 test_done