diff options
| author | Jeffrey Stedfast <fejj@ximian.com> | 2001-05-16 02:37:37 +0800 | 
|---|---|---|
| committer | Jeffrey Stedfast <fejj@src.gnome.org> | 2001-05-16 02:37:37 +0800 | 
| commit | d1fe1c2d897e8f37d509db960739516275ec35f6 (patch) | |
| tree | 3ab80449a58e2fd10f1cd61d490b2c63bfe073b4 | |
| parent | 34f2464cd318efa7ff81bae1459af30e94e7e6c3 (diff) | |
| download | gsoc2013-evolution-d1fe1c2d897e8f37d509db960739516275ec35f6.tar.gz gsoc2013-evolution-d1fe1c2d897e8f37d509db960739516275ec35f6.tar.zst gsoc2013-evolution-d1fe1c2d897e8f37d509db960739516275ec35f6.zip | |
Added t the test suite - tests the S/MIME pkcs7 functions.
2001-05-15  Jeffrey Stedfast  <fejj@ximian.com>
	* tests/smime/pkcs7.c: Added t the test suite - tests the S/MIME
	pkcs7 functions.
svn path=/trunk/; revision=9818
| -rw-r--r-- | camel/ChangeLog | 5 | ||||
| -rw-r--r-- | camel/tests/smime/Makefile.am | 5 | ||||
| -rw-r--r-- | camel/tests/smime/pkcs7.c | 178 | 
3 files changed, 186 insertions, 2 deletions
| diff --git a/camel/ChangeLog b/camel/ChangeLog index 2a87f14288..faad71f47c 100644 --- a/camel/ChangeLog +++ b/camel/ChangeLog @@ -1,3 +1,8 @@ +2001-05-15  Jeffrey Stedfast  <fejj@ximian.com> + +	* tests/smime/pkcs7.c: Added t the test suite - tests the S/MIME +	pkcs7 functions. +  2001-05-14  Jeffrey Stedfast  <fejj@ximian.com>  	* camel-smime-context.c: Lots of fixes to get this to compile. diff --git a/camel/tests/smime/Makefile.am b/camel/tests/smime/Makefile.am index 7027729487..cdc9c9b8b7 100644 --- a/camel/tests/smime/Makefile.am +++ b/camel/tests/smime/Makefile.am @@ -15,6 +15,7 @@ LDADD = \  check_PROGRAMS =  	\  	pgp		\ -	pgp-mime +	pgp-mime	\ +	pkcs7		\ -TESTS = pgp pgp-mime +TESTS = pgp pgp-mime pkcs7 diff --git a/camel/tests/smime/pkcs7.c b/camel/tests/smime/pkcs7.c new file mode 100644 index 0000000000..2248d8656d --- /dev/null +++ b/camel/tests/smime/pkcs7.c @@ -0,0 +1,178 @@ +#include <config.h> + +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <camel/camel-smime-context.h> +#include <camel/camel-stream-mem.h> + +#include "camel-test.h" + + +#define CAMEL_TEST_SESSION_TYPE     (camel_test_session_get_type ()) +#define CAMEL_TEST_SESSION(obj)     (CAMEL_CHECK_CAST((obj), CAMEL_TEST_SESSION_TYPE, CamelTestSession)) +#define CAMEL_TEST_SESSION_CLASS(k) (CAMEL_CHECK_CLASS_CAST ((k), CAMEL_TEST_SESSION_TYPE, CamelTestSessionClass)) +#define CAMEL_TEST_IS_SESSION(o)    (CAMEL_CHECK_TYPE((o), CAMEL_TEST_SESSION_TYPE)) + + +typedef struct _CamelTestSession { +	CamelSession parent_object; +	 +} CamelTestSession; + +typedef struct _CamelTestSessionClass { +	CamelSessionClass parent_class; +	 +} CamelTestSessionClass; + + +static char *get_password (CamelSession *session, const char *prompt, +			   gboolean secret, CamelService *service, +			   const char *item, CamelException *ex); + +static void +init (CamelTestSession *session) +{ +	; +} + +static void +class_init (CamelTestSessionClass *camel_test_session_class) +{ +	CamelSessionClass *camel_session_class = +		CAMEL_SESSION_CLASS (camel_test_session_class); +	 +	/* virtual method override */ +	camel_session_class->get_password = get_password; +} + +static CamelType +camel_test_session_get_type (void) +{ +	static CamelType type = CAMEL_INVALID_TYPE; +	 +	if (type == CAMEL_INVALID_TYPE) { +		type = camel_type_register ( +			camel_test_session_get_type (), +			"CamelTestSession", +			sizeof (CamelTestSession), +			sizeof (CamelTestSessionClass), +			(CamelObjectClassInitFunc) class_init, +			NULL, +			(CamelObjectInitFunc) init, +			NULL); +	} +	 +	return type; +} + +static char * +get_password (CamelSession *session, const char *prompt, gboolean secret, +	      CamelService *service, const char *item, CamelException *ex) +{ +	return g_strdup ("S/MIME v3 is rfc263x, now go and read them."); +} + +static CamelSession * +camel_test_session_new (const char *path) +{ +	CamelSession *session; +	 +	session = CAMEL_SESSION (camel_object_new (CAMEL_TEST_SESSION_TYPE)); +	 +	camel_session_construct (session, path); +	 +	return session; +} + + +int main (int argc, char **argv) +{ +	CamelSession *session; +	CamelSMimeContext *ctx; +	CamelException *ex; +	CamelCipherValidity *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_test_session_new ("/tmp/camel-test"); +	 +	ctx = camel_smime_context_new (session); +	 +	camel_test_start ("Test of S/MIME PKCS7 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 ("PKCS7 signing"); +	camel_smime_sign (ctx, "smime@xtorshun.org", CAMEL_CIPHER_HASH_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 ("PKCS7 verify"); +	camel_stream_reset (stream1); +	camel_stream_reset (stream2); +	valid = camel_smime_verify (ctx, CAMEL_CIPHER_HASH_SHA1, stream1, stream2, ex); +	check_msg (!camel_exception_is_set (ex), "%s", camel_exception_get_description (ex)); +	check_msg (camel_cipher_validity_get_valid (valid), "%s", camel_cipher_validity_get_description (valid)); +	camel_cipher_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 ("PKCS7 encrypt"); +	recipients = g_ptr_array_new (); +	g_ptr_array_add (recipients, "smime@xtorshun.org"); +	camel_smime_encrypt (ctx, FALSE, "smime@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 ("PKCS7 decrypt"); +	camel_smime_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; +} | 
