| #!/bin/sh |
| |
| test_description='fetch/clone from a shallow clone over http' |
| |
| GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main |
| export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME |
| |
| . ./test-lib.sh |
| . "$TEST_DIRECTORY"/lib-httpd.sh |
| start_httpd |
| |
| commit() { |
| echo "$1" >tracked && |
| git add tracked && |
| test_tick && |
| git commit -m "$1" |
| } |
| |
| test_expect_success 'setup shallow clone' ' |
| test_tick=1500000000 && |
| commit 1 && |
| commit 2 && |
| commit 3 && |
| commit 4 && |
| commit 5 && |
| commit 6 && |
| commit 7 && |
| git clone --no-local --depth=5 .git shallow && |
| git config --global transfer.fsckObjects true |
| ' |
| |
| test_expect_success 'clone http repository' ' |
| git clone --bare --no-local shallow "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" && |
| git clone $HTTPD_URL/smart/repo.git clone && |
| ( |
| cd clone && |
| git fsck && |
| git log --format=%s origin/main >actual && |
| cat <<EOF >expect && |
| 7 |
| 6 |
| 5 |
| 4 |
| 3 |
| EOF |
| test_cmp expect actual |
| ) |
| ' |
| |
| # This test is tricky. We need large enough "have"s that fetch-pack |
| # will put pkt-flush in between. Then we need a "have" the server |
| # does not have, it'll send "ACK %s ready" |
| test_expect_success 'no shallow lines after receiving ACK ready' ' |
| ( |
| cd shallow && |
| for i in $(test_seq 15) |
| do |
| git checkout --orphan unrelated$i && |
| test_commit unrelated$i && |
| git push -q "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" \ |
| refs/heads/unrelated$i:refs/heads/unrelated$i && |
| git push -q ../clone/.git \ |
| refs/heads/unrelated$i:refs/heads/unrelated$i || |
| exit 1 |
| done && |
| git checkout main && |
| test_commit new && |
| git push "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" main |
| ) && |
| ( |
| cd clone && |
| git checkout --orphan newnew && |
| test_tick=1400000000 && |
| test_commit new-too && |
| # NEEDSWORK: If the overspecification of the expected result is reduced, we |
| # might be able to run this test in all protocol versions. |
| GIT_TRACE_PACKET="$TRASH_DIRECTORY/trace" GIT_TEST_PROTOCOL_VERSION=0 \ |
| git fetch --depth=2 && |
| grep "fetch-pack< ACK .* ready" ../trace && |
| ! grep "fetch-pack> done" ../trace |
| ) |
| ' |
| |
| test_expect_success 'clone shallow since ...' ' |
| test_create_repo shallow-since && |
| ( |
| cd shallow-since && |
| GIT_COMMITTER_DATE="100000000 +0700" git commit --allow-empty -m one && |
| GIT_COMMITTER_DATE="200000000 +0700" git commit --allow-empty -m two && |
| GIT_COMMITTER_DATE="300000000 +0700" git commit --allow-empty -m three && |
| mv .git "$HTTPD_DOCUMENT_ROOT_PATH/shallow-since.git" && |
| git clone --shallow-since "300000000 +0700" $HTTPD_URL/smart/shallow-since.git ../shallow11 && |
| git -C ../shallow11 log --pretty=tformat:%s HEAD >actual && |
| echo three >expected && |
| test_cmp expected actual |
| ) |
| ' |
| |
| test_expect_success 'fetch shallow since ...' ' |
| git -C shallow11 fetch --shallow-since "200000000 +0700" origin && |
| git -C shallow11 log --pretty=tformat:%s origin/main >actual && |
| cat >expected <<-\EOF && |
| three |
| two |
| EOF |
| test_cmp expected actual |
| ' |
| |
| test_expect_success 'shallow clone exclude tag two' ' |
| test_create_repo shallow-exclude && |
| ( |
| cd shallow-exclude && |
| test_commit one && |
| test_commit two && |
| test_commit three && |
| mv .git "$HTTPD_DOCUMENT_ROOT_PATH/shallow-exclude.git" && |
| git clone --shallow-exclude two $HTTPD_URL/smart/shallow-exclude.git ../shallow12 && |
| git -C ../shallow12 log --pretty=tformat:%s HEAD >actual && |
| echo three >expected && |
| test_cmp expected actual |
| ) |
| ' |
| |
| test_expect_success 'fetch exclude tag one' ' |
| git -C shallow12 fetch --shallow-exclude one origin && |
| git -C shallow12 log --pretty=tformat:%s origin/main >actual && |
| test_write_lines three two >expected && |
| test_cmp expected actual |
| ' |
| |
| test_expect_success 'fetching deepen' ' |
| test_create_repo shallow-deepen && |
| ( |
| cd shallow-deepen && |
| test_commit one && |
| test_commit two && |
| test_commit three && |
| mv .git "$HTTPD_DOCUMENT_ROOT_PATH/shallow-deepen.git" && |
| git clone --depth 1 $HTTPD_URL/smart/shallow-deepen.git deepen && |
| mv "$HTTPD_DOCUMENT_ROOT_PATH/shallow-deepen.git" .git && |
| test_commit four && |
| git -C deepen log --pretty=tformat:%s main >actual && |
| echo three >expected && |
| test_cmp expected actual && |
| mv .git "$HTTPD_DOCUMENT_ROOT_PATH/shallow-deepen.git" && |
| git -C deepen fetch --deepen=1 && |
| git -C deepen log --pretty=tformat:%s origin/main >actual && |
| cat >expected <<-\EOF && |
| four |
| three |
| two |
| EOF |
| test_cmp expected actual |
| ) |
| ' |
| |
| test_done |