mirror of
https://github.com/strongswan/strongswan.git
synced 2025-10-07 00:01:49 -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_pen.c \
|
||||||
suites/test_asn1.c \
|
suites/test_asn1.c \
|
||||||
suites/test_printf.c \
|
suites/test_printf.c \
|
||||||
|
suites/test_test_rng.c \
|
||||||
suites/test_ntru.c
|
suites/test_ntru.c
|
||||||
|
|
||||||
tests_CFLAGS = \
|
tests_CFLAGS = \
|
||||||
|
@ -42,28 +42,6 @@ char *parameter_sets[] = {
|
|||||||
"x9_98_speed", "x9_98_bandwidth", "x9_98_balance", "optimum"
|
"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 {
|
typedef struct {
|
||||||
u_int32_t requested;
|
u_int32_t requested;
|
||||||
u_int32_t standard;
|
u_int32_t standard;
|
||||||
@ -498,10 +476,6 @@ Suite *ntru_suite_create()
|
|||||||
|
|
||||||
s = suite_create("ntru");
|
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");
|
tc = tcase_create("drbg_strength");
|
||||||
tcase_add_loop_test(tc, test_ntru_drbg_strength, 0, countof(strengths));
|
tcase_add_loop_test(tc, test_ntru_drbg_strength, 0, countof(strengths));
|
||||||
suite_add_tcase(s, tc);
|
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(printf_suite_create)
|
||||||
TEST_SUITE(pen_suite_create)
|
TEST_SUITE(pen_suite_create)
|
||||||
TEST_SUITE(asn1_suite_create)
|
TEST_SUITE(asn1_suite_create)
|
||||||
|
TEST_SUITE(test_rng_suite_create)
|
||||||
TEST_SUITE_DEPEND(ntru_suite_create, DH, NTRU_112_BIT)
|
TEST_SUITE_DEPEND(ntru_suite_create, DH, NTRU_112_BIT)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user