Merge branch 'jk/http-proxy-tests'
Test updates. * jk/http-proxy-tests: add basic http proxy tests
This commit is contained in:
commit
6f581b6d6d
@ -25,6 +25,7 @@
|
||||
# LIB_HTTPD_DAV enable DAV
|
||||
# LIB_HTTPD_SVN enable SVN at given location (e.g. "svn")
|
||||
# LIB_HTTPD_SSL enable SSL
|
||||
# LIB_HTTPD_PROXY enable proxy
|
||||
#
|
||||
# Copyright (c) 2008 Clemens Buchacher <drizzd@aon.at>
|
||||
#
|
||||
@ -133,6 +134,7 @@ install_script () {
|
||||
prepare_httpd() {
|
||||
mkdir -p "$HTTPD_DOCUMENT_ROOT_PATH"
|
||||
cp "$TEST_PATH"/passwd "$HTTPD_ROOT_PATH"
|
||||
cp "$TEST_PATH"/proxy-passwd "$HTTPD_ROOT_PATH"
|
||||
install_script incomplete-length-upload-pack-v2-http.sh
|
||||
install_script incomplete-body-upload-pack-v2-http.sh
|
||||
install_script error-no-report.sh
|
||||
@ -176,6 +178,11 @@ prepare_httpd() {
|
||||
export LIB_HTTPD_SVN LIB_HTTPD_SVNPATH
|
||||
fi
|
||||
fi
|
||||
|
||||
if test -n "$LIB_HTTPD_PROXY"
|
||||
then
|
||||
HTTPD_PARA="$HTTPD_PARA -DPROXY"
|
||||
fi
|
||||
}
|
||||
|
||||
enable_http2 () {
|
||||
|
@ -47,6 +47,22 @@ Protocols h2c
|
||||
LoadModule authz_host_module modules/mod_authz_host.so
|
||||
</IfModule>
|
||||
|
||||
<IfDefine PROXY>
|
||||
<IfModule !mod_proxy.c>
|
||||
LoadModule proxy_module modules/mod_proxy.so
|
||||
</IfModule>
|
||||
<IfModule !mod_proxy_http.c>
|
||||
LoadModule proxy_http_module modules/mod_proxy_http.so
|
||||
</IfModule>
|
||||
ProxyRequests On
|
||||
<Proxy "*">
|
||||
AuthType Basic
|
||||
AuthName "proxy-auth"
|
||||
AuthUserFile proxy-passwd
|
||||
Require valid-user
|
||||
</Proxy>
|
||||
</IfDefine>
|
||||
|
||||
<IfModule !mod_authn_core.c>
|
||||
LoadModule authn_core_module modules/mod_authn_core.so
|
||||
</IfModule>
|
||||
|
1
t/lib-httpd/proxy-passwd
Normal file
1
t/lib-httpd/proxy-passwd
Normal file
@ -0,0 +1 @@
|
||||
proxuser:2x7tAukjAED5M
|
41
t/t5564-http-proxy.sh
Executable file
41
t/t5564-http-proxy.sh
Executable file
@ -0,0 +1,41 @@
|
||||
#!/bin/sh
|
||||
|
||||
test_description="test fetching through http proxy"
|
||||
|
||||
. ./test-lib.sh
|
||||
. "$TEST_DIRECTORY"/lib-httpd.sh
|
||||
|
||||
LIB_HTTPD_PROXY=1
|
||||
start_httpd
|
||||
|
||||
test_expect_success 'setup repository' '
|
||||
test_commit foo &&
|
||||
git init --bare "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" &&
|
||||
git push --mirror "$HTTPD_DOCUMENT_ROOT_PATH/repo.git"
|
||||
'
|
||||
|
||||
setup_askpass_helper
|
||||
|
||||
# sanity check that our test setup is correctly using proxy
|
||||
test_expect_success 'proxy requires password' '
|
||||
test_config_global http.proxy $HTTPD_DEST &&
|
||||
test_must_fail git clone $HTTPD_URL/smart/repo.git 2>err &&
|
||||
grep "error.*407" err
|
||||
'
|
||||
|
||||
test_expect_success 'clone through proxy with auth' '
|
||||
test_when_finished "rm -rf clone" &&
|
||||
test_config_global http.proxy http://proxuser:proxpass@$HTTPD_DEST &&
|
||||
GIT_TRACE_CURL=$PWD/trace git clone $HTTPD_URL/smart/repo.git clone &&
|
||||
grep -i "Proxy-Authorization: Basic <redacted>" trace
|
||||
'
|
||||
|
||||
test_expect_success 'clone can prompt for proxy password' '
|
||||
test_when_finished "rm -rf clone" &&
|
||||
test_config_global http.proxy http://proxuser@$HTTPD_DEST &&
|
||||
set_askpass nobody proxpass &&
|
||||
GIT_TRACE_CURL=$PWD/trace git clone $HTTPD_URL/smart/repo.git clone &&
|
||||
expect_askpass pass proxuser
|
||||
'
|
||||
|
||||
test_done
|
Loading…
Reference in New Issue
Block a user