fsck: document and test commented & empty line skipList input
[git] / t / t5504-fetch-receive-strict.sh
1 #!/bin/sh
2
3 test_description='fetch/receive strict mode'
4 . ./test-lib.sh
5
6 test_expect_success 'setup and inject "corrupt or missing" object' '
7         echo hello >greetings &&
8         git add greetings &&
9         git commit -m greetings &&
10
11         S=$(git rev-parse :greetings | sed -e "s|^..|&/|") &&
12         X=$(echo bye | git hash-object -w --stdin | sed -e "s|^..|&/|") &&
13         echo $S >S &&
14         echo $X >X &&
15         cp .git/objects/$S .git/objects/$S.back &&
16         mv -f .git/objects/$X .git/objects/$S &&
17
18         test_must_fail git fsck
19 '
20
21 test_expect_success 'fetch without strict' '
22         rm -rf dst &&
23         git init dst &&
24         (
25                 cd dst &&
26                 git config fetch.fsckobjects false &&
27                 git config transfer.fsckobjects false &&
28                 test_must_fail git fetch ../.git master
29         )
30 '
31
32 test_expect_success 'fetch with !fetch.fsckobjects' '
33         rm -rf dst &&
34         git init dst &&
35         (
36                 cd dst &&
37                 git config fetch.fsckobjects false &&
38                 git config transfer.fsckobjects true &&
39                 test_must_fail git fetch ../.git master
40         )
41 '
42
43 test_expect_success 'fetch with fetch.fsckobjects' '
44         rm -rf dst &&
45         git init dst &&
46         (
47                 cd dst &&
48                 git config fetch.fsckobjects true &&
49                 git config transfer.fsckobjects false &&
50                 test_must_fail git fetch ../.git master
51         )
52 '
53
54 test_expect_success 'fetch with transfer.fsckobjects' '
55         rm -rf dst &&
56         git init dst &&
57         (
58                 cd dst &&
59                 git config transfer.fsckobjects true &&
60                 test_must_fail git fetch ../.git master
61         )
62 '
63
64 cat >exp <<EOF
65 To dst
66 !       refs/heads/master:refs/heads/test       [remote rejected] (missing necessary objects)
67 EOF
68
69 test_expect_success 'push without strict' '
70         rm -rf dst &&
71         git init dst &&
72         (
73                 cd dst &&
74                 git config fetch.fsckobjects false &&
75                 git config transfer.fsckobjects false
76         ) &&
77         test_must_fail git push --porcelain dst master:refs/heads/test >act &&
78         test_cmp exp act
79 '
80
81 test_expect_success 'push with !receive.fsckobjects' '
82         rm -rf dst &&
83         git init dst &&
84         (
85                 cd dst &&
86                 git config receive.fsckobjects false &&
87                 git config transfer.fsckobjects true
88         ) &&
89         test_must_fail git push --porcelain dst master:refs/heads/test >act &&
90         test_cmp exp act
91 '
92
93 cat >exp <<EOF
94 To dst
95 !       refs/heads/master:refs/heads/test       [remote rejected] (unpacker error)
96 EOF
97
98 test_expect_success 'push with receive.fsckobjects' '
99         rm -rf dst &&
100         git init dst &&
101         (
102                 cd dst &&
103                 git config receive.fsckobjects true &&
104                 git config transfer.fsckobjects false
105         ) &&
106         test_must_fail git push --porcelain dst master:refs/heads/test >act &&
107         test_cmp exp act
108 '
109
110 test_expect_success 'push with transfer.fsckobjects' '
111         rm -rf dst &&
112         git init dst &&
113         (
114                 cd dst &&
115                 git config transfer.fsckobjects true
116         ) &&
117         test_must_fail git push --porcelain dst master:refs/heads/test >act &&
118         test_cmp exp act
119 '
120
121 test_expect_success 'repair the "corrupt or missing" object' '
122         mv -f .git/objects/$(cat S) .git/objects/$(cat X) &&
123         mv .git/objects/$(cat S).back .git/objects/$(cat S) &&
124         rm -rf .git/objects/$(cat X) &&
125         git fsck
126 '
127
128 cat >bogus-commit <<EOF
129 tree $EMPTY_TREE
130 author Bugs Bunny 1234567890 +0000
131 committer Bugs Bunny <bugs@bun.ni> 1234567890 +0000
132
133 This commit object intentionally broken
134 EOF
135
136 test_expect_success 'setup bogus commit' '
137         commit="$(git hash-object -t commit -w --stdin <bogus-commit)"
138 '
139
140 test_expect_success 'fsck with no skipList input' '
141         test_must_fail git fsck 2>err &&
142         test_i18ngrep "missingEmail" err
143 '
144
145 test_expect_success 'setup sorted and unsorted skipLists' '
146         cat >SKIP.unsorted <<-EOF &&
147         0000000000000000000000000000000000000004
148         0000000000000000000000000000000000000002
149         $commit
150         0000000000000000000000000000000000000001
151         0000000000000000000000000000000000000003
152         EOF
153         sort SKIP.unsorted >SKIP.sorted
154 '
155
156 test_expect_success 'fsck with sorted skipList' '
157         git -c fsck.skipList=SKIP.sorted fsck
158 '
159
160 test_expect_success 'fsck with unsorted skipList' '
161         git -c fsck.skipList=SKIP.unsorted fsck
162 '
163
164 test_expect_success 'fsck with invalid or bogus skipList input' '
165         git -c fsck.skipList=/dev/null -c fsck.missingEmail=ignore fsck &&
166         test_must_fail git -c fsck.skipList=does-not-exist -c fsck.missingEmail=ignore fsck 2>err &&
167         test_i18ngrep "Could not open skip list: does-not-exist" err &&
168         test_must_fail git -c fsck.skipList=.git/config -c fsck.missingEmail=ignore fsck 2>err &&
169         test_i18ngrep "Invalid SHA-1: \[core\]" err
170 '
171
172 test_expect_success 'fsck with invalid or bogus skipList input (comments & empty lines)' '
173         cat >SKIP.with-comment <<-EOF &&
174         # Some bad commit
175         0000000000000000000000000000000000000001
176         EOF
177         test_must_fail git -c fsck.skipList=SKIP.with-comment fsck 2>err-with-comment &&
178         test_i18ngrep "^fatal: Invalid SHA-1: # Some bad commit$" err-with-comment &&
179         cat >SKIP.with-empty-line <<-EOF &&
180         0000000000000000000000000000000000000001
181
182         0000000000000000000000000000000000000002
183         EOF
184         test_must_fail git -c fsck.skipList=SKIP.with-empty-line fsck 2>err-with-empty-line &&
185         test_i18ngrep "^fatal: Invalid SHA-1: " err-with-empty-line
186 '
187
188 test_expect_failure 'fsck no garbage output from comments & empty lines errors' '
189         test_line_count = 1 err-with-comment &&
190         test_line_count = 1 err-with-empty-line
191 '
192
193 test_expect_success 'push with receive.fsck.skipList' '
194         git push . $commit:refs/heads/bogus &&
195         rm -rf dst &&
196         git init dst &&
197         git --git-dir=dst/.git config receive.fsckObjects true &&
198         test_must_fail git push --porcelain dst bogus &&
199         echo $commit >dst/.git/SKIP &&
200
201         # receive.fsck.* does not fall back on fsck.*
202         git --git-dir=dst/.git config fsck.skipList SKIP &&
203         test_must_fail git push --porcelain dst bogus &&
204
205         # Invalid and/or bogus skipList input
206         git --git-dir=dst/.git config receive.fsck.skipList /dev/null &&
207         test_must_fail git push --porcelain dst bogus &&
208         git --git-dir=dst/.git config receive.fsck.skipList does-not-exist &&
209         test_must_fail git push --porcelain dst bogus 2>err &&
210         test_i18ngrep "Could not open skip list: does-not-exist" err &&
211         git --git-dir=dst/.git config receive.fsck.skipList config &&
212         test_must_fail git push --porcelain dst bogus 2>err &&
213         test_i18ngrep "Invalid SHA-1: \[core\]" err &&
214
215         git --git-dir=dst/.git config receive.fsck.skipList SKIP &&
216         git push --porcelain dst bogus
217 '
218
219 test_expect_success 'fetch with fetch.fsck.skipList' '
220         refspec=refs/heads/bogus:refs/heads/bogus &&
221         git push . $commit:refs/heads/bogus &&
222         rm -rf dst &&
223         git init dst &&
224         git --git-dir=dst/.git config fetch.fsckObjects true &&
225         test_must_fail git --git-dir=dst/.git fetch "file://$(pwd)" $refspec &&
226         git --git-dir=dst/.git config fetch.fsck.skipList /dev/null &&
227         test_must_fail git --git-dir=dst/.git fetch "file://$(pwd)" $refspec &&
228         echo $commit >dst/.git/SKIP &&
229
230         # fetch.fsck.* does not fall back on fsck.*
231         git --git-dir=dst/.git config fsck.skipList dst/.git/SKIP &&
232         test_must_fail git --git-dir=dst/.git fetch "file://$(pwd)" $refspec &&
233
234         # Invalid and/or bogus skipList input
235         git --git-dir=dst/.git config fetch.fsck.skipList /dev/null &&
236         test_must_fail git --git-dir=dst/.git fetch "file://$(pwd)" $refspec &&
237         git --git-dir=dst/.git config fetch.fsck.skipList does-not-exist &&
238         test_must_fail git --git-dir=dst/.git fetch "file://$(pwd)" $refspec 2>err &&
239         test_i18ngrep "Could not open skip list: does-not-exist" err &&
240         git --git-dir=dst/.git config fetch.fsck.skipList dst/.git/config &&
241         test_must_fail git --git-dir=dst/.git fetch "file://$(pwd)" $refspec 2>err &&
242         test_i18ngrep "Invalid SHA-1: \[core\]" err &&
243
244         git --git-dir=dst/.git config fetch.fsck.skipList dst/.git/SKIP &&
245         git --git-dir=dst/.git fetch "file://$(pwd)" $refspec
246 '
247
248 test_expect_success 'fsck.<unknownmsg-id> dies' '
249         test_must_fail git -c fsck.whatEver=ignore fsck 2>err &&
250         test_i18ngrep "Unhandled message id: whatever" err
251 '
252
253 test_expect_success 'push with receive.fsck.missingEmail=warn' '
254         git push . $commit:refs/heads/bogus &&
255         rm -rf dst &&
256         git init dst &&
257         git --git-dir=dst/.git config receive.fsckobjects true &&
258         test_must_fail git push --porcelain dst bogus &&
259
260         # receive.fsck.<msg-id> does not fall back on fsck.<msg-id>
261         git --git-dir=dst/.git config fsck.missingEmail warn &&
262         test_must_fail git push --porcelain dst bogus &&
263
264         # receive.fsck.<unknownmsg-id> warns
265         git --git-dir=dst/.git config \
266                 receive.fsck.whatEver error &&
267
268         git --git-dir=dst/.git config \
269                 receive.fsck.missingEmail warn &&
270         git push --porcelain dst bogus >act 2>&1 &&
271         grep "missingEmail" act &&
272         test_i18ngrep "Skipping unknown msg id.*whatever" act &&
273         git --git-dir=dst/.git branch -D bogus &&
274         git --git-dir=dst/.git config --add \
275                 receive.fsck.missingEmail ignore &&
276         git push --porcelain dst bogus >act 2>&1 &&
277         ! grep "missingEmail" act
278 '
279
280 test_expect_success 'fetch with fetch.fsck.missingEmail=warn' '
281         refspec=refs/heads/bogus:refs/heads/bogus &&
282         git push . $commit:refs/heads/bogus &&
283         rm -rf dst &&
284         git init dst &&
285         git --git-dir=dst/.git config fetch.fsckobjects true &&
286         test_must_fail git --git-dir=dst/.git fetch "file://$(pwd)" $refspec &&
287
288         # fetch.fsck.<msg-id> does not fall back on fsck.<msg-id>
289         git --git-dir=dst/.git config fsck.missingEmail warn &&
290         test_must_fail git --git-dir=dst/.git fetch "file://$(pwd)" $refspec &&
291
292         # receive.fsck.<unknownmsg-id> warns
293         git --git-dir=dst/.git config \
294                 fetch.fsck.whatEver error &&
295
296         git --git-dir=dst/.git config \
297                 fetch.fsck.missingEmail warn &&
298         git --git-dir=dst/.git fetch "file://$(pwd)" $refspec >act 2>&1 &&
299         grep "missingEmail" act &&
300         test_i18ngrep "Skipping unknown msg id.*whatever" act &&
301         rm -rf dst &&
302         git init dst &&
303         git --git-dir=dst/.git config fetch.fsckobjects true &&
304         git --git-dir=dst/.git config \
305                 fetch.fsck.missingEmail ignore &&
306         git --git-dir=dst/.git fetch "file://$(pwd)" $refspec >act 2>&1 &&
307         ! grep "missingEmail" act
308 '
309
310 test_expect_success \
311         'receive.fsck.unterminatedHeader=warn triggers error' '
312         rm -rf dst &&
313         git init dst &&
314         git --git-dir=dst/.git config receive.fsckobjects true &&
315         git --git-dir=dst/.git config \
316                 receive.fsck.unterminatedheader warn &&
317         test_must_fail git push --porcelain dst HEAD >act 2>&1 &&
318         grep "Cannot demote unterminatedheader" act
319 '
320
321 test_expect_success \
322         'fetch.fsck.unterminatedHeader=warn triggers error' '
323         rm -rf dst &&
324         git init dst &&
325         git --git-dir=dst/.git config fetch.fsckobjects true &&
326         git --git-dir=dst/.git config \
327                 fetch.fsck.unterminatedheader warn &&
328         test_must_fail git --git-dir=dst/.git fetch "file://$(pwd)" HEAD &&
329         grep "Cannot demote unterminatedheader" act
330 '
331
332 test_done