|  | #!/bin/sh | 
|  | # | 
|  | # Copyright (c) 2008 Clemens Buchacher <drizzd@aon.at> | 
|  | # | 
|  |  | 
|  | test_description='test WebDAV http-push | 
|  |  | 
|  | This test runs various sanity checks on http-push.' | 
|  |  | 
|  | GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main | 
|  | export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME | 
|  |  | 
|  | . ./test-lib.sh | 
|  |  | 
|  | if git http-push > /dev/null 2>&1 || [ $? -eq 128 ] | 
|  | then | 
|  | skip_all="skipping test, USE_CURL_MULTI is not defined" | 
|  | test_done | 
|  | fi | 
|  |  | 
|  | if test_have_prereq !REFFILES | 
|  | then | 
|  | skip_all='skipping test; dumb HTTP protocol not supported with reftable.' | 
|  | test_done | 
|  | fi | 
|  |  | 
|  | LIB_HTTPD_DAV=t | 
|  | . "$TEST_DIRECTORY"/lib-httpd.sh | 
|  | ROOT_PATH="$PWD" | 
|  | start_httpd | 
|  |  | 
|  | test_expect_success 'setup remote repository' ' | 
|  | cd "$ROOT_PATH" && | 
|  | mkdir test_repo && | 
|  | cd test_repo && | 
|  | git init && | 
|  | : >path1 && | 
|  | git add path1 && | 
|  | test_tick && | 
|  | git commit -m initial && | 
|  | cd - && | 
|  | git clone --bare test_repo test_repo.git && | 
|  | cd test_repo.git && | 
|  | git --bare update-server-info && | 
|  | test_hook --setup post-update <<-\EOF && | 
|  | exec git update-server-info | 
|  | EOF | 
|  | ORIG_HEAD=$(git rev-parse --verify HEAD) && | 
|  | cd - && | 
|  | mv test_repo.git "$HTTPD_DOCUMENT_ROOT_PATH" | 
|  | ' | 
|  |  | 
|  | test_expect_success 'create password-protected repository' ' | 
|  | mkdir -p "$HTTPD_DOCUMENT_ROOT_PATH/auth/dumb" && | 
|  | cp -Rf "$HTTPD_DOCUMENT_ROOT_PATH/test_repo.git" \ | 
|  | "$HTTPD_DOCUMENT_ROOT_PATH/auth/dumb/test_repo.git" | 
|  | ' | 
|  |  | 
|  | setup_askpass_helper | 
|  |  | 
|  | test_expect_success 'clone remote repository' ' | 
|  | cd "$ROOT_PATH" && | 
|  | git clone $HTTPD_URL/dumb/test_repo.git test_repo_clone | 
|  | ' | 
|  |  | 
|  | test_expect_success 'push to remote repository with packed refs' ' | 
|  | cd "$ROOT_PATH"/test_repo_clone && | 
|  | : >path2 && | 
|  | git add path2 && | 
|  | test_tick && | 
|  | git commit -m path2 && | 
|  | HEAD=$(git rev-parse --verify HEAD) && | 
|  | git push && | 
|  | (cd "$HTTPD_DOCUMENT_ROOT_PATH"/test_repo.git && | 
|  | test $HEAD = $(git rev-parse --verify HEAD)) | 
|  | ' | 
|  |  | 
|  | test_expect_success 'push already up-to-date' ' | 
|  | git push | 
|  | ' | 
|  |  | 
|  | test_expect_success 'push to remote repository with unpacked refs' ' | 
|  | (cd "$HTTPD_DOCUMENT_ROOT_PATH"/test_repo.git && | 
|  | rm packed-refs && | 
|  | git update-ref refs/heads/main $ORIG_HEAD && | 
|  | git --bare update-server-info) && | 
|  | git push && | 
|  | (cd "$HTTPD_DOCUMENT_ROOT_PATH"/test_repo.git && | 
|  | test $HEAD = $(git rev-parse --verify HEAD)) | 
|  | ' | 
|  |  | 
|  | test_expect_success 'http-push fetches unpacked objects' ' | 
|  | cp -R "$HTTPD_DOCUMENT_ROOT_PATH"/test_repo.git \ | 
|  | "$HTTPD_DOCUMENT_ROOT_PATH"/test_repo_unpacked.git && | 
|  |  | 
|  | git clone $HTTPD_URL/dumb/test_repo_unpacked.git \ | 
|  | "$ROOT_PATH"/fetch_unpacked && | 
|  |  | 
|  | # By reset, we force git to retrieve the object | 
|  | (cd "$ROOT_PATH"/fetch_unpacked && | 
|  | git reset --hard HEAD^ && | 
|  | git remote rm origin && | 
|  | git reflog expire --expire=0 --all && | 
|  | git prune && | 
|  | git push -f -v $HTTPD_URL/dumb/test_repo_unpacked.git main) | 
|  | ' | 
|  |  | 
|  | test_expect_success 'http-push fetches packed objects' ' | 
|  | cp -R "$HTTPD_DOCUMENT_ROOT_PATH"/test_repo.git \ | 
|  | "$HTTPD_DOCUMENT_ROOT_PATH"/test_repo_packed.git && | 
|  |  | 
|  | git clone $HTTPD_URL/dumb/test_repo_packed.git \ | 
|  | "$ROOT_PATH"/test_repo_clone_packed && | 
|  |  | 
|  | (cd "$HTTPD_DOCUMENT_ROOT_PATH"/test_repo_packed.git && | 
|  | git --bare repack && | 
|  | git --bare prune-packed) && | 
|  |  | 
|  | # By reset, we force git to retrieve the packed object | 
|  | (cd "$ROOT_PATH"/test_repo_clone_packed && | 
|  | git reset --hard HEAD^ && | 
|  | git remote remove origin && | 
|  | git reflog expire --expire=0 --all && | 
|  | git prune && | 
|  | git push -f -v $HTTPD_URL/dumb/test_repo_packed.git main) | 
|  | ' | 
|  |  | 
|  | test_expect_success 'create and delete remote branch' ' | 
|  | cd "$ROOT_PATH"/test_repo_clone && | 
|  | git checkout -b dev && | 
|  | : >path3 && | 
|  | git add path3 && | 
|  | test_tick && | 
|  | git commit -m dev && | 
|  | git push origin dev && | 
|  | git push origin :dev && | 
|  | test_must_fail git show-ref --verify refs/remotes/origin/dev | 
|  | ' | 
|  |  | 
|  | test_expect_success 'non-force push fails if not up to date' ' | 
|  | git init --bare "$HTTPD_DOCUMENT_ROOT_PATH"/test_repo_conflict.git && | 
|  | git -C "$HTTPD_DOCUMENT_ROOT_PATH"/test_repo_conflict.git update-server-info && | 
|  | git clone $HTTPD_URL/dumb/test_repo_conflict.git "$ROOT_PATH"/c1 && | 
|  | git clone $HTTPD_URL/dumb/test_repo_conflict.git "$ROOT_PATH"/c2 && | 
|  | test_commit -C "$ROOT_PATH/c1" path1 && | 
|  | git -C "$ROOT_PATH/c1" push origin HEAD && | 
|  | git -C "$ROOT_PATH/c2" pull && | 
|  | test_commit -C "$ROOT_PATH/c1" path2 && | 
|  | git -C "$ROOT_PATH/c1" push origin HEAD && | 
|  | test_commit -C "$ROOT_PATH/c2" path3 && | 
|  | git -C "$ROOT_PATH/c1" log --graph --all && | 
|  | git -C "$ROOT_PATH/c2" log --graph --all && | 
|  | test_must_fail git -C "$ROOT_PATH/c2" push origin HEAD | 
|  | ' | 
|  |  | 
|  | test_expect_success 'MKCOL sends directory names with trailing slashes' ' | 
|  |  | 
|  | ! grep "\"MKCOL.*[^/] HTTP/[^ ]*\"" < "$HTTPD_ROOT_PATH"/access.log | 
|  |  | 
|  | ' | 
|  |  | 
|  | x1="[0-9a-f]" | 
|  | x2="$x1$x1" | 
|  | xtrunc=$(echo $OID_REGEX | sed -e "s/\[0-9a-f\]\[0-9a-f\]//") | 
|  |  | 
|  | test_expect_success 'PUT and MOVE sends object to URLs with SHA-1 hash suffix' ' | 
|  | sed \ | 
|  | -e "s/PUT /OP /" \ | 
|  | -e "s/MOVE /OP /" \ | 
|  | -e "s|/objects/$x2/${xtrunc}_$OID_REGEX|WANTED_PATH_REQUEST|" \ | 
|  | "$HTTPD_ROOT_PATH"/access.log | | 
|  | grep -e "\"OP .*WANTED_PATH_REQUEST HTTP/[.0-9]*\" 20[0-9] " | 
|  |  | 
|  | ' | 
|  |  | 
|  | test_http_push_nonff "$HTTPD_DOCUMENT_ROOT_PATH"/test_repo.git \ | 
|  | "$ROOT_PATH"/test_repo_clone main | 
|  |  | 
|  | test_expect_success 'push to password-protected repository (user in URL)' ' | 
|  | test_commit pw-user && | 
|  | set_askpass user@host pass@host && | 
|  | git push "$HTTPD_URL_USER/auth/dumb/test_repo.git" HEAD && | 
|  | git rev-parse --verify HEAD >expect && | 
|  | git --git-dir="$HTTPD_DOCUMENT_ROOT_PATH/auth/dumb/test_repo.git" \ | 
|  | rev-parse --verify HEAD >actual && | 
|  | test_cmp expect actual | 
|  | ' | 
|  |  | 
|  | test_expect_failure 'user was prompted only once for password' ' | 
|  | expect_askpass pass user@host | 
|  | ' | 
|  |  | 
|  | test_expect_failure 'push to password-protected repository (no user in URL)' ' | 
|  | test_commit pw-nouser && | 
|  | set_askpass user@host pass@host && | 
|  | git push "$HTTPD_URL/auth/dumb/test_repo.git" HEAD && | 
|  | expect_askpass both user@host && | 
|  | git rev-parse --verify HEAD >expect && | 
|  | git --git-dir="$HTTPD_DOCUMENT_ROOT_PATH/auth/dumb/test_repo.git" \ | 
|  | rev-parse --verify HEAD >actual && | 
|  | test_cmp expect actual | 
|  | ' | 
|  |  | 
|  | test_done |