diff options
author | Jeffrey Stedfast <fejj@ximian.com> | 2001-04-10 23:47:00 +0800 |
---|---|---|
committer | Jeffrey Stedfast <fejj@src.gnome.org> | 2001-04-10 23:47:00 +0800 |
commit | eee943f21ebc92e70cec963950c2fc0a29cab544 (patch) | |
tree | df2c372bcf6ea6cf9dad5c37a38e132d11d8625a /camel/tests/smime/pgp.c | |
parent | bcc5969a21062e0e24bb5544df44a5accc0570e6 (diff) | |
download | gsoc2013-evolution-eee943f21ebc92e70cec963950c2fc0a29cab544.tar.gz gsoc2013-evolution-eee943f21ebc92e70cec963950c2fc0a29cab544.tar.zst gsoc2013-evolution-eee943f21ebc92e70cec963950c2fc0a29cab544.zip |
Added camel-pgp-context.[c,h] to the build. Also added tests/smime/pgp.c
2001-04-06 Jeffrey Stedfast <fejj@ximian.com>
* Makefile.am: Added camel-pgp-context.[c,h] to the build. Also
added tests/smime/pgp.c and Makefile.am
* tests/smime/pgp.c: New test suite for PGP functions.
* camel-pgp-context.c: Various fixes to get it to build.
svn path=/trunk/; revision=9213
Diffstat (limited to 'camel/tests/smime/pgp.c')
-rw-r--r-- | camel/tests/smime/pgp.c | 110 |
1 files changed, 110 insertions, 0 deletions
diff --git a/camel/tests/smime/pgp.c b/camel/tests/smime/pgp.c new file mode 100644 index 0000000000..86e419e680 --- /dev/null +++ b/camel/tests/smime/pgp.c @@ -0,0 +1,110 @@ +#include <config.h> + +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <camel/camel-pgp-context.h> +#include <camel/camel-stream-mem.h> + +#include "camel-test.h" + +/* god, who designed this horrid interface */ +static gpointer auth_callback (CamelAuthCallbackMode mode, + char *data, gboolean secret, + CamelService *service, char *item, + CamelException *ex) +{ + return g_strdup ("PGP/MIME is rfc2015, now go and read it."); +} + +int main (int argc, char **argv) +{ + CamelSession *session; + CamelPgpContext *ctx; + CamelException *ex; + CamelPgpValidity *valid; + CamelStream *stream1, *stream2, *stream3; + GPtrArray *recipients; + GByteArray *buf; + char *before, *after; + + camel_test_init (argc, argv); + + ex = camel_exception_new (); + + /* clear out any camel-test data */ + system("/bin/rm -rf /tmp/camel-test"); + + session = camel_session_new ("/tmp/camel-test", + auth_callback, NULL, NULL); + + ctx = camel_pgp_context_new (session, CAMEL_PGP_TYPE_GPG, "/usr/bin/gpg"); + + camel_test_start ("Test of PGP functions"); + + stream1 = camel_stream_mem_new (); + camel_stream_write (stream1, "Hello, I am a test stream.", 25); + camel_stream_reset (stream1); + + stream2 = camel_stream_mem_new (); + + camel_test_push ("PGP signing"); + camel_pgp_sign (ctx, "pgp-mime@xtorshun.org", CAMEL_PGP_HASH_TYPE_SHA1, + stream1, stream2, ex); + check_msg (!camel_exception_is_set (ex), "%s", camel_exception_get_description (ex)); + camel_test_pull (); + + camel_exception_clear (ex); + + camel_test_push ("PGP verify"); + camel_stream_reset (stream1); + camel_stream_reset (stream2); + valid = camel_pgp_verify (ctx, stream1, stream2, ex); + check_msg (!camel_exception_is_set (ex), "%s", camel_exception_get_description (ex)); + check_msg (camel_pgp_validity_get_valid (valid), "%s", camel_pgp_validity_get_description (valid)); + camel_pgp_validity_free (valid); + camel_test_pull (); + + camel_object_unref (CAMEL_OBJECT (stream1)); + camel_object_unref (CAMEL_OBJECT (stream2)); + + stream1 = camel_stream_mem_new (); + stream2 = camel_stream_mem_new (); + stream3 = camel_stream_mem_new (); + + camel_stream_write (stream1, "Hello, I am a test of encryption/decryption.", 44); + camel_stream_reset (stream1); + + camel_exception_clear (ex); + + camel_test_push ("PGP encrypt"); + recipients = g_ptr_array_new (); + g_ptr_array_add (recipients, "pgp-mime@xtorshun.org"); + camel_pgp_encrypt (ctx, FALSE, "pgp-mime@xtorshun.org", recipients, + stream1, stream2, ex); + check_msg (!camel_exception_is_set (ex), "%s", camel_exception_get_description (ex)); + g_ptr_array_free (recipients, TRUE); + camel_test_pull (); + + camel_stream_reset (stream2); + camel_exception_clear (ex); + + camel_test_push ("PGP decrypt"); + camel_pgp_decrypt (ctx, stream2, stream3, ex); + check_msg (!camel_exception_is_set (ex), "%s", camel_exception_get_description (ex)); + buf = CAMEL_STREAM_MEM (stream1)->buffer; + before = g_strndup (buf->data, buf->len); + buf = CAMEL_STREAM_MEM (stream3)->buffer; + after = g_strndup (buf->data, buf->len); + check_msg (string_equal (before, after), "before = '%s', after = '%s'", before, after); + g_free (before); + g_free (after); + camel_test_pull (); + + camel_object_unref (CAMEL_OBJECT (ctx)); + camel_object_unref (CAMEL_OBJECT (session)); + + camel_test_end (); + + return 0; +} |