http: add Accept-Language header if possible
[git/git.git] / t / t5550-http-fetch-dumb.sh
1 #!/bin/sh
2
3 test_description='test dumb fetching over http via static file'
4 . ./test-lib.sh
5
6 if test -n "$NO_CURL"; then
7 skip_all='skipping test, git built without http support'
8 test_done
9 fi
10
11 . "$TEST_DIRECTORY"/lib-httpd.sh
12 start_httpd
13
14 test_expect_success 'setup repository' '
15 git config push.default matching &&
16 echo content1 >file &&
17 git add file &&
18 git commit -m one
19 echo content2 >file &&
20 git add file &&
21 git commit -m two
22 '
23
24 test_expect_success 'create http-accessible bare repository with loose objects' '
25 cp -R .git "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" &&
26 (cd "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" &&
27 git config core.bare true &&
28 mkdir -p hooks &&
29 echo "exec git update-server-info" >hooks/post-update &&
30 chmod +x hooks/post-update &&
31 hooks/post-update
32 ) &&
33 git remote add public "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" &&
34 git push public master:master
35 '
36
37 test_expect_success 'clone http repository' '
38 git clone $HTTPD_URL/dumb/repo.git clone-tmpl &&
39 cp -R clone-tmpl clone &&
40 test_cmp file clone/file
41 '
42
43 test_expect_success 'create password-protected repository' '
44 mkdir -p "$HTTPD_DOCUMENT_ROOT_PATH/auth/dumb/" &&
45 cp -Rf "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" \
46 "$HTTPD_DOCUMENT_ROOT_PATH/auth/dumb/repo.git"
47 '
48
49 setup_askpass_helper
50
51 test_expect_success 'cloning password-protected repository can fail' '
52 set_askpass wrong &&
53 test_must_fail git clone "$HTTPD_URL/auth/dumb/repo.git" clone-auth-fail &&
54 expect_askpass both wrong
55 '
56
57 test_expect_success 'http auth can use user/pass in URL' '
58 set_askpass wrong &&
59 git clone "$HTTPD_URL_USER_PASS/auth/dumb/repo.git" clone-auth-none &&
60 expect_askpass none
61 '
62
63 test_expect_success 'http auth can use just user in URL' '
64 set_askpass wrong pass@host &&
65 git clone "$HTTPD_URL_USER/auth/dumb/repo.git" clone-auth-pass &&
66 expect_askpass pass user@host
67 '
68
69 test_expect_success 'http auth can request both user and pass' '
70 set_askpass user@host pass@host &&
71 git clone "$HTTPD_URL/auth/dumb/repo.git" clone-auth-both &&
72 expect_askpass both user@host
73 '
74
75 test_expect_success 'http auth respects credential helper config' '
76 test_config_global credential.helper "!f() {
77 cat >/dev/null
78 echo username=user@host
79 echo password=pass@host
80 }; f" &&
81 set_askpass wrong &&
82 git clone "$HTTPD_URL/auth/dumb/repo.git" clone-auth-helper &&
83 expect_askpass none
84 '
85
86 test_expect_success 'http auth can get username from config' '
87 test_config_global "credential.$HTTPD_URL.username" user@host &&
88 set_askpass wrong pass@host &&
89 git clone "$HTTPD_URL/auth/dumb/repo.git" clone-auth-user &&
90 expect_askpass pass user@host
91 '
92
93 test_expect_success 'configured username does not override URL' '
94 test_config_global "credential.$HTTPD_URL.username" wrong &&
95 set_askpass wrong pass@host &&
96 git clone "$HTTPD_URL_USER/auth/dumb/repo.git" clone-auth-user2 &&
97 expect_askpass pass user@host
98 '
99
100 test_expect_success 'fetch changes via http' '
101 echo content >>file &&
102 git commit -a -m two &&
103 git push public &&
104 (cd clone && git pull) &&
105 test_cmp file clone/file
106 '
107
108 test_expect_success 'fetch changes via manual http-fetch' '
109 cp -R clone-tmpl clone2 &&
110
111 HEAD=$(git rev-parse --verify HEAD) &&
112 (cd clone2 &&
113 git http-fetch -a -w heads/master-new $HEAD $(git config remote.origin.url) &&
114 git checkout master-new &&
115 test $HEAD = $(git rev-parse --verify HEAD)) &&
116 test_cmp file clone2/file
117 '
118
119 test_expect_success 'http remote detects correct HEAD' '
120 git push public master:other &&
121 (cd clone &&
122 git remote set-head origin -d &&
123 git remote set-head origin -a &&
124 git symbolic-ref refs/remotes/origin/HEAD > output &&
125 echo refs/remotes/origin/master > expect &&
126 test_cmp expect output
127 )
128 '
129
130 test_expect_success 'fetch packed objects' '
131 cp -R "$HTTPD_DOCUMENT_ROOT_PATH"/repo.git "$HTTPD_DOCUMENT_ROOT_PATH"/repo_pack.git &&
132 (cd "$HTTPD_DOCUMENT_ROOT_PATH"/repo_pack.git &&
133 git --bare repack -a -d
134 ) &&
135 git clone $HTTPD_URL/dumb/repo_pack.git
136 '
137
138 test_expect_success 'fetch notices corrupt pack' '
139 cp -R "$HTTPD_DOCUMENT_ROOT_PATH"/repo_pack.git "$HTTPD_DOCUMENT_ROOT_PATH"/repo_bad1.git &&
140 (cd "$HTTPD_DOCUMENT_ROOT_PATH"/repo_bad1.git &&
141 p=`ls objects/pack/pack-*.pack` &&
142 chmod u+w $p &&
143 printf %0256d 0 | dd of=$p bs=256 count=1 seek=1 conv=notrunc
144 ) &&
145 mkdir repo_bad1.git &&
146 (cd repo_bad1.git &&
147 git --bare init &&
148 test_must_fail git --bare fetch $HTTPD_URL/dumb/repo_bad1.git &&
149 test 0 = `ls objects/pack/pack-*.pack | wc -l`
150 )
151 '
152
153 test_expect_success 'fetch notices corrupt idx' '
154 cp -R "$HTTPD_DOCUMENT_ROOT_PATH"/repo_pack.git "$HTTPD_DOCUMENT_ROOT_PATH"/repo_bad2.git &&
155 (cd "$HTTPD_DOCUMENT_ROOT_PATH"/repo_bad2.git &&
156 p=`ls objects/pack/pack-*.idx` &&
157 chmod u+w $p &&
158 printf %0256d 0 | dd of=$p bs=256 count=1 seek=1 conv=notrunc
159 ) &&
160 mkdir repo_bad2.git &&
161 (cd repo_bad2.git &&
162 git --bare init &&
163 test_must_fail git --bare fetch $HTTPD_URL/dumb/repo_bad2.git &&
164 test 0 = `ls objects/pack | wc -l`
165 )
166 '
167
168 test_expect_success 'did not use upload-pack service' '
169 grep '/git-upload-pack' <"$HTTPD_ROOT_PATH"/access.log >act
170 : >exp
171 test_cmp exp act
172 '
173
174 test_expect_success 'git client shows text/plain errors' '
175 test_must_fail git clone "$HTTPD_URL/error/text" 2>stderr &&
176 grep "this is the error message" stderr
177 '
178
179 test_expect_success 'git client does not show html errors' '
180 test_must_fail git clone "$HTTPD_URL/error/html" 2>stderr &&
181 ! grep "this is the error message" stderr
182 '
183
184 test_expect_success 'git client shows text/plain with a charset' '
185 test_must_fail git clone "$HTTPD_URL/error/charset" 2>stderr &&
186 grep "this is the error message" stderr
187 '
188
189 test_expect_success 'http error messages are reencoded' '
190 test_must_fail git clone "$HTTPD_URL/error/utf16" 2>stderr &&
191 grep "this is the error message" stderr
192 '
193
194 test_expect_success 'reencoding is robust to whitespace oddities' '
195 test_must_fail git clone "$HTTPD_URL/error/odd-spacing" 2>stderr &&
196 grep "this is the error message" stderr
197 '
198
199 check_language () {
200 case "$2" in
201 '')
202 >expect
203 ;;
204 ?*)
205 echo "Accept-Language: $1" >expect
206 ;;
207 esac &&
208 GIT_CURL_VERBOSE=1 \
209 LANGUAGE=$2 \
210 git ls-remote "$HTTPD_URL/dumb/repo.git" >output 2>&1 &&
211 tr -d '\015' <output |
212 sort -u |
213 sed -ne '/^Accept-Language:/ p' >actual &&
214 test_cmp expect actual
215 }
216
217 test_expect_success 'git client sends Accept-Language based on LANGUAGE' '
218 check_language "ko-KR, *;q=0.9" ko_KR.UTF-8'
219
220 test_expect_success 'git client sends Accept-Language correctly with unordinary LANGUAGE' '
221 check_language "ko-KR, *;q=0.9" "ko_KR:" &&
222 check_language "ko-KR, en-US;q=0.9, *;q=0.8" "ko_KR::en_US" &&
223 check_language "ko-KR, *;q=0.9" ":::ko_KR" &&
224 check_language "ko-KR, en-US;q=0.9, *;q=0.8" "ko_KR!!:en_US" &&
225 check_language "ko-KR, ja-JP;q=0.9, *;q=0.8" "ko_KR en_US:ja_JP"'
226
227 test_expect_success 'git client sends Accept-Language with many preferred languages' '
228 check_language "ko-KR, en-US;q=0.9, fr-CA;q=0.8, de;q=0.7, sr;q=0.6, \
229 ja;q=0.5, zh;q=0.4, sv;q=0.3, pt;q=0.2, *;q=0.1" \
230 ko_KR.EUC-KR:en_US.UTF-8:fr_CA:de.UTF-8@euro:sr@latin:ja:zh:sv:pt &&
231 check_language "ko-KR, en-US;q=0.99, fr-CA;q=0.98, de;q=0.97, sr;q=0.96, \
232 ja;q=0.95, zh;q=0.94, sv;q=0.93, pt;q=0.92, nb;q=0.91, *;q=0.90" \
233 ko_KR.EUC-KR:en_US.UTF-8:fr_CA:de.UTF-8@euro:sr@latin:ja:zh:sv:pt:nb
234 '
235
236 test_expect_success 'git client does not send an empty Accept-Language' '
237 GIT_CURL_VERBOSE=1 LANGUAGE= git ls-remote "$HTTPD_URL/dumb/repo.git" 2>stderr &&
238 ! grep "^Accept-Language:" stderr
239 '
240
241 stop_httpd
242 test_done