-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
verify-tag was lacking tests. Add some, mirroring those used for verify-commit. Signed-off-by: brian m. carlson <sandals@crustytoothpaste.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
- Loading branch information
brian m. carlson
authored and
Junio C Hamano
committed
Jun 22, 2015
1 parent
3d4a3ff
commit d66aeff
Showing
1 changed file
with
84 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,84 @@ | ||
#!/bin/sh | ||
|
||
test_description='signed tag tests' | ||
. ./test-lib.sh | ||
. "$TEST_DIRECTORY/lib-gpg.sh" | ||
|
||
test_expect_success GPG 'create signed tags' ' | ||
echo 1 >file && git add file && | ||
test_tick && git commit -m initial && | ||
git tag -s -m initial initial && | ||
git branch side && | ||
echo 2 >file && test_tick && git commit -a -m second && | ||
git tag -s -m second second && | ||
git checkout side && | ||
echo 3 >elif && git add elif && | ||
test_tick && git commit -m "third on side" && | ||
git checkout master && | ||
test_tick && git merge -S side && | ||
git tag -s -m merge merge && | ||
echo 4 >file && test_tick && git commit -a -S -m "fourth unsigned" && | ||
git tag -a -m fourth-unsigned fourth-unsigned && | ||
test_tick && git commit --amend -S -m "fourth signed" && | ||
git tag -s -m fourth fourth-signed && | ||
echo 5 >file && test_tick && git commit -a -m "fifth" && | ||
git tag fifth-unsigned && | ||
git config commit.gpgsign true && | ||
echo 6 >file && test_tick && git commit -a -m "sixth" && | ||
git tag -a -m sixth sixth-unsigned && | ||
test_tick && git rebase -f HEAD^^ && git tag -s -m 6th sixth-signed HEAD^ && | ||
git tag -m seventh -s seventh-signed && | ||
echo 8 >file && test_tick && git commit -a -m eighth && | ||
git tag -uB7227189 -m eighth eighth-signed-alt | ||
' | ||
|
||
test_expect_success GPG 'verify and show signatures' ' | ||
( | ||
for tag in initial second merge fourth-signed sixth-signed seventh-signed | ||
do | ||
git verify-tag $tag 2>actual && | ||
grep "Good signature from" actual && | ||
! grep "BAD signature from" actual && | ||
echo $tag OK || exit 1 | ||
done | ||
) && | ||
( | ||
for tag in fourth-unsigned fifth-unsigned sixth-unsigned | ||
do | ||
test_must_fail git verify-tag $tag 2>actual && | ||
! grep "Good signature from" actual && | ||
! grep "BAD signature from" actual && | ||
echo $tag OK || exit 1 | ||
done | ||
) && | ||
( | ||
for tag in eighth-signed-alt | ||
do | ||
git verify-tag $tag 2>actual && | ||
grep "Good signature from" actual && | ||
! grep "BAD signature from" actual && | ||
grep "not certified" actual && | ||
echo $tag OK || exit 1 | ||
done | ||
) | ||
' | ||
|
||
test_expect_success GPG 'detect fudged signature' ' | ||
git cat-file tag seventh-signed >raw && | ||
sed -e "s/seventh/7th forged/" raw >forged1 && | ||
git hash-object -w -t tag forged1 >forged1.tag && | ||
test_must_fail git verify-tag $(cat forged1.tag) 2>actual1 && | ||
grep "BAD signature from" actual1 && | ||
! grep "Good signature from" actual1 | ||
' | ||
|
||
test_done |