116 lines
3.4 KiB
Bash
Executable File
116 lines
3.4 KiB
Bash
Executable File
#!/bin/sh
|
|
|
|
test_description='check the consisitency of behavior of --all and --branches'
|
|
|
|
GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main
|
|
export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME
|
|
|
|
. ./test-lib.sh
|
|
|
|
delete_refs() {
|
|
dir=$1
|
|
shift
|
|
rm -rf deletes
|
|
for arg in $*
|
|
do
|
|
echo "delete ${arg}" >>deletes
|
|
done
|
|
git -C $dir update-ref --stdin < deletes
|
|
}
|
|
|
|
test_expect_success 'setup bare remote' '
|
|
git init --bare remote-1 &&
|
|
git -C remote-1 config gc.auto 0 &&
|
|
test_commit one &&
|
|
git push remote-1 HEAD
|
|
'
|
|
|
|
test_expect_success 'setup different types of references' '
|
|
cat >refs <<-EOF &&
|
|
update refs/heads/branch-1 HEAD
|
|
update refs/heads/branch-2 HEAD
|
|
EOF
|
|
|
|
git tag -a -m "annotated" annotated-1 HEAD &&
|
|
git tag -a -m "annotated" annotated-2 HEAD &&
|
|
git update-ref --stdin < refs
|
|
'
|
|
|
|
test_expect_success '--all and --branches have the same behavior' '
|
|
test_when_finished "delete_refs remote-1 \
|
|
refs/heads/branch-1 \
|
|
refs/heads/branch-2" &&
|
|
git push remote-1 --all &&
|
|
commit=$(git rev-parse HEAD) &&
|
|
cat >expect <<-EOF &&
|
|
$commit refs/heads/branch-1
|
|
$commit refs/heads/branch-2
|
|
$commit refs/heads/main
|
|
EOF
|
|
|
|
git -C remote-1 show-ref --heads >actual.all &&
|
|
delete_refs remote-1 refs/heads/branch-1 refs/heads/branch-2 &&
|
|
git push remote-1 --branches &&
|
|
git -C remote-1 show-ref --heads >actual.branches &&
|
|
test_cmp actual.all actual.branches &&
|
|
test_cmp expect actual.all
|
|
'
|
|
|
|
test_expect_success '--all or --branches can not be combined with refspecs' '
|
|
test_must_fail git push remote-1 --all main >actual.all 2>&1 &&
|
|
test_must_fail git push remote-1 --branches main >actual.branches 2>&1 &&
|
|
test_cmp actual.all actual.branches &&
|
|
grep "be combined with refspecs" actual.all
|
|
'
|
|
|
|
test_expect_success '--all or --branches can not be combined with --mirror' '
|
|
test_must_fail git push remote-1 --all --mirror >actual.all 2>&1 &&
|
|
test_must_fail git push remote-1 --branches --mirror >actual.branches 2>&1 &&
|
|
test_cmp actual.all actual.branches &&
|
|
grep "cannot be used together" actual.all
|
|
'
|
|
|
|
test_expect_success '--all or --branches can not be combined with --tags' '
|
|
test_must_fail git push remote-1 --all --tags >actual.all 2>&1 &&
|
|
test_must_fail git push remote-1 --branches --tags >actual.branches 2>&1 &&
|
|
test_cmp actual.all actual.branches &&
|
|
grep "cannot be used together" actual.all
|
|
'
|
|
|
|
|
|
test_expect_success '--all or --branches can not be combined with --delete' '
|
|
test_must_fail git push remote-1 --all --delete >actual.all 2>&1 &&
|
|
test_must_fail git push remote-1 --branches --delete >actual.branches 2>&1 &&
|
|
test_cmp actual.all actual.branches &&
|
|
grep "cannot be used together" actual.all
|
|
'
|
|
|
|
test_expect_success '--all or --branches combines with --follow-tags have same behavior' '
|
|
test_when_finished "delete_refs remote-1 \
|
|
refs/heads/branch-1 \
|
|
refs/heads/branch-2 \
|
|
refs/tags/annotated-1 \
|
|
refs/tags/annotated-2" &&
|
|
git push remote-1 --all --follow-tags &&
|
|
git -C remote-1 show-ref > actual.all &&
|
|
cat >expect <<-EOF &&
|
|
$commit refs/heads/branch-1
|
|
$commit refs/heads/branch-2
|
|
$commit refs/heads/main
|
|
$(git rev-parse annotated-1) refs/tags/annotated-1
|
|
$(git rev-parse annotated-2) refs/tags/annotated-2
|
|
EOF
|
|
|
|
delete_refs remote-1 \
|
|
refs/heads/branch-1 \
|
|
refs/heads/branch-2 \
|
|
refs/tags/annotated-1 \
|
|
refs/tags/annotated-2 &&
|
|
git push remote-1 --branches --follow-tags &&
|
|
git -C remote-1 show-ref >actual.branches &&
|
|
test_cmp actual.all actual.branches &&
|
|
test_cmp expect actual.all
|
|
'
|
|
|
|
test_done
|