afa53fe5d1
As0232852b
, but for the push tests instead: this avoids a start_httpd in the middle of the file, which fails under GIT_TEST_HTTPD=false. Note that we have to munge the test in a few ways while moving it: 1. We drop the `test -z "$GIT_TEST_HTTPD"` check; this is too simplistic since83d842d
, and we should let lib-httpd.sh handle it. 2. We have to port over some of the old setup from t5538. 3. In the final test, we no longer expect the extra commit "1" built on top of "4". This was a side effect from an earlier test in t5538 which was not ported over. Signed-off-by: Nick Alcock <nick.alcock@oracle.com> Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
124 lines
2.4 KiB
Bash
Executable File
124 lines
2.4 KiB
Bash
Executable File
#!/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 &&
|
|
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 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
|
|
'
|
|
|
|
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
|
|
'
|
|
|
|
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
|
|
)
|
|
'
|
|
test_done
|