Merge branch 'br/commit-tree-fully-spelled-gpg-sign-option'

The documentation of "git commit-tree" said that the command
understands "--gpg-sign" in addition to "-S", but the command line
parser did not know about the longhand, which has been corrected.

* br/commit-tree-fully-spelled-gpg-sign-option:
  commit-tree: add missing --gpg-sign flag
  t7510: invoke git as part of &&-chain
This commit is contained in:
Junio C Hamano 2019-02-06 22:05:25 -08:00
commit e7b120bfa5
2 changed files with 24 additions and 5 deletions

View File

@ -66,7 +66,13 @@ int cmd_commit_tree(int argc, const char **argv, const char *prefix)
continue; continue;
} }
if (skip_prefix(arg, "-S", &sign_commit)) if (!strcmp(arg, "--gpg-sign")) {
sign_commit = "";
continue;
}
if (skip_prefix(arg, "-S", &sign_commit) ||
skip_prefix(arg, "--gpg-sign=", &sign_commit))
continue; continue;
if (!strcmp(arg, "--no-gpg-sign")) { if (!strcmp(arg, "--no-gpg-sign")) {

View File

@ -49,15 +49,28 @@ test_expect_success GPG 'create signed commits' '
git tag eighth-signed-alt && git tag eighth-signed-alt &&
# commit.gpgsign is still on but this must not be signed # commit.gpgsign is still on but this must not be signed
git tag ninth-unsigned $(echo 9 | git commit-tree HEAD^{tree}) && echo 9 | git commit-tree HEAD^{tree} >oid &&
test_line_count = 1 oid &&
git tag ninth-unsigned $(cat oid) &&
# explicit -S of course must sign. # explicit -S of course must sign.
git tag tenth-signed $(echo 9 | git commit-tree -S HEAD^{tree}) echo 10 | git commit-tree -S HEAD^{tree} >oid &&
test_line_count = 1 oid &&
git tag tenth-signed $(cat oid) &&
# --gpg-sign[=<key-id>] must sign.
echo 11 | git commit-tree --gpg-sign HEAD^{tree} >oid &&
test_line_count = 1 oid &&
git tag eleventh-signed $(cat oid) &&
echo 12 | git commit-tree --gpg-sign=B7227189 HEAD^{tree} >oid &&
test_line_count = 1 oid &&
git tag twelfth-signed-alt $(cat oid)
' '
test_expect_success GPG 'verify and show signatures' ' test_expect_success GPG 'verify and show signatures' '
( (
for commit in initial second merge fourth-signed \ for commit in initial second merge fourth-signed \
fifth-signed sixth-signed seventh-signed tenth-signed fifth-signed sixth-signed seventh-signed tenth-signed \
eleventh-signed
do do
git verify-commit $commit && git verify-commit $commit &&
git show --pretty=short --show-signature $commit >actual && git show --pretty=short --show-signature $commit >actual &&
@ -78,7 +91,7 @@ test_expect_success GPG 'verify and show signatures' '
done done
) && ) &&
( (
for commit in eighth-signed-alt for commit in eighth-signed-alt twelfth-signed-alt
do do
git show --pretty=short --show-signature $commit >actual && git show --pretty=short --show-signature $commit >actual &&
grep "Good signature from" actual && grep "Good signature from" actual &&