#!/bin/sh test_description='push from/to a shallow clone over http' . ./test-lib.sh if test -n "$NO_CURL"; then say 'skipping test, git built without http support' test_done fi . "$TEST_DIRECTORY"/lib-httpd.sh start_httpd commit() { echo "$1" >tracked && git add tracked && git commit -m "$1" } test_expect_success 'setup' ' git config --global transfer.fsckObjects true && commit 1 && commit 2 && commit 3 && commit 4 && git clone . full && ( git init full-abc && cd full-abc && commit a && commit b && commit c ) && git clone --no-local --depth=2 .git shallow && git --git-dir=shallow/.git log --format=%s >actual && cat <<EOF >expect && 4 3 EOF test_cmp expect actual && git clone --no-local --depth=2 full-abc/.git shallow2 && git --git-dir=shallow2/.git log --format=%s >actual && cat <<EOF >expect && c b EOF test_cmp expect actual ' test_expect_success 'push to shallow repo via http' ' git clone --bare --no-local shallow "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" && ( cd "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" && git config http.receivepack true ) && ( cd full && commit 9 && git push $HTTPD_URL/smart/repo.git +master:refs/remotes/top/master ) && ( cd "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" && git fsck && git log --format=%s top/master >actual && cat <<EOF >expect && 9 4 3 EOF test_cmp expect actual ) ' test_expect_success 'push from shallow repo via http' ' mv "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" shallow-upstream.git && git clone --bare --no-local full "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" && ( cd "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" && git config http.receivepack true ) && commit 10 && git push $HTTPD_URL/smart/repo.git +master:refs/remotes/top/master && ( cd "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" && git fsck && git log --format=%s top/master >actual && cat <<EOF >expect && 10 4 3 2 1 EOF test_cmp expect actual ) ' stop_httpd test_done