t / t5812-proto-disable-http.shon commit Merge branch 'da/mergetool-xxdiff-hotkey' (a3c9887)
   1#!/bin/sh
   2
   3test_description='test disabling of git-over-http in clone/fetch'
   4. ./test-lib.sh
   5. "$TEST_DIRECTORY/lib-proto-disable.sh"
   6. "$TEST_DIRECTORY/lib-httpd.sh"
   7start_httpd
   8
   9test_expect_success 'create git-accessible repo' '
  10        bare="$HTTPD_DOCUMENT_ROOT_PATH/repo.git" &&
  11        test_commit one &&
  12        git --bare init "$bare" &&
  13        git push "$bare" HEAD &&
  14        git -C "$bare" config http.receivepack true
  15'
  16
  17test_proto "smart http" http "$HTTPD_URL/smart/repo.git"
  18
  19test_expect_success 'curl redirects respect whitelist' '
  20        test_must_fail env GIT_ALLOW_PROTOCOL=http:https \
  21                           GIT_SMART_HTTP=0 \
  22                git clone "$HTTPD_URL/ftp-redir/repo.git" 2>stderr &&
  23        {
  24                test_i18ngrep "ftp.*disabled" stderr ||
  25                test_i18ngrep "your curl version is too old"
  26        }
  27'
  28
  29test_expect_success 'curl limits redirects' '
  30        test_must_fail git clone "$HTTPD_URL/loop-redir/smart/repo.git"
  31'
  32
  33stop_httpd
  34test_done