2013-12-05 14:02:44 +01:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
test_description='push from/to a shallow clone'
|
|
|
|
|
|
|
|
. ./test-lib.sh
|
|
|
|
|
|
|
|
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 &&
|
2013-12-05 14:02:51 +01:00
|
|
|
git clone . full &&
|
2013-12-05 14:02:44 +01:00
|
|
|
(
|
|
|
|
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 from shallow clone' '
|
|
|
|
(
|
|
|
|
cd shallow &&
|
|
|
|
commit 5 &&
|
|
|
|
git push ../.git +master:refs/remotes/shallow/master
|
|
|
|
) &&
|
|
|
|
git log --format=%s shallow/master >actual &&
|
|
|
|
git fsck &&
|
|
|
|
cat <<EOF >expect &&
|
|
|
|
5
|
|
|
|
4
|
|
|
|
3
|
|
|
|
2
|
|
|
|
1
|
|
|
|
EOF
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'push from shallow clone, with grafted roots' '
|
|
|
|
(
|
|
|
|
cd shallow2 &&
|
|
|
|
test_must_fail git push ../.git +master:refs/remotes/shallow2/master 2>err &&
|
|
|
|
grep "shallow2/master.*shallow update not allowed" err
|
|
|
|
) &&
|
|
|
|
test_must_fail git rev-parse shallow2/master &&
|
|
|
|
git fsck
|
|
|
|
'
|
|
|
|
|
2013-12-05 14:02:47 +01:00
|
|
|
test_expect_success 'add new shallow root with receive.updateshallow on' '
|
|
|
|
test_config receive.shallowupdate true &&
|
|
|
|
(
|
|
|
|
cd shallow2 &&
|
|
|
|
git push ../.git +master:refs/remotes/shallow2/master
|
|
|
|
) &&
|
|
|
|
git log --format=%s shallow2/master >actual &&
|
|
|
|
git fsck &&
|
|
|
|
cat <<EOF >expect &&
|
|
|
|
c
|
|
|
|
b
|
|
|
|
EOF
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2013-12-05 14:02:48 +01:00
|
|
|
test_expect_success 'push from shallow to shallow' '
|
|
|
|
(
|
|
|
|
cd shallow &&
|
|
|
|
git --git-dir=../shallow2/.git config receive.shallowupdate true &&
|
|
|
|
git push ../shallow2/.git +master:refs/remotes/shallow/master &&
|
|
|
|
git --git-dir=../shallow2/.git config receive.shallowupdate false
|
|
|
|
) &&
|
|
|
|
(
|
|
|
|
cd shallow2 &&
|
|
|
|
git log --format=%s shallow/master >actual &&
|
|
|
|
git fsck &&
|
|
|
|
cat <<EOF >expect &&
|
|
|
|
5
|
|
|
|
4
|
|
|
|
3
|
|
|
|
EOF
|
|
|
|
test_cmp expect actual
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'push from full to shallow' '
|
|
|
|
! git --git-dir=shallow2/.git cat-file blob `echo 1|git hash-object --stdin` &&
|
|
|
|
commit 1 &&
|
|
|
|
git push shallow2/.git +master:refs/remotes/top/master &&
|
|
|
|
(
|
|
|
|
cd shallow2 &&
|
|
|
|
git log --format=%s top/master >actual &&
|
|
|
|
git fsck &&
|
|
|
|
cat <<EOF >expect &&
|
|
|
|
1
|
|
|
|
4
|
|
|
|
3
|
|
|
|
EOF
|
|
|
|
test_cmp expect actual &&
|
|
|
|
git cat-file blob `echo 1|git hash-object --stdin` >/dev/null
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
2013-12-05 14:02:51 +01:00
|
|
|
if test -n "$NO_CURL" -o -z "$GIT_TEST_HTTPD"; then
|
|
|
|
say 'skipping remaining tests, git built without http support'
|
|
|
|
test_done
|
|
|
|
fi
|
|
|
|
|
|
|
|
. "$TEST_DIRECTORY"/lib-httpd.sh
|
|
|
|
start_httpd
|
|
|
|
|
|
|
|
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
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
2013-12-05 14:02:52 +01:00
|
|
|
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
|
|
|
|
1
|
|
|
|
4
|
|
|
|
3
|
|
|
|
2
|
|
|
|
1
|
|
|
|
EOF
|
|
|
|
test_cmp expect actual
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
2013-12-05 14:02:51 +01:00
|
|
|
stop_httpd
|
2013-12-05 14:02:44 +01:00
|
|
|
test_done
|