From eee943f21ebc92e70cec963950c2fc0a29cab544 Mon Sep 17 00:00:00 2001
From: Jeffrey Stedfast <fejj@ximian.com>
Date: Tue, 10 Apr 2001 15:47:00 +0000
Subject: 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
---
 camel/tests/Makefile.am       |   2 +-
 camel/tests/smime/.cvsignore  |   4 ++
 camel/tests/smime/Makefile.am |  22 +++++++++
 camel/tests/smime/README      |   2 +
 camel/tests/smime/pgp.c       | 110 ++++++++++++++++++++++++++++++++++++++++++
 5 files changed, 139 insertions(+), 1 deletion(-)
 create mode 100644 camel/tests/smime/.cvsignore
 create mode 100644 camel/tests/smime/Makefile.am
 create mode 100644 camel/tests/smime/README
 create mode 100644 camel/tests/smime/pgp.c

(limited to 'camel/tests')

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;
+}
-- 
cgit