diff options
Diffstat (limited to 'camel/tests')
-rw-r--r-- | camel/tests/Makefile.am | 2 | ||||
-rw-r--r-- | camel/tests/smime/.cvsignore | 4 | ||||
-rw-r--r-- | camel/tests/smime/Makefile.am | 22 | ||||
-rw-r--r-- | camel/tests/smime/README | 2 | ||||
-rw-r--r-- | camel/tests/smime/pgp.c | 110 |
5 files changed, 139 insertions, 1 deletions
diff --git a/camel/tests/Makefile.am b/camel/tests/Makefile.am index 6125c6b134..1d24ebd0ac 100644 --- a/camel/tests/Makefile.am +++ b/camel/tests/Makefile.am @@ -1,3 +1,3 @@ SUBDIRS = lib \ - message folder stream misc + message folder stream smime misc diff --git a/camel/tests/smime/.cvsignore b/camel/tests/smime/.cvsignore new file mode 100644 index 0000000000..9dffc98fae --- /dev/null +++ b/camel/tests/smime/.cvsignore @@ -0,0 +1,4 @@ +.deps +.libs +Makefile* +pgp diff --git a/camel/tests/smime/Makefile.am b/camel/tests/smime/Makefile.am new file mode 100644 index 0000000000..8c6ead5418 --- /dev/null +++ b/camel/tests/smime/Makefile.am @@ -0,0 +1,22 @@ + +INCLUDES = -I$(top_srcdir)/intl -I$(top_srcdir) -I$(top_srcdir)/camel \ + -I$(includedir) \ + -I$(top_srcdir)/camel/tests/lib \ + -DG_LOG_DOMAIN=\"evolution-tests\" + +LDADD = \ + $(top_builddir)/camel/libcamel.la \ + $(top_builddir)/e-util/libeutil.la \ + $(top_builddir)/libibex/libibex.la \ + $(GNOME_LIBDIR) \ + $(top_builddir)/camel/tests/lib/libcameltest.a \ + $(GNOMEUI_LIBS) $(INTLLIBS) $(EXTRA_GNOME_LIBS) \ + $(BONOBO_GNOME_LIBS) + +check_PROGRAMS = \ + pgp + +TESTS = pgp + + + diff --git a/camel/tests/smime/README b/camel/tests/smime/README new file mode 100644 index 0000000000..baad91ba00 --- /dev/null +++ b/camel/tests/smime/README @@ -0,0 +1,2 @@ +pgp PGP test suite + 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; +} |