mirror of
https://github.com/strongswan/strongswan.git
synced 2025-10-10 00:00:19 -04:00
unit-tests: Move ntru_test_rng_t to a utility class in libtest
This commit is contained in:
parent
6354466a5b
commit
a24eec4649
@ -14,7 +14,6 @@ libstrongswan_ntru_la_SOURCES = \
|
|||||||
ntru_plugin.h ntru_plugin.c \
|
ntru_plugin.h ntru_plugin.c \
|
||||||
ntru_drbg.h ntru_drbg.c \
|
ntru_drbg.h ntru_drbg.c \
|
||||||
ntru_ke.h ntru_ke.c \
|
ntru_ke.h ntru_ke.c \
|
||||||
ntru_test_rng.h ntru_test_rng.c \
|
|
||||||
ntru_crypto/ntru_crypto.h ntru_crypto/ntru_crypto_error.h \
|
ntru_crypto/ntru_crypto.h ntru_crypto/ntru_crypto_error.h \
|
||||||
ntru_crypto/ntru_crypto_ntru_convert.h \
|
ntru_crypto/ntru_crypto_ntru_convert.h \
|
||||||
ntru_crypto/ntru_crypto_ntru_convert.c \
|
ntru_crypto/ntru_crypto_ntru_convert.c \
|
||||||
|
@ -2,7 +2,8 @@ check_LTLIBRARIES = libtest.la
|
|||||||
|
|
||||||
libtest_la_SOURCES = \
|
libtest_la_SOURCES = \
|
||||||
test_suite.c test_suite.h \
|
test_suite.c test_suite.h \
|
||||||
test_runner.c test_runner.h
|
test_runner.c test_runner.h \
|
||||||
|
utils/test_rng.c utils/test_rng.h
|
||||||
|
|
||||||
libtest_la_CFLAGS = \
|
libtest_la_CFLAGS = \
|
||||||
-I$(top_srcdir)/src/libstrongswan \
|
-I$(top_srcdir)/src/libstrongswan \
|
||||||
|
@ -15,8 +15,8 @@
|
|||||||
|
|
||||||
#include "test_suite.h"
|
#include "test_suite.h"
|
||||||
|
|
||||||
|
#include <tests/utils/test_rng.h>
|
||||||
#include <plugins/ntru/ntru_drbg.h>
|
#include <plugins/ntru/ntru_drbg.h>
|
||||||
#include <plugins/ntru/ntru_test_rng.h>
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* NTRU parameter sets to test
|
* NTRU parameter sets to test
|
||||||
@ -47,7 +47,7 @@ START_TEST(test_ntru_test_rng)
|
|||||||
in2 = chunk_from_chars(0x07, 0x08);
|
in2 = chunk_from_chars(0x07, 0x08);
|
||||||
in = chunk_cat("cc", in1, in2);
|
in = chunk_cat("cc", in1, in2);
|
||||||
|
|
||||||
entropy = ntru_test_rng_create(in);
|
entropy = test_rng_create(in);
|
||||||
ck_assert(entropy->allocate_bytes(entropy, 6, &out));
|
ck_assert(entropy->allocate_bytes(entropy, 6, &out));
|
||||||
ck_assert(chunk_equals(in1, out));
|
ck_assert(chunk_equals(in1, out));
|
||||||
ck_assert(entropy->get_bytes(entropy, 2, out.ptr));
|
ck_assert(entropy->get_bytes(entropy, 2, out.ptr));
|
||||||
@ -241,7 +241,7 @@ START_TEST(test_ntru_drbg)
|
|||||||
chunk_t out;
|
chunk_t out;
|
||||||
|
|
||||||
out = chunk_alloc(128);
|
out = chunk_alloc(128);
|
||||||
entropy = ntru_test_rng_create(drbg_tests[_i].entropy);
|
entropy = test_rng_create(drbg_tests[_i].entropy);
|
||||||
drbg = ntru_drbg_create(256, drbg_tests[_i].pers_str, entropy);
|
drbg = ntru_drbg_create(256, drbg_tests[_i].pers_str, entropy);
|
||||||
ck_assert(drbg != NULL);
|
ck_assert(drbg != NULL);
|
||||||
ck_assert(drbg->reseed(drbg));
|
ck_assert(drbg->reseed(drbg));
|
||||||
@ -263,7 +263,7 @@ START_TEST(test_ntru_drbg_reseed)
|
|||||||
lib->settings->set_int(lib->settings,
|
lib->settings->set_int(lib->settings,
|
||||||
"libstrongswan.plugins.ntru.max_drbg_requests", 2);
|
"libstrongswan.plugins.ntru.max_drbg_requests", 2);
|
||||||
out = chunk_alloc(128);
|
out = chunk_alloc(128);
|
||||||
entropy = ntru_test_rng_create(drbg_tests[0].entropy);
|
entropy = test_rng_create(drbg_tests[0].entropy);
|
||||||
drbg = ntru_drbg_create(256, chunk_empty, entropy);
|
drbg = ntru_drbg_create(256, chunk_empty, entropy);
|
||||||
|
|
||||||
/* bad output parameters */
|
/* bad output parameters */
|
||||||
@ -287,7 +287,7 @@ START_TEST(test_ntru_drbg_reseed)
|
|||||||
entropy->destroy(entropy);
|
entropy->destroy(entropy);
|
||||||
|
|
||||||
/* one automatic reseeding occurs */
|
/* one automatic reseeding occurs */
|
||||||
entropy = ntru_test_rng_create(drbg_tests[0].entropy);
|
entropy = test_rng_create(drbg_tests[0].entropy);
|
||||||
drbg = ntru_drbg_create(256, chunk_empty, entropy);
|
drbg = ntru_drbg_create(256, chunk_empty, entropy);
|
||||||
ck_assert(drbg->generate(drbg, 256, 128, out.ptr));
|
ck_assert(drbg->generate(drbg, 256, 128, out.ptr));
|
||||||
ck_assert(drbg->generate(drbg, 256, 128, out.ptr));
|
ck_assert(drbg->generate(drbg, 256, 128, out.ptr));
|
||||||
@ -311,7 +311,7 @@ START_TEST(test_ntru_ke)
|
|||||||
char buf[10];
|
char buf[10];
|
||||||
int n, len;
|
int n, len;
|
||||||
status_t status;
|
status_t status;
|
||||||
|
|
||||||
len = snprintf(buf, sizeof(buf), "%N", diffie_hellman_group_names,
|
len = snprintf(buf, sizeof(buf), "%N", diffie_hellman_group_names,
|
||||||
params[_i].group);
|
params[_i].group);
|
||||||
ck_assert(len == 8);
|
ck_assert(len == 8);
|
||||||
|
@ -16,6 +16,9 @@
|
|||||||
/**
|
/**
|
||||||
* @defgroup libtest libtest
|
* @defgroup libtest libtest
|
||||||
*
|
*
|
||||||
|
* @defgroup test_utils test_utils
|
||||||
|
* @ingroup libtest
|
||||||
|
*
|
||||||
* @defgroup test_runner test_runner
|
* @defgroup test_runner test_runner
|
||||||
* @{ @ingroup libtest
|
* @{ @ingroup libtest
|
||||||
*/
|
*/
|
||||||
|
@ -13,28 +13,28 @@
|
|||||||
* for more details.
|
* for more details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "ntru_test_rng.h"
|
#include "test_rng.h"
|
||||||
|
|
||||||
typedef struct private_ntru_test_rng_t private_ntru_test_rng_t;
|
typedef struct private_rng_t private_rng_t;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Private data of an ntru_test_rng_t object.
|
* Private data.
|
||||||
*/
|
*/
|
||||||
struct private_ntru_test_rng_t {
|
struct private_rng_t {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Public ntru_test_rng_t interface.
|
* Public interface.
|
||||||
*/
|
*/
|
||||||
ntru_test_rng_t public;
|
rng_t public;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* entropy string
|
* Entropy string.
|
||||||
*/
|
*/
|
||||||
chunk_t entropy;
|
chunk_t entropy;
|
||||||
};
|
};
|
||||||
|
|
||||||
METHOD(rng_t, get_bytes, bool,
|
METHOD(rng_t, get_bytes, bool,
|
||||||
private_ntru_test_rng_t *this, size_t bytes, u_int8_t *buffer)
|
private_rng_t *this, size_t bytes, u_int8_t *buffer)
|
||||||
{
|
{
|
||||||
if (bytes > this->entropy.len)
|
if (bytes > this->entropy.len)
|
||||||
{
|
{
|
||||||
@ -46,7 +46,7 @@ METHOD(rng_t, get_bytes, bool,
|
|||||||
}
|
}
|
||||||
|
|
||||||
METHOD(rng_t, allocate_bytes, bool,
|
METHOD(rng_t, allocate_bytes, bool,
|
||||||
private_ntru_test_rng_t *this, size_t bytes, chunk_t *chunk)
|
private_rng_t *this, size_t bytes, chunk_t *chunk)
|
||||||
{
|
{
|
||||||
if (bytes > this->entropy.len)
|
if (bytes > this->entropy.len)
|
||||||
{
|
{
|
||||||
@ -61,7 +61,7 @@ METHOD(rng_t, allocate_bytes, bool,
|
|||||||
}
|
}
|
||||||
|
|
||||||
METHOD(rng_t, destroy, void,
|
METHOD(rng_t, destroy, void,
|
||||||
private_ntru_test_rng_t *this)
|
private_rng_t *this)
|
||||||
{
|
{
|
||||||
free(this);
|
free(this);
|
||||||
}
|
}
|
||||||
@ -69,21 +69,18 @@ METHOD(rng_t, destroy, void,
|
|||||||
/*
|
/*
|
||||||
* Described in header.
|
* Described in header.
|
||||||
*/
|
*/
|
||||||
rng_t *ntru_test_rng_create(chunk_t entropy)
|
rng_t *test_rng_create(chunk_t entropy)
|
||||||
{
|
{
|
||||||
private_ntru_test_rng_t *this;
|
private_rng_t *this;
|
||||||
|
|
||||||
INIT(this,
|
INIT(this,
|
||||||
.public = {
|
.public = {
|
||||||
.rng = {
|
.get_bytes = _get_bytes,
|
||||||
.get_bytes = _get_bytes,
|
.allocate_bytes = _allocate_bytes,
|
||||||
.allocate_bytes = _allocate_bytes,
|
.destroy = _destroy,
|
||||||
.destroy = _destroy,
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
.entropy = entropy,
|
.entropy = entropy,
|
||||||
);
|
);
|
||||||
|
|
||||||
return &this->public.rng;
|
return &this->public;
|
||||||
}
|
}
|
||||||
|
|
@ -14,34 +14,23 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @defgroup ntru_test_rng ntru_test_rng
|
* rng_t providing NIST SP 800-90A entropy test vectors
|
||||||
* @{ @ingroup ntru_p
|
*
|
||||||
|
* @defgroup test_rng test_rng
|
||||||
|
* @{ @ingroup test_utils
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef NTRU_TEST_RNG_H_
|
#ifndef TEST_RNG_H_
|
||||||
#define NTRU_TEST_RNG_H_
|
#define TEST_RNG_H_
|
||||||
|
|
||||||
typedef struct ntru_test_rng_t ntru_test_rng_t;
|
|
||||||
|
|
||||||
#include <library.h>
|
#include <library.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* rng_t providing NIST SP 800-90A entropy test vectors
|
* Creates a test_rng_t instance.
|
||||||
*/
|
|
||||||
struct ntru_test_rng_t {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Implements rng_t.
|
|
||||||
*/
|
|
||||||
rng_t rng;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates an ntru_test_rng_t instance.
|
|
||||||
*
|
*
|
||||||
* @param entropy entropy test vector
|
* @param entropy entropy test vector
|
||||||
* @return created ntru_test_rng_t
|
* @return created test_rng_t
|
||||||
*/
|
*/
|
||||||
rng_t *ntru_test_rng_create(chunk_t entropy);
|
rng_t *test_rng_create(chunk_t entropy);
|
||||||
|
|
||||||
#endif /** NTRU_TEST_RNG_H_ @} */
|
#endif /** TEST_RNG_H_ @} */
|
Loading…
x
Reference in New Issue
Block a user