You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
123 lines
3.3 KiB
123 lines
3.3 KiB
#!/bin/sh |
|
# |
|
# Copyright (c) 2020 Doan Tran Cong Danh |
|
# |
|
|
|
test_description='test rebase --[no-]gpg-sign' |
|
|
|
GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main |
|
export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME |
|
|
|
. ./test-lib.sh |
|
. "$TEST_DIRECTORY/lib-rebase.sh" |
|
. "$TEST_DIRECTORY/lib-gpg.sh" |
|
|
|
if ! test_have_prereq GPG |
|
then |
|
skip_all='skip all test rebase --[no-]gpg-sign, gpg not available' |
|
test_done |
|
fi |
|
|
|
test_rebase_gpg_sign () { |
|
local must_fail= will=will fake_editor= |
|
if test "x$1" = "x!" |
|
then |
|
must_fail=test_must_fail |
|
will="won't" |
|
shift |
|
fi |
|
conf=$1 |
|
shift |
|
test_expect_success "rebase $* with commit.gpgsign=$conf $will sign commit" " |
|
git reset two && |
|
git config commit.gpgsign $conf && |
|
set_fake_editor && |
|
FAKE_LINES='r 1 p 2' git rebase --force-rebase --root $* && |
|
$must_fail git verify-commit HEAD^ && |
|
$must_fail git verify-commit HEAD |
|
" |
|
} |
|
|
|
test_expect_success 'setup' ' |
|
test_commit one && |
|
test_commit two && |
|
test_must_fail git verify-commit HEAD && |
|
test_must_fail git verify-commit HEAD^ |
|
' |
|
|
|
test_expect_success 'setup: merge commit' ' |
|
test_commit fork-point && |
|
git switch -c side && |
|
test_commit three && |
|
git switch main && |
|
git merge --no-ff side && |
|
git tag merged |
|
' |
|
|
|
test_rebase_gpg_sign ! false |
|
test_rebase_gpg_sign true |
|
test_rebase_gpg_sign ! true --no-gpg-sign |
|
test_rebase_gpg_sign ! true --gpg-sign --no-gpg-sign |
|
test_rebase_gpg_sign false --no-gpg-sign --gpg-sign |
|
test_rebase_gpg_sign true -i |
|
test_rebase_gpg_sign ! true -i --no-gpg-sign |
|
test_rebase_gpg_sign ! true -i --gpg-sign --no-gpg-sign |
|
test_rebase_gpg_sign false -i --no-gpg-sign --gpg-sign |
|
|
|
test_expect_success 'rebase -r, merge strategy, --gpg-sign will sign commit' ' |
|
git reset --hard merged && |
|
test_unconfig commit.gpgsign && |
|
git rebase -fr --gpg-sign -s resolve --root && |
|
git verify-commit HEAD |
|
' |
|
|
|
test_expect_success 'rebase -r, merge strategy, commit.gpgsign=true will sign commit' ' |
|
git reset --hard merged && |
|
git config commit.gpgsign true && |
|
git rebase -fr -s resolve --root && |
|
git verify-commit HEAD |
|
' |
|
|
|
test_expect_success 'rebase -r, merge strategy, commit.gpgsign=false --gpg-sign will sign commit' ' |
|
git reset --hard merged && |
|
git config commit.gpgsign false && |
|
git rebase -fr --gpg-sign -s resolve --root && |
|
git verify-commit HEAD |
|
' |
|
|
|
test_expect_success "rebase -r, merge strategy, commit.gpgsign=true --no-gpg-sign won't sign commit" ' |
|
git reset --hard merged && |
|
git config commit.gpgsign true && |
|
git rebase -fr --no-gpg-sign -s resolve --root && |
|
test_must_fail git verify-commit HEAD |
|
' |
|
|
|
test_expect_success 'rebase -r --gpg-sign will sign commit' ' |
|
git reset --hard merged && |
|
test_unconfig commit.gpgsign && |
|
git rebase -fr --gpg-sign --root && |
|
git verify-commit HEAD |
|
' |
|
|
|
test_expect_success 'rebase -r with commit.gpgsign=true will sign commit' ' |
|
git reset --hard merged && |
|
git config commit.gpgsign true && |
|
git rebase -fr --root && |
|
git verify-commit HEAD |
|
' |
|
|
|
test_expect_success 'rebase -r --gpg-sign with commit.gpgsign=false will sign commit' ' |
|
git reset --hard merged && |
|
git config commit.gpgsign false && |
|
git rebase -fr --gpg-sign --root && |
|
git verify-commit HEAD |
|
' |
|
|
|
test_expect_success "rebase -r --no-gpg-sign with commit.gpgsign=true won't sign commit" ' |
|
git reset --hard merged && |
|
git config commit.gpgsign true && |
|
git rebase -fr --no-gpg-sign --root && |
|
test_must_fail git verify-commit HEAD |
|
' |
|
|
|
test_done
|
|
|