diff options
| author | Junio C Hamano <gitster@pobox.com> | 2023-02-24 22:54:01 -0800 |
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2023-02-24 22:54:01 -0800 |
| commit | 6f581b6d6d17a0956f77d2f245a47ae9a2e76ae6 (patch) | |
| tree | f4cf70f974591566b947c31f108f11a65b560750 /t/t5564-http-proxy.sh | |
| parent | Merge branch 'ma/fetch-parallel-use-online-cpus' (diff) | |
| parent | add basic http proxy tests (diff) | |
| download | git-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-x | t/t5564-http-proxy.sh | 41 |
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 |
