[gmime] Added unit tests for application/pkcs7-mime
- From: Jeffrey Stedfast <fejj src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gmime] Added unit tests for application/pkcs7-mime
- Date: Sat, 11 Mar 2017 19:20:25 +0000 (UTC)
commit 22465c9d800bf7b12cca4661e63cbe4fed46da1f
Author: Jeffrey Stedfast <jestedfa microsoft com>
Date: Sat Mar 11 11:53:57 2017 -0500
Added unit tests for application/pkcs7-mime
tests/test-smime.c | 287 +++++++++++++++++++++++++++-------------------------
1 files changed, 149 insertions(+), 138 deletions(-)
---
diff --git a/tests/test-smime.c b/tests/test-smime.c
index 9b01625..c1854bb 100644
--- a/tests/test-smime.c
+++ b/tests/test-smime.c
@@ -36,8 +36,6 @@
#include "testsuite.h"
-#define GPG_PATH "/usr/bin/gpg"
-
extern int verbose;
#define v(x) if (verbose > 3) x
@@ -150,44 +148,14 @@ print_verify_results (GMimeSignatureList *signatures)
}
}
-#define MULTIPART_SIGNED_CONTENT "This is a test of the emergency broadcast system \
-with an sha1 detach-sign.\n\nFrom now on, there will be text to try and break \t\
- \nvarious things. For example, the F in \"From\" in the previous line...\n...and \
-the first dot of this line have been pre-encoded in the QP encoding in order to test \
-that GMime properly treats MIME part content as opaque.\nIf this still verifies okay, \
-then we have ourselves a winner I guess...\n"
-
-static void
-test_multipart_signed (GMimeCryptoContext *ctx)
+static GMimeMessage *
+create_message (GMimeObject *body)
{
- GMimeSignatureList *signatures;
- GMimeMultipartSigned *mps;
InternetAddressList *list;
InternetAddress *mailbox;
GMimeMessage *message;
- GMimeStream *stream;
GMimeParser *parser;
- GMimeTextPart *part;
- GError *err = NULL;
- Exception *ex;
-
- part = g_mime_text_part_new_with_subtype ("plain");
- g_mime_text_part_set_text (part, MULTIPART_SIGNED_CONTENT);
-
- /* create the multipart/signed container part */
- mps = g_mime_multipart_signed_new ();
-
- /* sign the part */
- g_mime_multipart_signed_sign (mps, GMIME_OBJECT (part), ctx, "alice example net",
- GMIME_DIGEST_ALGO_SHA1, &err);
- g_object_unref (part);
-
- if (err != NULL) {
- ex = exception_new ("signing failed: %s", err->message);
- g_object_unref (mps);
- g_error_free (err);
- throw (ex);
- }
+ GMimeStream *stream;
message = g_mime_message_new (TRUE);
@@ -208,8 +176,7 @@ test_multipart_signed (GMimeCryptoContext *ctx)
g_mime_message_set_subject (message, "This is a test message", NULL);
g_mime_object_set_header ((GMimeObject *) message, "X-Mailer", "main.c");
- g_mime_message_set_mime_part (message, GMIME_OBJECT (mps));
- g_object_unref (mps);
+ g_mime_message_set_mime_part (message, body);
stream = g_mime_stream_mem_new ();
g_mime_object_write_to_stream ((GMimeObject *) message, stream);
@@ -223,6 +190,47 @@ test_multipart_signed (GMimeCryptoContext *ctx)
message = g_mime_parser_construct_message (parser);
g_object_unref (parser);
+ return message;
+}
+
+#define MULTIPART_SIGNED_CONTENT "This is a test of the emergency broadcast system \
+with an sha1 detach-sign.\n\nFrom now on, there will be text to try and break \t\
+ \nvarious things. For example, the F in \"From\" in the previous line...\n...and \
+the first dot of this line have been pre-encoded in the QP encoding in order to test \
+that GMime properly treats MIME part content as opaque.\nIf this still verifies okay, \
+then we have ourselves a winner I guess...\n"
+
+static void
+test_multipart_signed (GMimeCryptoContext *ctx)
+{
+ GMimeSignatureList *signatures;
+ GMimeMultipartSigned *mps;
+ GMimeMessage *message;
+ GMimeTextPart *part;
+ GError *err = NULL;
+ Exception *ex;
+
+ part = g_mime_text_part_new_with_subtype ("plain");
+ g_mime_text_part_set_text (part, MULTIPART_SIGNED_CONTENT);
+
+ /* create the multipart/signed container part */
+ mps = g_mime_multipart_signed_new ();
+
+ /* sign the part */
+ g_mime_multipart_signed_sign (mps, GMIME_OBJECT (part), ctx, "mimekit example com",
+ GMIME_DIGEST_ALGO_SHA1, &err);
+ g_object_unref (part);
+
+ if (err != NULL) {
+ ex = exception_new ("signing failed: %s", err->message);
+ g_object_unref (mps);
+ g_error_free (err);
+ throw (ex);
+ }
+
+ message = create_message ((GMimeObject *) mps);
+ g_object_unref (mps);
+
if (!GMIME_IS_MULTIPART_SIGNED (message->mime_part)) {
ex = exception_new ("resultant top-level mime part not a multipart/signed?");
g_object_unref (message);
@@ -231,10 +239,8 @@ test_multipart_signed (GMimeCryptoContext *ctx)
mps = (GMimeMultipartSigned *) message->mime_part;
- v(fputs ("Trying to verify signature... ", stdout));
if (!(signatures = g_mime_multipart_signed_verify (mps, 0, &err))) {
ex = exception_new ("%s", err->message);
- v(fputs ("failed.\n", stdout));
g_error_free (err);
throw (ex);
}
@@ -245,139 +251,144 @@ test_multipart_signed (GMimeCryptoContext *ctx)
g_object_unref (message);
}
-#define MULTIPART_ENCRYPTED_CONTENT "This is a test of multipart/encrypted.\n"
+#define SIGNED_CONTENT "This is a test of application/pkcs7-mime; smime-type=signed-data.\n"
static void
-test_multipart_encrypted (GMimeCryptoContext *ctx, gboolean sign)
+test_pkcs7_mime_sign (void)
{
- GMimeSignatureStatus status;
- GMimeStream *cleartext, *stream;
- GMimeMultipartEncrypted *mpe;
- GMimeDecryptResult *result;
- InternetAddressList *list;
- InternetAddress *mailbox;
- GMimeObject *decrypted;
- GPtrArray *recipients;
+ GMimeApplicationPkcs7Mime *pkcs7_mime;
+ GMimeSignatureList *signatures;
GMimeMessage *message;
- Exception *ex = NULL;
- GMimeParser *parser;
+ GMimeObject *entity;
GMimeTextPart *part;
- GByteArray *buf[2];
GError *err = NULL;
+ Exception *ex;
+ char *text;
part = g_mime_text_part_new ();
- g_mime_text_part_set_text (part, MULTIPART_ENCRYPTED_CONTENT);
-
- /* hold onto this for comparison later */
- cleartext = g_mime_stream_mem_new ();
- g_mime_object_write_to_stream ((GMimeObject *) part, cleartext);
- g_mime_stream_reset (cleartext);
+ g_mime_text_part_set_text (part, SIGNED_CONTENT);
- /* create the multipart/encrypted container part */
- mpe = g_mime_multipart_encrypted_new ();
-
- /* encrypt the part */
- recipients = g_ptr_array_new ();
- g_ptr_array_add (recipients, "alice example net");
- g_mime_multipart_encrypted_encrypt (mpe, GMIME_OBJECT (part), ctx, sign,
- "alice example net", GMIME_DIGEST_ALGO_SHA256,
- GMIME_ENCRYPT_FLAGS_ALWAYS_TRUST, recipients, &err);
- g_ptr_array_free (recipients, TRUE);
+ pkcs7_mime = g_mime_application_pkcs7_mime_sign ((GMimeObject *) part, "mimekit example com",
GMIME_DIGEST_ALGO_SHA1, &err);
g_object_unref (part);
if (err != NULL) {
- ex = exception_new ("encryption failed: %s", err->message);
- g_object_unref (cleartext);
- g_object_unref (mpe);
+ ex = exception_new ("sign failed: %s", err->message);
g_error_free (err);
throw (ex);
}
- message = g_mime_message_new (TRUE);
-
- mailbox = internet_address_mailbox_new ("Jeffrey Stedfast", "fejj helixcode com");
- list = g_mime_message_get_from (message);
- internet_address_list_add (list, mailbox);
- g_object_unref (mailbox);
+ message = create_message ((GMimeObject *) pkcs7_mime);
+ g_object_unref (pkcs7_mime);
- mailbox = internet_address_mailbox_new ("Jeffrey Stedfast", "fejj helixcode com");
- list = g_mime_message_get_reply_to (message);
- internet_address_list_add (list, mailbox);
- g_object_unref (mailbox);
+ if (!GMIME_IS_APPLICATION_PKCS7_MIME (message->mime_part)) {
+ ex = exception_new ("resultant top-level mime part not an application/pkcs7-mime?");
+ g_object_unref (message);
+ throw (ex);
+ }
- mailbox = internet_address_mailbox_new ("Federico Mena-Quintero", "federico helixcode com");
- list = g_mime_message_get_addresses (message, GMIME_ADDRESS_TYPE_TO);
- internet_address_list_add (list, mailbox);
- g_object_unref (mailbox);
+ pkcs7_mime = (GMimeApplicationPkcs7Mime *) message->mime_part;
- g_mime_message_set_subject (message, "This is a test message", NULL);
- g_mime_object_set_header ((GMimeObject *) message, "X-Mailer", "main.c");
- g_mime_message_set_mime_part (message, GMIME_OBJECT (mpe));
- g_object_unref (mpe);
+ if (!(signatures = g_mime_application_pkcs7_mime_verify (pkcs7_mime, 0, &entity, &err))) {
+ ex = exception_new ("verify failed: %s", err->message);
+ g_object_unref (message);
+ g_error_free (err);
+ throw (ex);
+ }
- stream = g_mime_stream_mem_new ();
- g_mime_object_write_to_stream ((GMimeObject *) message, stream);
- g_mime_stream_reset (stream);
+ v(print_verify_results (signatures));
+ g_object_unref (signatures);
g_object_unref (message);
- parser = g_mime_parser_new ();
- g_mime_parser_init_with_stream (parser, stream);
- g_object_unref (stream);
-
- message = g_mime_parser_construct_message (parser);
- g_object_unref (parser);
+ /* TODO: verify extracted content... */
+ if (!GMIME_IS_TEXT_PART (entity)) {
+ g_object_unref (entity);
+ throw (exception_new ("extracted entity was not a text/plain part?"));
+ }
- if (!GMIME_IS_MULTIPART_ENCRYPTED (message->mime_part)) {
- ex = exception_new ("resultant top-level mime part not a multipart/encrypted?");
- g_object_unref (message);
+ text = g_mime_text_part_get_text ((GMimeTextPart *) entity);
+ if (strcmp (SIGNED_CONTENT, text) != 0) {
+ ex = exception_new ("text part content does not match");
+ g_object_unref (entity);
+ g_free (text);
throw (ex);
}
- mpe = (GMimeMultipartEncrypted *) message->mime_part;
+ g_object_unref (entity);
+ g_free (text);
+}
+
+#define ENCRYPTED_CONTENT "This is a test of application/pkcs7-mime; smime-type=enveloped-data.\n"
+
+static void
+test_pkcs7_mime_encrypt (void)
+{
+ GMimeApplicationPkcs7Mime *pkcs7_mime;
+ GMimeDecryptResult *result;
+ GPtrArray *recipients;
+ GMimeMessage *message;
+ GMimeObject *entity;
+ GMimeTextPart *part;
+ GError *err = NULL;
+ Exception *ex;
+ char *text;
+
+ part = g_mime_text_part_new ();
+ g_mime_text_part_set_text (part, ENCRYPTED_CONTENT);
+
+ recipients = g_ptr_array_new ();
+ g_ptr_array_add (recipients, "mimekit example com");
+
+ pkcs7_mime = g_mime_application_pkcs7_mime_encrypt ((GMimeObject *) part,
GMIME_ENCRYPT_FLAGS_ALWAYS_TRUST, recipients, &err);
+ g_ptr_array_free (recipients, TRUE);
+ g_object_unref (part);
- /* okay, now to test our decrypt function... */
- decrypted = g_mime_multipart_encrypted_decrypt (mpe, 0, NULL, &result, &err);
- if (!decrypted || err != NULL) {
- ex = exception_new ("decryption failed: %s", err->message);
- g_object_unref (cleartext);
+ if (err != NULL) {
+ ex = exception_new ("encrypt failed: %s", err->message);
g_error_free (err);
throw (ex);
}
- if (result->signatures)
- v(print_verify_results (result->signatures));
+ message = create_message ((GMimeObject *) pkcs7_mime);
+ g_object_unref (pkcs7_mime);
- if (sign) {
- status = get_sig_status (result->signatures);
-
- if ((status & GMIME_SIGNATURE_STATUS_RED) != 0)
- ex = exception_new ("signature status expected to be GOOD");
- } else {
- if (result->signatures)
- ex = exception_new ("signature status expected to be NONE");
+ if (!GMIME_IS_APPLICATION_PKCS7_MIME (message->mime_part)) {
+ ex = exception_new ("resultant top-level mime part not an application/pkcs7-mime?");
+ g_object_unref (message);
+ throw (ex);
}
- g_object_unref (result);
+ pkcs7_mime = (GMimeApplicationPkcs7Mime *) message->mime_part;
- if (ex != NULL) {
- g_object_unref (cleartext);
+ if (!(entity = g_mime_application_pkcs7_mime_decrypt (pkcs7_mime, 0, NULL, &result, &err))) {
+ ex = exception_new ("decrypt failed: %s", err->message);
+ g_object_unref (message);
+ g_error_free (err);
throw (ex);
}
- stream = g_mime_stream_mem_new ();
- g_mime_object_write_to_stream (decrypted, stream);
+ g_object_unref (message);
- buf[0] = GMIME_STREAM_MEM (cleartext)->buffer;
- buf[1] = GMIME_STREAM_MEM (stream)->buffer;
+ if (result->signatures)
+ ex = exception_new ("signature status expected to be NONE");
- if (buf[0]->len != buf[1]->len || memcmp (buf[0]->data, buf[1]->data, buf[0]->len) != 0)
- ex = exception_new ("decrypted data does not match original cleartext");
+ g_object_unref (result);
- g_object_unref (cleartext);
- g_object_unref (stream);
+ /* TODO: verify decrypted content... */
+ if (!GMIME_IS_TEXT_PART (entity)) {
+ g_object_unref (entity);
+ throw (exception_new ("decrypted entity was not a text/plain part?"));
+ }
- if (ex != NULL)
+ text = g_mime_text_part_get_text ((GMimeTextPart *) entity);
+ if (strcmp (SIGNED_CONTENT, text) != 0) {
+ ex = exception_new ("text part content does not match");
+ g_object_unref (entity);
+ g_free (text);
throw (ex);
+ }
+
+ g_object_unref (entity);
+ g_free (text);
}
static void
@@ -414,7 +425,7 @@ int main (int argc, char *argv[])
testsuite_init (argc, argv);
- if (testsuite_setup_gpghome (GPG_PATH) != 0)
+ if (testsuite_setup_gpghome ("gpgsm") != 0)
return EXIT_FAILURE;
for (i = 1; i < argc; i++) {
@@ -434,11 +445,11 @@ int main (int argc, char *argv[])
testsuite_check ("GMimePkcs7Context::import");
try {
- key = g_build_filename (datadir, "gmime-cert.p7", NULL);
+ key = g_build_filename (datadir, "certificate-authority.crt", NULL);
import_key (ctx, key);
g_free (key);
- key = g_build_filename (datadir, "gmime-cert.p12", NULL);
+ key = g_build_filename (datadir, "smime.p12", NULL);
import_key (ctx, key);
g_free (key);
@@ -456,20 +467,20 @@ int main (int argc, char *argv[])
testsuite_check_failed ("multipart/signed failed: %s", ex->message);
} finally;
- testsuite_check ("multipart/encrypted");
+ testsuite_check ("application/pkcs7-mime; smime-type=signed-data");
try {
- test_multipart_encrypted (ctx, FALSE);
+ test_pkcs7_mime_sign ();
testsuite_check_passed ();
} catch (ex) {
- testsuite_check_failed ("multipart/encrypted failed: %s", ex->message);
+ testsuite_check_failed ("multipart/signed failed: %s", ex->message);
} finally;
- testsuite_check ("multipart/encrypted+sign");
+ testsuite_check ("application/pkcs7-mime; smime-type=enveloped-data");
try {
- test_multipart_encrypted (ctx, TRUE);
+ test_pkcs7_mime_encrypt ();
testsuite_check_passed ();
} catch (ex) {
- testsuite_check_failed ("multipart/encrypted+sign failed: %s", ex->message);
+ testsuite_check_failed ("multipart/encrypted failed: %s", ex->message);
} finally;
g_object_unref (ctx);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]