summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarlos Martín Nieto <cmn@dwim.me>2014-09-10 18:13:34 +0200
committerCarlos Martín Nieto <cmn@dwim.me>2014-09-10 18:14:46 +0200
commit76e3c43fb99eb75cf33affb1a93260af4d472da5 (patch)
treefcb4c2fa8629c5715dfe5f46a5723418909c05fa
parent31e752b6546537bbeee89b6d2f3027cf0eff9a53 (diff)
downloadlibgit2-cmn/signature-empty-email.tar.gz
signature: don't allow empty emailscmn/signature-empty-email
A signature is made up of a non-empty name and a non-empty email so let's validate that. This also brings us more in line with git, which also rejects ident with an empty email.
-rw-r--r--src/signature.c4
-rw-r--r--tests/commit/signature.c4
2 files changed, 4 insertions, 4 deletions
diff --git a/src/signature.c b/src/signature.c
index 2545b7519..2a16b484a 100644
--- a/src/signature.c
+++ b/src/signature.c
@@ -70,9 +70,9 @@ int git_signature_new(git_signature **sig_out, const char *name, const char *ema
if (p->name == NULL || p->email == NULL)
return -1; /* oom */
- if (p->name[0] == '\0') {
+ if (p->name[0] == '\0' || p->email[0] == '\0') {
git_signature_free(p);
- return signature_error("Signature cannot have an empty name");
+ return signature_error("Signature cannot have an empty name or email");
}
p->when.time = time;
diff --git a/tests/commit/signature.c b/tests/commit/signature.c
index e9dcfab41..41a74b999 100644
--- a/tests/commit/signature.c
+++ b/tests/commit/signature.c
@@ -56,8 +56,8 @@ void test_commit_signature__create_empties(void)
cl_git_fail(try_build_signature("", "emeric.fermas@gmail.com", 1234567890, 60));
cl_git_fail(try_build_signature(" ", "emeric.fermas@gmail.com", 1234567890, 60));
- cl_git_pass(try_build_signature("nulltoken", "", 1234567890, 60));
- cl_git_pass(try_build_signature("nulltoken", " ", 1234567890, 60));
+ cl_git_fail(try_build_signature("nulltoken", "", 1234567890, 60));
+ cl_git_fail(try_build_signature("nulltoken", " ", 1234567890, 60));
}
void test_commit_signature__create_one_char(void)