|  | #!/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 |