2016-10-03 20:49:14 +00:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
test_description='check quarantine of objects during push'
|
2023-02-06 23:07:54 +00:00
|
|
|
|
|
|
|
TEST_PASSES_SANITIZE_LEAK=true
|
2016-10-03 20:49:14 +00:00
|
|
|
. ./test-lib.sh
|
|
|
|
|
|
|
|
test_expect_success 'create picky dest repo' '
|
|
|
|
git init --bare dest.git &&
|
2022-03-17 10:13:06 +00:00
|
|
|
test_hook --setup -C dest.git pre-receive <<-\EOF
|
2016-10-03 20:49:14 +00:00
|
|
|
while read old new ref; do
|
|
|
|
test "$(git log -1 --format=%s $new)" = reject && exit 1
|
|
|
|
done
|
|
|
|
exit 0
|
|
|
|
EOF
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'accepted objects work' '
|
|
|
|
test_commit ok &&
|
|
|
|
git push dest.git HEAD &&
|
|
|
|
commit=$(git rev-parse HEAD) &&
|
|
|
|
git --git-dir=dest.git cat-file commit $commit
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'rejected objects are not installed' '
|
|
|
|
test_commit reject &&
|
|
|
|
commit=$(git rev-parse HEAD) &&
|
|
|
|
test_must_fail git push dest.git reject &&
|
|
|
|
test_must_fail git --git-dir=dest.git cat-file commit $commit
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'rejected objects are removed' '
|
|
|
|
echo "incoming-*" >expect &&
|
|
|
|
(cd dest.git/objects && echo incoming-*) >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2016-12-13 19:09:31 +00:00
|
|
|
test_expect_success 'push to repo path with path separator (colon)' '
|
2016-12-12 19:53:55 +00:00
|
|
|
# The interesting failure case here is when the
|
|
|
|
# receiving end cannot access its original object directory,
|
|
|
|
# so make it likely for us to generate a delta by having
|
|
|
|
# a non-trivial file with multiple versions.
|
|
|
|
|
2018-03-24 07:44:42 +00:00
|
|
|
test-tool genrandom foo 4096 >file.bin &&
|
2016-12-12 19:53:55 +00:00
|
|
|
git add file.bin &&
|
|
|
|
git commit -m bin &&
|
2016-12-13 19:09:31 +00:00
|
|
|
|
|
|
|
if test_have_prereq MINGW
|
|
|
|
then
|
|
|
|
pathsep=";"
|
|
|
|
else
|
|
|
|
pathsep=":"
|
|
|
|
fi &&
|
|
|
|
git clone --bare . "xxx${pathsep}yyy.git" &&
|
2016-12-12 19:53:55 +00:00
|
|
|
|
|
|
|
echo change >>file.bin &&
|
|
|
|
git commit -am change &&
|
|
|
|
# Note that we have to use the full path here, or it gets confused
|
|
|
|
# with the ssh host:path syntax.
|
2016-12-13 19:09:31 +00:00
|
|
|
git push "$(pwd)/xxx${pathsep}yyy.git" HEAD
|
2016-12-12 19:53:55 +00:00
|
|
|
'
|
|
|
|
|
2017-04-10 22:14:12 +00:00
|
|
|
test_expect_success 'updating a ref from quarantine is forbidden' '
|
|
|
|
git init --bare update.git &&
|
2022-03-17 10:13:06 +00:00
|
|
|
test_hook -C update.git pre-receive <<-\EOF &&
|
2017-04-10 22:14:12 +00:00
|
|
|
read old new refname
|
|
|
|
git update-ref refs/heads/unrelated $new
|
|
|
|
exit 1
|
|
|
|
EOF
|
|
|
|
test_must_fail git push update.git HEAD &&
|
|
|
|
git -C update.git fsck
|
|
|
|
'
|
|
|
|
|
2016-10-03 20:49:14 +00:00
|
|
|
test_done
|