#!/bin/sh test_description='test git-http-backend' . ./test-lib.sh if test -n "$NO_CURL"; then say 'skipping test, git built without http support' test_done fi LIB_HTTPD_PORT=${LIB_HTTPD_PORT-'5560'} . "$TEST_DIRECTORY"/lib-httpd.sh start_httpd find_file() { cd "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" && find $1 -type f | sed -e 1q } config() { git --git-dir="$HTTPD_DOCUMENT_ROOT_PATH/repo.git" config $1 $2 } GET() { curl --include "$HTTPD_URL/smart/repo.git/$1" >out 2>/dev/null && tr '\015' Q <out | sed ' s/Q$// 1q ' >act && echo "HTTP/1.1 $2" >exp && test_cmp exp act } POST() { curl --include --data "$2" \ --header "Content-Type: application/x-$1-request" \ "$HTTPD_URL/smart/repo.git/$1" >out 2>/dev/null && tr '\015' Q <out | sed ' s/Q$// 1q ' >act && echo "HTTP/1.1 $3" >exp && test_cmp exp act } log_div() { echo >>"$HTTPD_ROOT_PATH"/access.log echo "### $1" >>"$HTTPD_ROOT_PATH"/access.log echo "###" >>"$HTTPD_ROOT_PATH"/access.log } test_expect_success 'setup repository' ' echo content >file && git add file && git commit -m one && mkdir "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" && (cd "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" && git --bare init && : >objects/info/alternates && : >objects/info/http-alternates ) && git remote add public "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" && git push public master:master && (cd "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" && git repack -a -d ) && echo other >file && git add file && git commit -m two && git push public master:master && LOOSE_URL=$(find_file objects/??) && PACK_URL=$(find_file objects/pack/*.pack) && IDX_URL=$(find_file objects/pack/*.idx) ' get_static_files() { GET HEAD "$1" && GET info/refs "$1" && GET objects/info/packs "$1" && GET objects/info/alternates "$1" && GET objects/info/http-alternates "$1" && GET $LOOSE_URL "$1" && GET $PACK_URL "$1" && GET $IDX_URL "$1" } test_expect_success 'direct refs/heads/master not found' ' log_div "refs/heads/master" GET refs/heads/master "404 Not Found" ' test_expect_success 'static file is ok' ' log_div "getanyfile default" get_static_files "200 OK" ' test_expect_success 'static file if http.getanyfile true is ok' ' log_div "getanyfile true" config http.getanyfile true && get_static_files "200 OK" ' test_expect_success 'static file if http.getanyfile false fails' ' log_div "getanyfile false" config http.getanyfile false && get_static_files "403 Forbidden" ' test_expect_success 'http.uploadpack default enabled' ' log_div "uploadpack default" GET info/refs?service=git-upload-pack "200 OK" && POST git-upload-pack 0000 "200 OK" ' test_expect_success 'http.uploadpack true' ' log_div "uploadpack true" config http.uploadpack true && GET info/refs?service=git-upload-pack "200 OK" && POST git-upload-pack 0000 "200 OK" ' test_expect_success 'http.uploadpack false' ' log_div "uploadpack false" config http.uploadpack false && GET info/refs?service=git-upload-pack "403 Forbidden" && POST git-upload-pack 0000 "403 Forbidden" ' test_expect_success 'http.receivepack default disabled' ' log_div "receivepack default" GET info/refs?service=git-receive-pack "403 Forbidden" && POST git-receive-pack 0000 "403 Forbidden" ' test_expect_success 'http.receivepack true' ' log_div "receivepack true" config http.receivepack true && GET info/refs?service=git-receive-pack "200 OK" && POST git-receive-pack 0000 "200 OK" ' test_expect_success 'http.receivepack false' ' log_div "receivepack false" config http.receivepack false && GET info/refs?service=git-receive-pack "403 Forbidden" && POST git-receive-pack 0000 "403 Forbidden" ' run_backend() { REQUEST_METHOD=GET \ GIT_PROJECT_ROOT="$HTTPD_DOCUMENT_ROOT_PATH" \ PATH_INFO="$2" \ git http-backend >act.out 2>act.err } path_info() { if test $1 = 0; then run_backend "$2" else test_must_fail run_backend "$2" && echo "fatal: '$2': aliased" >exp.err && test_cmp exp.err act.err fi } test_expect_success 'http-backend blocks bad PATH_INFO' ' config http.getanyfile true && run_backend 0 /repo.git/HEAD && run_backend 1 /repo.git/../HEAD && run_backend 1 /../etc/passwd && run_backend 1 ../etc/passwd && run_backend 1 /etc//passwd && run_backend 1 /etc/./passwd && run_backend 1 /etc/.../passwd && run_backend 1 //domain/data.txt ' cat >exp <<EOF ### refs/heads/master ### GET /smart/repo.git/refs/heads/master HTTP/1.1 404 - ### getanyfile default ### GET /smart/repo.git/HEAD HTTP/1.1 200 GET /smart/repo.git/info/refs HTTP/1.1 200 GET /smart/repo.git/objects/info/packs HTTP/1.1 200 GET /smart/repo.git/objects/info/alternates HTTP/1.1 200 - GET /smart/repo.git/objects/info/http-alternates HTTP/1.1 200 - GET /smart/repo.git/$LOOSE_URL HTTP/1.1 200 GET /smart/repo.git/$PACK_URL HTTP/1.1 200 GET /smart/repo.git/$IDX_URL HTTP/1.1 200 ### getanyfile true ### GET /smart/repo.git/HEAD HTTP/1.1 200 GET /smart/repo.git/info/refs HTTP/1.1 200 GET /smart/repo.git/objects/info/packs HTTP/1.1 200 GET /smart/repo.git/objects/info/alternates HTTP/1.1 200 - GET /smart/repo.git/objects/info/http-alternates HTTP/1.1 200 - GET /smart/repo.git/$LOOSE_URL HTTP/1.1 200 GET /smart/repo.git/$PACK_URL HTTP/1.1 200 GET /smart/repo.git/$IDX_URL HTTP/1.1 200 ### getanyfile false ### GET /smart/repo.git/HEAD HTTP/1.1 403 - GET /smart/repo.git/info/refs HTTP/1.1 403 - GET /smart/repo.git/objects/info/packs HTTP/1.1 403 - GET /smart/repo.git/objects/info/alternates HTTP/1.1 403 - GET /smart/repo.git/objects/info/http-alternates HTTP/1.1 403 - GET /smart/repo.git/$LOOSE_URL HTTP/1.1 403 - GET /smart/repo.git/$PACK_URL HTTP/1.1 403 - GET /smart/repo.git/$IDX_URL HTTP/1.1 403 - ### uploadpack default ### GET /smart/repo.git/info/refs?service=git-upload-pack HTTP/1.1 200 POST /smart/repo.git/git-upload-pack HTTP/1.1 200 - ### uploadpack true ### GET /smart/repo.git/info/refs?service=git-upload-pack HTTP/1.1 200 POST /smart/repo.git/git-upload-pack HTTP/1.1 200 - ### uploadpack false ### GET /smart/repo.git/info/refs?service=git-upload-pack HTTP/1.1 403 - POST /smart/repo.git/git-upload-pack HTTP/1.1 403 - ### receivepack default ### GET /smart/repo.git/info/refs?service=git-receive-pack HTTP/1.1 403 - POST /smart/repo.git/git-receive-pack HTTP/1.1 403 - ### receivepack true ### GET /smart/repo.git/info/refs?service=git-receive-pack HTTP/1.1 200 POST /smart/repo.git/git-receive-pack HTTP/1.1 200 - ### receivepack false ### GET /smart/repo.git/info/refs?service=git-receive-pack HTTP/1.1 403 - POST /smart/repo.git/git-receive-pack HTTP/1.1 403 - EOF test_expect_success 'server request log matches test results' ' sed -e " s/^.* \"// s/\"// s/ [1-9][0-9]*\$// s/^GET /GET / " >act <"$HTTPD_ROOT_PATH"/access.log && test_cmp exp act ' stop_httpd test_done