#!/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_PASSES_SANITIZE_LEAK=true . ./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