2018-06-29 17:33:09 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2018 Freie Universität Berlin
|
|
|
|
* Copyright (C) 2018 Inria
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup tests
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Monocypher package
|
|
|
|
*
|
|
|
|
* @author Koen Zandberg <koen@bergzand.net>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "monocypher.h"
|
|
|
|
#include "embUnit.h"
|
|
|
|
#include "random.h"
|
|
|
|
|
|
|
|
static uint8_t message[] = "0123456789abcdef";
|
|
|
|
|
2024-05-14 17:22:03 +02:00
|
|
|
static uint8_t sign_sk[64];
|
2018-06-29 17:33:09 +02:00
|
|
|
static uint8_t sign_pk[32];
|
|
|
|
static uint8_t signature[64];
|
|
|
|
|
|
|
|
static void setUp(void)
|
|
|
|
{
|
|
|
|
random_init(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void test_monocypher_signverify(void)
|
|
|
|
{
|
|
|
|
int res;
|
2024-05-14 17:22:03 +02:00
|
|
|
uint8_t seed[32];
|
|
|
|
|
2018-06-29 17:33:09 +02:00
|
|
|
/* Creating keypair ... */
|
2024-05-14 17:22:03 +02:00
|
|
|
random_bytes(seed, sizeof(seed));
|
|
|
|
crypto_eddsa_key_pair(sign_sk, sign_pk, seed);
|
2018-06-29 17:33:09 +02:00
|
|
|
|
|
|
|
/* Sign */
|
2024-05-14 17:22:03 +02:00
|
|
|
crypto_eddsa_sign(signature, sign_sk, message, sizeof(message));
|
2018-06-29 17:33:09 +02:00
|
|
|
|
|
|
|
/* Verifying... */
|
2024-05-14 17:22:03 +02:00
|
|
|
res = crypto_eddsa_check(signature, sign_pk, message, sizeof(message));
|
2018-06-29 17:33:09 +02:00
|
|
|
TEST_ASSERT_EQUAL_INT(0, res);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void test_monocypher_verifynegative(void)
|
|
|
|
{
|
|
|
|
int res;
|
|
|
|
|
|
|
|
/* changing message at random position (10) */
|
|
|
|
message[0] = 'A';
|
|
|
|
|
|
|
|
/* Verifying... */
|
2024-05-14 17:22:03 +02:00
|
|
|
res = crypto_eddsa_check(signature, sign_pk, message, sizeof(message));
|
2018-06-29 17:33:09 +02:00
|
|
|
TEST_ASSERT_EQUAL_INT(-1, res);
|
|
|
|
}
|
|
|
|
|
|
|
|
Test *tests_monocypher(void)
|
|
|
|
{
|
|
|
|
EMB_UNIT_TESTFIXTURES(fixtures) {
|
|
|
|
new_TestFixture(test_monocypher_signverify),
|
|
|
|
new_TestFixture(test_monocypher_verifynegative)
|
|
|
|
};
|
|
|
|
|
|
|
|
EMB_UNIT_TESTCALLER(monocypher_tests, setUp, NULL, fixtures);
|
|
|
|
return (Test*)&monocypher_tests;
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
TESTS_START();
|
|
|
|
TESTS_RUN(tests_monocypher());
|
|
|
|
TESTS_END();
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|