summaryrefslogtreecommitdiff
path: root/t/t5812-proto-disable-http.sh
blob: d911afd24cd7d43fc412adb34144b90b66082b73 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
#!/bin/sh

test_description='test disabling of git-over-http in clone/fetch'
. ./test-lib.sh
. "$TEST_DIRECTORY/lib-proto-disable.sh"
. "$TEST_DIRECTORY/lib-httpd.sh"
start_httpd

test_expect_success 'create git-accessible repo' '
	bare="$HTTPD_DOCUMENT_ROOT_PATH/repo.git" &&
	test_commit one &&
	git --bare init "$bare" &&
	git push "$bare" HEAD &&
	git -C "$bare" config http.receivepack true
'

test_proto "smart http" http "$HTTPD_URL/smart/repo.git"

test_expect_success 'curl redirects respect whitelist' '
	test_must_fail env GIT_ALLOW_PROTOCOL=http:https \
			   GIT_SMART_HTTP=0 \
		git clone "$HTTPD_URL/ftp-redir/repo.git" 2>stderr &&
	{
		test_i18ngrep "ftp.*disabled" stderr ||
		test_i18ngrep "your curl version is too old"
	}
'

test_expect_success 'curl limits redirects' '
	test_must_fail git clone "$HTTPD_URL/loop-redir/smart/repo.git"
'

test_expect_success 'http can be limited to from-user' '
	git -c protocol.http.allow=user \
		clone "$HTTPD_URL/smart/repo.git" plain.git &&
	test_must_fail git -c protocol.http.allow=user \
		clone "$HTTPD_URL/smart-redir-perm/repo.git" redir.git
'

stop_httpd
test_done