mirror of
https://github.com/strongswan/strongswan.git
synced 2025-10-06 00:00:47 -04:00
Moved test_rng to a test suite of its own
This commit is contained in:
parent
f1e12da7ef
commit
2006709ec5
@ -41,6 +41,7 @@ tests_SOURCES = tests.h tests.c \
|
||||
suites/test_pen.c \
|
||||
suites/test_asn1.c \
|
||||
suites/test_printf.c \
|
||||
suites/test_test_rng.c \
|
||||
suites/test_ntru.c
|
||||
|
||||
tests_CFLAGS = \
|
||||
|
@ -42,28 +42,6 @@ char *parameter_sets[] = {
|
||||
"x9_98_speed", "x9_98_bandwidth", "x9_98_balance", "optimum"
|
||||
};
|
||||
|
||||
START_TEST(test_ntru_test_rng)
|
||||
{
|
||||
rng_t *entropy;
|
||||
chunk_t in, in1, in2, out;
|
||||
|
||||
in1 = chunk_from_chars(0x01, 0x02, 0x03, 0x04, 0x05, 0x06);
|
||||
in2 = chunk_from_chars(0x07, 0x08);
|
||||
in = chunk_cat("cc", in1, in2);
|
||||
|
||||
entropy = test_rng_create(in);
|
||||
ck_assert(entropy->allocate_bytes(entropy, 6, &out));
|
||||
ck_assert(chunk_equals(in1, out));
|
||||
ck_assert(entropy->get_bytes(entropy, 2, out.ptr));
|
||||
ck_assert(memeq(in2.ptr, out.ptr, in2.len));
|
||||
ck_assert(!entropy->get_bytes(entropy, 4, out.ptr));
|
||||
chunk_free(&out);
|
||||
ck_assert(!entropy->allocate_bytes(entropy, 4, &out));
|
||||
entropy->destroy(entropy);
|
||||
chunk_free(&in);
|
||||
}
|
||||
END_TEST
|
||||
|
||||
typedef struct {
|
||||
u_int32_t requested;
|
||||
u_int32_t standard;
|
||||
@ -498,10 +476,6 @@ Suite *ntru_suite_create()
|
||||
|
||||
s = suite_create("ntru");
|
||||
|
||||
tc = tcase_create("test_rng");
|
||||
tcase_add_test(tc, test_ntru_test_rng);
|
||||
suite_add_tcase(s, tc);
|
||||
|
||||
tc = tcase_create("drbg_strength");
|
||||
tcase_add_loop_test(tc, test_ntru_drbg_strength, 0, countof(strengths));
|
||||
suite_add_tcase(s, tc);
|
||||
|
56
src/libstrongswan/tests/suites/test_test_rng.c
Normal file
56
src/libstrongswan/tests/suites/test_test_rng.c
Normal file
@ -0,0 +1,56 @@
|
||||
/*
|
||||
* Copyright (C) 2013 Andreas Steffen
|
||||
* HSR 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 "test_suite.h"
|
||||
|
||||
#include <tests/utils/test_rng.h>
|
||||
#include <utils/test.h>
|
||||
|
||||
START_TEST(test_test_rng)
|
||||
{
|
||||
rng_t *entropy;
|
||||
chunk_t in, in1, in2, out;
|
||||
|
||||
in1 = chunk_from_chars(0x01, 0x02, 0x03, 0x04, 0x05, 0x06);
|
||||
in2 = chunk_from_chars(0x07, 0x08);
|
||||
in = chunk_cat("cc", in1, in2);
|
||||
|
||||
entropy = test_rng_create(in);
|
||||
ck_assert(entropy->allocate_bytes(entropy, 6, &out));
|
||||
ck_assert(chunk_equals(in1, out));
|
||||
ck_assert(entropy->get_bytes(entropy, 2, out.ptr));
|
||||
ck_assert(memeq(in2.ptr, out.ptr, in2.len));
|
||||
ck_assert(!entropy->get_bytes(entropy, 4, out.ptr));
|
||||
chunk_free(&out);
|
||||
ck_assert(!entropy->allocate_bytes(entropy, 4, &out));
|
||||
entropy->destroy(entropy);
|
||||
chunk_free(&in);
|
||||
}
|
||||
END_TEST
|
||||
|
||||
|
||||
Suite *test_rng_suite_create()
|
||||
{
|
||||
Suite *s;
|
||||
TCase *tc;
|
||||
|
||||
s = suite_create("test_rng");
|
||||
|
||||
tc = tcase_create("test_rng");
|
||||
tcase_add_test(tc, test_test_rng);
|
||||
suite_add_tcase(s, tc);
|
||||
|
||||
return s;
|
||||
}
|
@ -34,5 +34,6 @@ TEST_SUITE(host_suite_create)
|
||||
TEST_SUITE(printf_suite_create)
|
||||
TEST_SUITE(pen_suite_create)
|
||||
TEST_SUITE(asn1_suite_create)
|
||||
TEST_SUITE(test_rng_suite_create)
|
||||
TEST_SUITE_DEPEND(ntru_suite_create, DH, NTRU_112_BIT)
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user