aboutsummaryrefslogtreecommitdiffstats
path: root/Source/charon/testcases
diff options
context:
space:
mode:
Diffstat (limited to 'Source/charon/testcases')
-rw-r--r--Source/charon/testcases/Makefile.testcases4
-rw-r--r--Source/charon/testcases/encryption_payload_test.c138
-rw-r--r--Source/charon/testcases/encryption_payload_test.h37
-rw-r--r--Source/charon/testcases/testcases.c9
4 files changed, 185 insertions, 3 deletions
diff --git a/Source/charon/testcases/Makefile.testcases b/Source/charon/testcases/Makefile.testcases
index bc1a537a9..abee371f2 100644
--- a/Source/charon/testcases/Makefile.testcases
+++ b/Source/charon/testcases/Makefile.testcases
@@ -103,5 +103,9 @@ $(BUILD_DIR)sender_test.o : $(TESTCASES_DIR)sender_test.c $(TESTCASES_DIR)send
TEST_OBJS+= $(BUILD_DIR)thread_pool_test.o
$(BUILD_DIR)thread_pool_test.o : $(TESTCASES_DIR)thread_pool_test.c $(TESTCASES_DIR)thread_pool_test.h
$(CC) $(CFLAGS) -c -o $@ $<
+
+TEST_OBJS+= $(BUILD_DIR)encryption_payload_test.o
+$(BUILD_DIR)encryption_payload_test.o : $(TESTCASES_DIR)encryption_payload_test.c $(TESTCASES_DIR)encryption_payload_test.h
+ $(CC) $(CFLAGS) -c -o $@ $<
diff --git a/Source/charon/testcases/encryption_payload_test.c b/Source/charon/testcases/encryption_payload_test.c
new file mode 100644
index 000000000..c824fe446
--- /dev/null
+++ b/Source/charon/testcases/encryption_payload_test.c
@@ -0,0 +1,138 @@
+/**
+ * @file encryption_payload_test.c
+ *
+ * @brief Tests for the encryption_payload_t class.
+ *
+ */
+
+/*
+ * Copyright (C) 2005 Jan Hutter, Martin Willi
+ * Hochschule fuer Technik Rapperswil
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by the
+ * Free Software Foundation; either version 2 of the License, or (at your
+ * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
+ * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+ * for more details.
+ */
+
+#include "encryption_payload_test.h"
+
+#include <daemon.h>
+#include <utils/logger_manager.h>
+#include <utils/allocator.h>
+#include <encoding/generator.h>
+#include <encoding/parser.h>
+#include <encoding/payloads/encryption_payload.h>
+#include <encoding/payloads/nonce_payload.h>
+#include <transforms/crypters/crypter.h>
+#include <transforms/signers/signer.h>
+
+/*
+ * described in Header-File
+ */
+void test_encryption_payload(tester_t *tester)
+{
+ encryption_payload_t *encryption_payload;
+ nonce_payload_t *nonce_payload;
+ crypter_t *crypter;
+ signer_t *signer;
+ chunk_t nonce, got_nonce;
+ chunk_t data;
+ chunk_t key;
+ generator_t *generator;
+ parser_t *parser;
+ status_t status;
+ logger_t *logger;
+ iterator_t *iterator;
+
+
+ u_int8_t key_bytes[] = {
+ 0x01,0x01,0x01,0x01,
+ 0x01,0x01,0x01,0x01,
+ 0x01,0x01,0x01,0x01,
+ 0x01,0x01,0x01,0x01
+ };
+ key.ptr = key_bytes;
+ key.len = sizeof(key_bytes);
+
+ logger = charon->logger_manager->create_logger(charon->logger_manager, TESTER, NULL);
+
+ nonce.ptr = "test text und so...";
+ nonce.len = strlen(nonce.ptr) +1;
+
+ logger->log_chunk(logger, RAW, "nonce", &nonce);
+
+ encryption_payload = encryption_payload_create();
+ nonce_payload = nonce_payload_create();
+ nonce_payload->set_nonce(nonce_payload, nonce);
+
+ encryption_payload->add_payload(encryption_payload, (payload_t*)nonce_payload);
+ signer = signer_create(AUTH_HMAC_SHA1_96);
+ crypter = crypter_create(ENCR_AES_CBC, 16);
+
+ signer->set_key(signer, key);
+ crypter->set_key(crypter, key);
+
+
+
+ /* generating */
+
+ encryption_payload->set_transforms(encryption_payload, crypter, signer);
+
+ logger->log(logger, RAW, "encrypt");
+ status = encryption_payload->encrypt(encryption_payload);
+ tester->assert_true(tester, (status == SUCCESS), "encryption");
+
+ generator = generator_create();
+ generator->generate_payload(generator, (payload_t*)encryption_payload);
+
+ generator->write_to_chunk(generator, &data);
+ logger->log_chunk(logger, RAW, "generated data", &data);
+
+ encryption_payload->build_signature(encryption_payload, data);
+ logger->log_chunk(logger, RAW, "generated data", &data);
+
+ encryption_payload->destroy(encryption_payload);
+
+
+ /* parsing */
+
+ parser = parser_create(data);
+ status = parser->parse_payload(parser, ENCRYPTED, (payload_t**)&encryption_payload);
+ tester->assert_true(tester, (status == SUCCESS), "parsing");
+
+ encryption_payload->set_transforms(encryption_payload, crypter, signer);
+ status = encryption_payload->verify_signature(encryption_payload, data);
+ tester->assert_true(tester, (status == SUCCESS), "signature verification");
+
+ status = encryption_payload->decrypt(encryption_payload);
+ tester->assert_true(tester, (status == SUCCESS), "decryption");
+
+
+ iterator = encryption_payload->create_payload_iterator(encryption_payload, TRUE);
+ while (iterator->has_next(iterator))
+ {
+ iterator->current(iterator, (void**)&nonce_payload);
+ nonce_payload->get_nonce(nonce_payload, &got_nonce);
+ }
+ iterator->destroy(iterator);
+
+
+ tester->assert_true(tester, (got_nonce.len == nonce.len), "decrypted nonce");
+ tester->assert_false(tester, memcmp(nonce.ptr, got_nonce.ptr, nonce.len), "decrypted nonce");
+
+ logger->log_chunk(logger, RAW, "nonce", &got_nonce);
+
+ allocator_free(data.ptr);
+ allocator_free(got_nonce.ptr);
+ encryption_payload->destroy(encryption_payload);
+ crypter->destroy(crypter);
+ signer->destroy(signer);
+ generator->destroy(generator);
+ parser->destroy(parser);
+}
diff --git a/Source/charon/testcases/encryption_payload_test.h b/Source/charon/testcases/encryption_payload_test.h
new file mode 100644
index 000000000..3bc72ce06
--- /dev/null
+++ b/Source/charon/testcases/encryption_payload_test.h
@@ -0,0 +1,37 @@
+/**
+ * @file encryption_payload_test.h
+ *
+ * @brief Tests for the encryption_payload_t class.
+ *
+ */
+
+/*
+ * Copyright (C) 2005 Jan Hutter, Martin Willi
+ * Hochschule fuer Technik Rapperswil
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by the
+ * Free Software Foundation; either version 2 of the License, or (at your
+ * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
+ * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+ * for more details.
+ */
+
+#ifndef ENCRYPTION_PAYLOAD_TEST_H_
+#define ENCRYPTION_PAYLOAD_TEST_H_
+
+#include <utils/tester.h>
+
+/**
+ * @brief Test function used to test the encryption_payload_t functionality.
+ *
+ * @param tester associated tester object
+ *
+ * @ingroup testcases
+ */
+void test_encryption_payload(tester_t *tester);
+
+#endif /*ENCRYPTION_PAYLOAD_TEST_H_*/
diff --git a/Source/charon/testcases/testcases.c b/Source/charon/testcases/testcases.c
index 6a8ddcd98..e62ba5f1f 100644
--- a/Source/charon/testcases/testcases.c
+++ b/Source/charon/testcases/testcases.c
@@ -55,6 +55,7 @@
#include <testcases/prf_plus_test.h>
#include <testcases/aes_cbc_crypter_test.h>
#include <testcases/hmac_signer_test.h>
+#include <testcases/encryption_payload_test.h>
/* output for test messages */
extern FILE * stderr;
@@ -102,6 +103,7 @@ test_t prf_plus_test = {test_prf_plus, "prf+"};
test_t aes_cbc_crypter_test = {test_aes_cbc_crypter, "AES CBC"};
test_t hmac_signer_test1 = {test_hmac_md5_signer, "HMAC MD5 signer test"};
test_t hmac_signer_test2 = {test_hmac_sha1_signer, "HMAC SHA1 signer test"};
+test_t encryption_payload_test = {test_encryption_payload, "encryption payload test"};
daemon_t* charon;
@@ -194,19 +196,20 @@ int main()
&aes_cbc_crypter_test,
&hmac_signer_test1,
&hmac_signer_test2,
+ &encryption_payload_test,
NULL
};
daemon_create();
charon->logger_manager->disable_logger_level(charon->logger_manager,TESTER,FULL);
- charon->logger_manager->enable_logger_level(charon->logger_manager,TESTER,RAW);
+ //charon->logger_manager->enable_logger_level(charon->logger_manager,TESTER,RAW);
tester_t *tester = tester_create(test_output, FALSE);
+ tester->perform_tests(tester,all_tests);
+ //tester->perform_test(tester,&encryption_payload_test);
-// tester->perform_tests(tester,all_tests);
- tester->perform_test(tester,&parser_test8);
tester->destroy(tester);