/* * Copyright (C) 2018 Kaspar Schleiser <kaspar@schleiser.de> * * 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 unittests * @{ * * @file * @brief qDSA crypto library tests * * @author Kaspar Schleiser <kaspar@schleiser.de> * * @} */ #include "embUnit.h" #include "random.h" #include "sign.h" static const unsigned char m[] = "0123456789abcdef"; #define SMLEN (sizeof(m) + 64) static unsigned char sm[SMLEN]; static unsigned char m_result[sizeof(m)]; static unsigned char sk[64]; static unsigned char pk[32]; static void setUp(void) { /* Initialize */ random_init(0); } static void tearDown(void) { /* Finalize */ } static void test_qDSA_sign_verify(void) { unsigned long long smlen; random_bytes(sk, 32); keypair(pk, sk); sign(sm, &smlen, m, sizeof(m), pk, sk); TEST_ASSERT_EQUAL_INT(SMLEN, smlen); TEST_ASSERT_EQUAL_STRING("0123456789abcdef", (const char *)(sm + 64)); TEST_ASSERT_EQUAL_INT(0, verify(m_result, 0, sm, smlen, pk)); TEST_ASSERT_EQUAL_STRING("0123456789abcdef", (const char *)m_result); sm[70] = 'x'; TEST_ASSERT_EQUAL_INT(1, verify(m_result, 0, sm, smlen, pk)); } Test *tests_qDSA(void) { EMB_UNIT_TESTFIXTURES(fixtures) { new_TestFixture(test_qDSA_sign_verify), }; EMB_UNIT_TESTCALLER(qDSA_tests, setUp, tearDown, fixtures); return (Test*)&qDSA_tests; } int main(void) { TESTS_START(); TESTS_RUN(tests_qDSA()); TESTS_END(); return 0; }