From 53232d58834efe53fda4b4fd80fc7c5440592c2d Mon Sep 17 00:00:00 2001 From: Reto Buerki Date: Fri, 24 Aug 2012 12:16:17 +0200 Subject: Implement sequence_to_chunk function This function converts a given TKM variable-length byte sequence to chunk. --- src/charon-tkm/tests/utils_tests.c | 45 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 src/charon-tkm/tests/utils_tests.c (limited to 'src/charon-tkm/tests/utils_tests.c') diff --git a/src/charon-tkm/tests/utils_tests.c b/src/charon-tkm/tests/utils_tests.c new file mode 100644 index 000000000..510ebd0b7 --- /dev/null +++ b/src/charon-tkm/tests/utils_tests.c @@ -0,0 +1,45 @@ +/* + * Copyright (C) 2012 Reto Buerki + * Copyright (C) 2012 Adrian-Ken Rueegsegger + * 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 . + * + * 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 +#include + +#include "tkm_utils.h" + +START_TEST(test_sequence_to_chunk) +{ + key_type key = {5, {0, 1, 2, 3, 4}}; + chunk_t chunk = chunk_empty; + + sequence_to_chunk(key.data, key.size, &chunk); + fail_if(chunk.len != key.size, "Chunk size mismatch"); + + uint32_t i; + for (i = 0; i < key.size; i++) + { + fail_if(chunk.ptr[i] != i, "Data mismatch"); + } + chunk_free(&chunk); +} +END_TEST + +TCase *make_utility_tests(void) +{ + TCase *tc = tcase_create("Utility tests"); + tcase_add_test(tc, test_sequence_to_chunk); + + return tc; +} -- cgit v1.2.3 From 0327fac6b6f0c5ec127ab39de11fed0185e49fb7 Mon Sep 17 00:00:00 2001 From: Reto Buerki Date: Fri, 24 Aug 2012 12:58:47 +0200 Subject: Implement chunk_to_sequence function This function converts a given chunk to a variable-length byte sequence. --- src/charon-tkm/tests/utils_tests.c | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) (limited to 'src/charon-tkm/tests/utils_tests.c') diff --git a/src/charon-tkm/tests/utils_tests.c b/src/charon-tkm/tests/utils_tests.c index 510ebd0b7..acc93ecf9 100644 --- a/src/charon-tkm/tests/utils_tests.c +++ b/src/charon-tkm/tests/utils_tests.c @@ -36,10 +36,28 @@ START_TEST(test_sequence_to_chunk) } END_TEST +START_TEST(test_chunk_to_sequence) +{ + chunk_t chunk = chunk_from_thing("ABCDEFGH"); + key_type key; + + chunk_to_sequence(&chunk, &key); + fail_if(key.size != chunk.len, "Seq size mismatch"); + + uint32_t i; + for (i = 0; i < key.size - 1; i++) + { + fail_if(key.data[i] != 65 + i, "Data mismatch (1)"); + } + fail_if(key.data[key.size - 1] != 0, "Data mismatch (2)"); +} +END_TEST + TCase *make_utility_tests(void) { TCase *tc = tcase_create("Utility tests"); tcase_add_test(tc, test_sequence_to_chunk); + tcase_add_test(tc, test_chunk_to_sequence); return tc; } -- cgit v1.2.3 From 0f0165c81f1b33279ad2d10e3b9a8a955d2bf55b Mon Sep 17 00:00:00 2001 From: Adrian-Ken Rueegsegger Date: Thu, 4 Oct 2012 11:17:33 +0200 Subject: Add typelen parameter to chunk_to_sequence function The parameter is used to initialize the given sequence to zero. --- src/charon-tkm/tests/utils_tests.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'src/charon-tkm/tests/utils_tests.c') diff --git a/src/charon-tkm/tests/utils_tests.c b/src/charon-tkm/tests/utils_tests.c index acc93ecf9..b3ead7633 100644 --- a/src/charon-tkm/tests/utils_tests.c +++ b/src/charon-tkm/tests/utils_tests.c @@ -41,7 +41,7 @@ START_TEST(test_chunk_to_sequence) chunk_t chunk = chunk_from_thing("ABCDEFGH"); key_type key; - chunk_to_sequence(&chunk, &key); + chunk_to_sequence(&chunk, &key, sizeof(key_type)); fail_if(key.size != chunk.len, "Seq size mismatch"); uint32_t i; -- cgit v1.2.3