aboutsummaryrefslogtreecommitdiffstats
path: root/t/t5564-http-proxy.sh
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2023-02-24 22:54:01 -0800
committerJunio C Hamano <gitster@pobox.com>2023-02-24 22:54:01 -0800
commit6f581b6d6d17a0956f77d2f245a47ae9a2e76ae6 (patch)
treef4cf70f974591566b947c31f108f11a65b560750 /t/t5564-http-proxy.sh
parentMerge branch 'ma/fetch-parallel-use-online-cpus' (diff)
parentadd basic http proxy tests (diff)
downloadgit-6f581b6d6d17a0956f77d2f245a47ae9a2e76ae6.tar.gz
git-6f581b6d6d17a0956f77d2f245a47ae9a2e76ae6.zip
Merge branch 'jk/http-proxy-tests'
Test updates. * jk/http-proxy-tests: add basic http proxy tests
Diffstat (limited to 't/t5564-http-proxy.sh')
-rwxr-xr-xt/t5564-http-proxy.sh41
1 files changed, 41 insertions, 0 deletions
diff --git a/t/t5564-http-proxy.sh b/t/t5564-http-proxy.sh
new file mode 100755
index 0000000000..9da5134614
--- /dev/null
+++ b/t/t5564-http-proxy.sh
@@ -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