Merge branch 'bc/mktag'
* bc/mktag: mktag.c: tweak validation of tagger field and adjust test script mktag.c: improve verification of tagger field and tests
This commit is contained in:
commit
5fbd0a44cf
60
mktag.c
60
mktag.c
@ -8,10 +8,11 @@
|
|||||||
* message and a signature block that git itself doesn't care about,
|
* message and a signature block that git itself doesn't care about,
|
||||||
* but that can be verified with gpg or similar.
|
* but that can be verified with gpg or similar.
|
||||||
*
|
*
|
||||||
* The first three lines are guaranteed to be at least 63 bytes:
|
* The first four lines are guaranteed to be at least 83 bytes:
|
||||||
* "object <sha1>\n" is 48 bytes, "type tag\n" at 9 bytes is the
|
* "object <sha1>\n" is 48 bytes, "type tag\n" at 9 bytes is the
|
||||||
* shortest possible type-line, and "tag .\n" at 6 bytes is the
|
* shortest possible type-line, "tag .\n" at 6 bytes is the shortest
|
||||||
* shortest single-character-tag line.
|
* single-character-tag line, and "tagger . <> 0 +0000\n" at 20 bytes is
|
||||||
|
* the shortest possible tagger-line.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -43,9 +44,10 @@ static int verify_tag(char *buffer, unsigned long size)
|
|||||||
int typelen;
|
int typelen;
|
||||||
char type[20];
|
char type[20];
|
||||||
unsigned char sha1[20];
|
unsigned char sha1[20];
|
||||||
const char *object, *type_line, *tag_line, *tagger_line;
|
const char *object, *type_line, *tag_line, *tagger_line, *lb, *rb;
|
||||||
|
size_t len;
|
||||||
|
|
||||||
if (size < 64)
|
if (size < 84)
|
||||||
return error("wanna fool me ? you obviously got the size wrong !");
|
return error("wanna fool me ? you obviously got the size wrong !");
|
||||||
|
|
||||||
buffer[size] = 0;
|
buffer[size] = 0;
|
||||||
@ -97,11 +99,51 @@ static int verify_tag(char *buffer, unsigned long size)
|
|||||||
/* Verify the tagger line */
|
/* Verify the tagger line */
|
||||||
tagger_line = tag_line;
|
tagger_line = tag_line;
|
||||||
|
|
||||||
if (memcmp(tagger_line, "tagger", 6) || (tagger_line[6] == '\n'))
|
if (memcmp(tagger_line, "tagger ", 7))
|
||||||
return error("char" PD_FMT ": could not find \"tagger\"", tagger_line - buffer);
|
return error("char" PD_FMT ": could not find \"tagger \"",
|
||||||
|
tagger_line - buffer);
|
||||||
|
|
||||||
/* TODO: check for committer info + blank line? */
|
/*
|
||||||
/* Also, the minimum length is probably + "tagger .", or 63+8=71 */
|
* Check for correct form for name and email
|
||||||
|
* i.e. " <" followed by "> " on _this_ line
|
||||||
|
* No angle brackets within the name or email address fields.
|
||||||
|
* No spaces within the email address field.
|
||||||
|
*/
|
||||||
|
tagger_line += 7;
|
||||||
|
if (!(lb = strstr(tagger_line, " <")) || !(rb = strstr(lb+2, "> ")) ||
|
||||||
|
strpbrk(tagger_line, "<>\n") != lb+1 ||
|
||||||
|
strpbrk(lb+2, "><\n ") != rb)
|
||||||
|
return error("char" PD_FMT ": malformed tagger field",
|
||||||
|
tagger_line - buffer);
|
||||||
|
|
||||||
|
/* Check for author name, at least one character, space is acceptable */
|
||||||
|
if (lb == tagger_line)
|
||||||
|
return error("char" PD_FMT ": missing tagger name",
|
||||||
|
tagger_line - buffer);
|
||||||
|
|
||||||
|
/* timestamp, 1 or more digits followed by space */
|
||||||
|
tagger_line = rb + 2;
|
||||||
|
if (!(len = strspn(tagger_line, "0123456789")))
|
||||||
|
return error("char" PD_FMT ": missing tag timestamp",
|
||||||
|
tagger_line - buffer);
|
||||||
|
tagger_line += len;
|
||||||
|
if (*tagger_line != ' ')
|
||||||
|
return error("char" PD_FMT ": malformed tag timestamp",
|
||||||
|
tagger_line - buffer);
|
||||||
|
tagger_line++;
|
||||||
|
|
||||||
|
/* timezone, 5 digits [+-]hhmm, max. 1400 */
|
||||||
|
if (!((tagger_line[0] == '+' || tagger_line[0] == '-') &&
|
||||||
|
strspn(tagger_line+1, "0123456789") == 4 &&
|
||||||
|
tagger_line[5] == '\n' && atoi(tagger_line+1) <= 1400))
|
||||||
|
return error("char" PD_FMT ": malformed tag timezone",
|
||||||
|
tagger_line - buffer);
|
||||||
|
tagger_line += 6;
|
||||||
|
|
||||||
|
/* Verify the blank line separating the header from the body */
|
||||||
|
if (*tagger_line != '\n')
|
||||||
|
return error("char" PD_FMT ": trailing garbage in tag header",
|
||||||
|
tagger_line - buffer);
|
||||||
|
|
||||||
/* The actual stuff afterwards we don't care about.. */
|
/* The actual stuff afterwards we don't care about.. */
|
||||||
return 0;
|
return 0;
|
||||||
|
181
t/t3800-mktag.sh
181
t/t3800-mktag.sh
@ -44,6 +44,8 @@ cat >tag.sig <<EOF
|
|||||||
xxxxxx 139e9b33986b1c2670fff52c5067603117b3e895
|
xxxxxx 139e9b33986b1c2670fff52c5067603117b3e895
|
||||||
type tag
|
type tag
|
||||||
tag mytag
|
tag mytag
|
||||||
|
tagger . <> 0 +0000
|
||||||
|
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
check_verify_failure '"object" line label check' '^error: char0: .*"object "$'
|
check_verify_failure '"object" line label check' '^error: char0: .*"object "$'
|
||||||
@ -55,6 +57,8 @@ cat >tag.sig <<EOF
|
|||||||
object zz9e9b33986b1c2670fff52c5067603117b3e895
|
object zz9e9b33986b1c2670fff52c5067603117b3e895
|
||||||
type tag
|
type tag
|
||||||
tag mytag
|
tag mytag
|
||||||
|
tagger . <> 0 +0000
|
||||||
|
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
check_verify_failure '"object" line SHA1 check' '^error: char7: .*SHA1 hash$'
|
check_verify_failure '"object" line SHA1 check' '^error: char7: .*SHA1 hash$'
|
||||||
@ -66,6 +70,8 @@ cat >tag.sig <<EOF
|
|||||||
object 779e9b33986b1c2670fff52c5067603117b3e895
|
object 779e9b33986b1c2670fff52c5067603117b3e895
|
||||||
xxxx tag
|
xxxx tag
|
||||||
tag mytag
|
tag mytag
|
||||||
|
tagger . <> 0 +0000
|
||||||
|
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
check_verify_failure '"type" line label check' '^error: char47: .*"\\ntype "$'
|
check_verify_failure '"type" line label check' '^error: char47: .*"\\ntype "$'
|
||||||
@ -85,6 +91,8 @@ cat >tag.sig <<EOF
|
|||||||
object 779e9b33986b1c2670fff52c5067603117b3e895
|
object 779e9b33986b1c2670fff52c5067603117b3e895
|
||||||
type tag
|
type tag
|
||||||
xxx mytag
|
xxx mytag
|
||||||
|
tagger . <> 0 +0000
|
||||||
|
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
check_verify_failure '"tag" line label check #1' \
|
check_verify_failure '"tag" line label check #1' \
|
||||||
@ -121,6 +129,8 @@ cat >tag.sig <<EOF
|
|||||||
object 779e9b33986b1c2670fff52c5067603117b3e895
|
object 779e9b33986b1c2670fff52c5067603117b3e895
|
||||||
type tagggg
|
type tagggg
|
||||||
tag mytag
|
tag mytag
|
||||||
|
tagger . <> 0 +0000
|
||||||
|
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
check_verify_failure 'verify object (SHA1/type) check' \
|
check_verify_failure 'verify object (SHA1/type) check' \
|
||||||
@ -133,6 +143,8 @@ cat >tag.sig <<EOF
|
|||||||
object $head
|
object $head
|
||||||
type commit
|
type commit
|
||||||
tag my tag
|
tag my tag
|
||||||
|
tagger . <> 0 +0000
|
||||||
|
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
check_verify_failure 'verify tag-name check' \
|
check_verify_failure 'verify tag-name check' \
|
||||||
@ -145,6 +157,8 @@ cat >tag.sig <<EOF
|
|||||||
object $head
|
object $head
|
||||||
type commit
|
type commit
|
||||||
tag mytag
|
tag mytag
|
||||||
|
|
||||||
|
This is filler
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
check_verify_failure '"tagger" line label check #1' \
|
check_verify_failure '"tagger" line label check #1' \
|
||||||
@ -158,19 +172,180 @@ object $head
|
|||||||
type commit
|
type commit
|
||||||
tag mytag
|
tag mytag
|
||||||
tagger
|
tagger
|
||||||
|
|
||||||
|
This is filler
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
check_verify_failure '"tagger" line label check #2' \
|
check_verify_failure '"tagger" line label check #2' \
|
||||||
'^error: char70: could not find "tagger "$'
|
'^error: char70: could not find "tagger "$'
|
||||||
|
|
||||||
############################################################
|
############################################################
|
||||||
# 13. create valid tag
|
# 13. disallow missing tag author name
|
||||||
|
|
||||||
cat >tag.sig <<EOF
|
cat >tag.sig <<EOF
|
||||||
object $head
|
object $head
|
||||||
type commit
|
type commit
|
||||||
tag mytag
|
tag mytag
|
||||||
tagger another@example.com
|
tagger <> 0 +0000
|
||||||
|
|
||||||
|
This is filler
|
||||||
|
EOF
|
||||||
|
|
||||||
|
check_verify_failure 'disallow missing tag author name' \
|
||||||
|
'^error: char77: missing tagger name$'
|
||||||
|
|
||||||
|
############################################################
|
||||||
|
# 14. disallow missing tag author name
|
||||||
|
|
||||||
|
cat >tag.sig <<EOF
|
||||||
|
object $head
|
||||||
|
type commit
|
||||||
|
tag mytag
|
||||||
|
tagger T A Gger <
|
||||||
|
> 0 +0000
|
||||||
|
|
||||||
|
EOF
|
||||||
|
|
||||||
|
check_verify_failure 'disallow malformed tagger' \
|
||||||
|
'^error: char77: malformed tagger field$'
|
||||||
|
|
||||||
|
############################################################
|
||||||
|
# 15. allow empty tag email
|
||||||
|
|
||||||
|
cat >tag.sig <<EOF
|
||||||
|
object $head
|
||||||
|
type commit
|
||||||
|
tag mytag
|
||||||
|
tagger T A Gger <> 0 +0000
|
||||||
|
|
||||||
|
EOF
|
||||||
|
|
||||||
|
test_expect_success \
|
||||||
|
'allow empty tag email' \
|
||||||
|
'git-mktag <tag.sig >.git/refs/tags/mytag 2>message'
|
||||||
|
|
||||||
|
############################################################
|
||||||
|
# 16. disallow spaces in tag email
|
||||||
|
|
||||||
|
cat >tag.sig <<EOF
|
||||||
|
object $head
|
||||||
|
type commit
|
||||||
|
tag mytag
|
||||||
|
tagger T A Gger <tag ger@example.com> 0 +0000
|
||||||
|
|
||||||
|
EOF
|
||||||
|
|
||||||
|
check_verify_failure 'disallow spaces in tag email' \
|
||||||
|
'^error: char77: malformed tagger field$'
|
||||||
|
|
||||||
|
############################################################
|
||||||
|
# 17. disallow missing tag timestamp
|
||||||
|
|
||||||
|
cat >tag.sig <<EOF
|
||||||
|
object $head
|
||||||
|
type commit
|
||||||
|
tag mytag
|
||||||
|
tagger T A Gger <tagger@example.com>
|
||||||
|
|
||||||
|
EOF
|
||||||
|
|
||||||
|
check_verify_failure 'disallow missing tag timestamp' \
|
||||||
|
'^error: char107: missing tag timestamp$'
|
||||||
|
|
||||||
|
############################################################
|
||||||
|
# 18. detect invalid tag timestamp1
|
||||||
|
|
||||||
|
cat >tag.sig <<EOF
|
||||||
|
object $head
|
||||||
|
type commit
|
||||||
|
tag mytag
|
||||||
|
tagger T A Gger <tagger@example.com> Tue Mar 25 15:47:44 2008
|
||||||
|
|
||||||
|
EOF
|
||||||
|
|
||||||
|
check_verify_failure 'detect invalid tag timestamp1' \
|
||||||
|
'^error: char107: missing tag timestamp$'
|
||||||
|
|
||||||
|
############################################################
|
||||||
|
# 19. detect invalid tag timestamp2
|
||||||
|
|
||||||
|
cat >tag.sig <<EOF
|
||||||
|
object $head
|
||||||
|
type commit
|
||||||
|
tag mytag
|
||||||
|
tagger T A Gger <tagger@example.com> 2008-03-31T12:20:15-0500
|
||||||
|
|
||||||
|
EOF
|
||||||
|
|
||||||
|
check_verify_failure 'detect invalid tag timestamp2' \
|
||||||
|
'^error: char111: malformed tag timestamp$'
|
||||||
|
|
||||||
|
############################################################
|
||||||
|
# 20. detect invalid tag timezone1
|
||||||
|
|
||||||
|
cat >tag.sig <<EOF
|
||||||
|
object $head
|
||||||
|
type commit
|
||||||
|
tag mytag
|
||||||
|
tagger T A Gger <tagger@example.com> 1206478233 GMT
|
||||||
|
|
||||||
|
EOF
|
||||||
|
|
||||||
|
check_verify_failure 'detect invalid tag timezone1' \
|
||||||
|
'^error: char118: malformed tag timezone$'
|
||||||
|
|
||||||
|
############################################################
|
||||||
|
# 21. detect invalid tag timezone2
|
||||||
|
|
||||||
|
cat >tag.sig <<EOF
|
||||||
|
object $head
|
||||||
|
type commit
|
||||||
|
tag mytag
|
||||||
|
tagger T A Gger <tagger@example.com> 1206478233 + 30
|
||||||
|
|
||||||
|
EOF
|
||||||
|
|
||||||
|
check_verify_failure 'detect invalid tag timezone2' \
|
||||||
|
'^error: char118: malformed tag timezone$'
|
||||||
|
|
||||||
|
############################################################
|
||||||
|
# 22. detect invalid tag timezone3
|
||||||
|
|
||||||
|
cat >tag.sig <<EOF
|
||||||
|
object $head
|
||||||
|
type commit
|
||||||
|
tag mytag
|
||||||
|
tagger T A Gger <tagger@example.com> 1206478233 -1430
|
||||||
|
|
||||||
|
EOF
|
||||||
|
|
||||||
|
check_verify_failure 'detect invalid tag timezone3' \
|
||||||
|
'^error: char118: malformed tag timezone$'
|
||||||
|
|
||||||
|
############################################################
|
||||||
|
# 23. detect invalid header entry
|
||||||
|
|
||||||
|
cat >tag.sig <<EOF
|
||||||
|
object $head
|
||||||
|
type commit
|
||||||
|
tag mytag
|
||||||
|
tagger T A Gger <tagger@example.com> 1206478233 -0500
|
||||||
|
this line should not be here
|
||||||
|
|
||||||
|
EOF
|
||||||
|
|
||||||
|
check_verify_failure 'detect invalid header entry' \
|
||||||
|
'^error: char124: trailing garbage in tag header$'
|
||||||
|
|
||||||
|
############################################################
|
||||||
|
# 24. create valid tag
|
||||||
|
|
||||||
|
cat >tag.sig <<EOF
|
||||||
|
object $head
|
||||||
|
type commit
|
||||||
|
tag mytag
|
||||||
|
tagger T A Gger <tagger@example.com> 1206478233 -0500
|
||||||
|
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
test_expect_success \
|
test_expect_success \
|
||||||
@ -178,7 +353,7 @@ test_expect_success \
|
|||||||
'git-mktag <tag.sig >.git/refs/tags/mytag 2>message'
|
'git-mktag <tag.sig >.git/refs/tags/mytag 2>message'
|
||||||
|
|
||||||
############################################################
|
############################################################
|
||||||
# 14. check mytag
|
# 25. check mytag
|
||||||
|
|
||||||
test_expect_success \
|
test_expect_success \
|
||||||
'check mytag' \
|
'check mytag' \
|
||||||
|
Loading…
Reference in New Issue
Block a user