Start the 2.48 cycle
[alt-git.git] / t / t3435-rebase-gpg-sign.sh
blob6e329fea7c0fac0482e363a3d297134c942e256a
1 #!/bin/sh
3 # Copyright (c) 2020 Doan Tran Cong Danh
6 test_description='test rebase --[no-]gpg-sign'
8 GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main
9 export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME
11 TEST_PASSES_SANITIZE_LEAK=true
12 . ./test-lib.sh
13 . "$TEST_DIRECTORY/lib-rebase.sh"
14 . "$TEST_DIRECTORY/lib-gpg.sh"
16 if ! test_have_prereq GPG
17 then
18 skip_all='skip all test rebase --[no-]gpg-sign, gpg not available'
19 test_done
22 test_rebase_gpg_sign () {
23 local must_fail= will=will fake_editor=
24 if test "x$1" = "x!"
25 then
26 must_fail=test_must_fail
27 will="won't"
28 shift
30 conf=$1
31 shift
32 test_expect_success "rebase $* with commit.gpgsign=$conf $will sign commit" "
33 git reset two &&
34 git config commit.gpgsign $conf &&
35 set_fake_editor &&
36 FAKE_LINES='r 1 p 2' git rebase --force-rebase --root $* &&
37 $must_fail git verify-commit HEAD^ &&
38 $must_fail git verify-commit HEAD
42 test_expect_success 'setup' '
43 test_commit one &&
44 test_commit two &&
45 test_must_fail git verify-commit HEAD &&
46 test_must_fail git verify-commit HEAD^
49 test_expect_success 'setup: merge commit' '
50 test_commit fork-point &&
51 git switch -c side &&
52 test_commit three &&
53 git switch main &&
54 git merge --no-ff side &&
55 git tag merged
58 test_rebase_gpg_sign ! false
59 test_rebase_gpg_sign true
60 test_rebase_gpg_sign ! true --no-gpg-sign
61 test_rebase_gpg_sign ! true --gpg-sign --no-gpg-sign
62 test_rebase_gpg_sign false --no-gpg-sign --gpg-sign
63 test_rebase_gpg_sign true -i
64 test_rebase_gpg_sign ! true -i --no-gpg-sign
65 test_rebase_gpg_sign ! true -i --gpg-sign --no-gpg-sign
66 test_rebase_gpg_sign false -i --no-gpg-sign --gpg-sign
68 test_expect_success 'rebase -r, merge strategy, --gpg-sign will sign commit' '
69 git reset --hard merged &&
70 test_unconfig commit.gpgsign &&
71 git rebase -fr --gpg-sign -s resolve --root &&
72 git verify-commit HEAD
75 test_expect_success 'rebase -r, merge strategy, commit.gpgsign=true will sign commit' '
76 git reset --hard merged &&
77 git config commit.gpgsign true &&
78 git rebase -fr -s resolve --root &&
79 git verify-commit HEAD
82 test_expect_success 'rebase -r, merge strategy, commit.gpgsign=false --gpg-sign will sign commit' '
83 git reset --hard merged &&
84 git config commit.gpgsign false &&
85 git rebase -fr --gpg-sign -s resolve --root &&
86 git verify-commit HEAD
89 test_expect_success "rebase -r, merge strategy, commit.gpgsign=true --no-gpg-sign won't sign commit" '
90 git reset --hard merged &&
91 git config commit.gpgsign true &&
92 git rebase -fr --no-gpg-sign -s resolve --root &&
93 test_must_fail git verify-commit HEAD
96 test_expect_success 'rebase -r --gpg-sign will sign commit' '
97 git reset --hard merged &&
98 test_unconfig commit.gpgsign &&
99 git rebase -fr --gpg-sign --root &&
100 git verify-commit HEAD
103 test_expect_success 'rebase -r with commit.gpgsign=true will sign commit' '
104 git reset --hard merged &&
105 git config commit.gpgsign true &&
106 git rebase -fr --root &&
107 git verify-commit HEAD
110 test_expect_success 'rebase -r --gpg-sign with commit.gpgsign=false will sign commit' '
111 git reset --hard merged &&
112 git config commit.gpgsign false &&
113 git rebase -fr --gpg-sign --root &&
114 git verify-commit HEAD
117 test_expect_success "rebase -r --no-gpg-sign with commit.gpgsign=true won't sign commit" '
118 git reset --hard merged &&
119 git config commit.gpgsign true &&
120 git rebase -fr --no-gpg-sign --root &&
121 test_must_fail git verify-commit HEAD
124 test_done