1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-15 09:52:45 +01:00
RIOT/tests/unittests/tests-hashes/tests-hashes-sha224.c

150 lines
5.1 KiB
C

/*
* Copyright (C) 2020 HAW Hamburg
*
* 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 testcases for the sha224 implementation
*
* @author Peter Kietzmann <peter.kietzmann@haw-hamburg.de>
*
* @}
*/
#include <limits.h>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#include "embUnit/embUnit.h"
#include "hashes/sha224.h"
#include "tests-hashes.h"
/**
* @brief expected hash for test 01
* i.e. 3eda9ffe5537a588f54d0b2a453e5fa932986d0bc0f9556924f5c2379b2c91b0
*
* converted using:
* s=$(echo '<hash string>' | sed -e 's/../0x&, /g' | sed 's/, $//'); echo {$s}\;
*
* where <hash string> is the above sequence of characters 3e...b0
*/
/**
* @brief expected hash for test empty
* i.e. d14a028c2a3a2bc9476102bb288234c415a2b01f828ea62ac5b3e42f
*/
static const unsigned char hempty[] =
{0xd1, 0x4a, 0x02, 0x8c, 0x2a, 0x3a, 0x2b, 0xc9, 0x47,
0x61, 0x02, 0xbb, 0x28, 0x82, 0x34, 0xc4, 0x15, 0xa2,
0xb0, 0x1f, 0x82, 0x8e, 0xa6, 0x2a, 0xc5, 0xb3, 0xe4,
0x2f};
/**
* @brief expected hash for "abc"
* (from FIPS 180-2 Appendix B.1)
*/
static const unsigned char h_abc[] =
{0x23, 0x09, 0x7d, 0x22, 0x34, 0x05, 0xd8, 0x22, 0x86,
0x42, 0xa4, 0x77, 0xbd, 0xa2, 0x55, 0xb3, 0x2a, 0xad,
0xbc, 0xe4, 0xbd, 0xa0, 0xb3, 0xf7, 0xe3, 0x6c, 0x9d,
0xa7};
/**
* @brief expected hash for "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq"
* (from FIPS 180-2 Appendix B.2)
*/
static const unsigned char h_abc_long[] =
{0x75, 0x38, 0x8b, 0x16, 0x51, 0x27, 0x76, 0xcc, 0x5d,
0xba, 0x5d, 0xa1, 0xfd, 0x89, 0x01, 0x50, 0xb0, 0xc6,
0x45, 0x5c, 0xb4, 0xf5, 0x8b, 0x19, 0x52, 0x52, 0x25,
0x25};
/**
* @brief expected hash for test long_sequence
* i.e. 34674aab568a93190425d9f9d7e96ff835635630e3d2638218a9103b
*/
static const unsigned char hlong_sequence[] =
{0x34, 0x67, 0x4a, 0xab, 0x56, 0x8a, 0x93, 0x19, 0x04,
0x25, 0xd9, 0xf9, 0xd7, 0xe9, 0x6f, 0xf8, 0x35, 0x63,
0x56, 0x30, 0xe3, 0xd2, 0x63, 0x82, 0x18, 0xa9, 0x10,
0x3b};
static int calc_and_compare_hash(const char *str, const unsigned char *expected)
{
static unsigned char hash[28];
sha224_context_t sha224;
sha224_init(&sha224);
sha224_update(&sha224, (uint8_t*)str, strlen(str));
sha224_final(&sha224, hash);
return (memcmp(expected, hash, 28) == 0);
}
static int calc_and_compare_hash_wrapper(const char *str, const unsigned char *expected)
{
static unsigned char hash[SHA224_DIGEST_LENGTH];
sha224((uint8_t*)str, strlen(str), hash);
return (memcmp(expected, hash, SHA224_DIGEST_LENGTH) == 0);
}
static void test_hashes_sha224_hash_sequence_empty(void)
{
const char *teststring = "";
TEST_ASSERT(calc_and_compare_hash(teststring, hempty));
TEST_ASSERT(calc_and_compare_hash_wrapper(teststring, hempty));
}
static void test_hashes_sha224_hash_sequence_abc(void)
{
char *teststring = "abc";
TEST_ASSERT(calc_and_compare_hash(teststring, h_abc));
TEST_ASSERT(calc_and_compare_hash_wrapper(teststring, h_abc));
}
static void test_hashes_sha224_hash_sequence_abc_long(void)
{
char *teststring = "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq";
TEST_ASSERT(calc_and_compare_hash(teststring, h_abc_long));
TEST_ASSERT(calc_and_compare_hash_wrapper(teststring, h_abc_long));
}
static void test_hashes_sha256_hash_long_sequence(void)
{
static const char *teststring =
{"RIOT is an open-source microkernel-based operating system, designed"
" to match the requirements of Internet of Things (IoT) devices and"
" other embedded devices. These requirements include a very low memory"
" footprint (on the order of a few kilobytes), high energy efficiency"
", real-time capabilities, communication stacks for both wireless and"
" wired networks, and support for a wide range of low-power hardware."};
TEST_ASSERT(calc_and_compare_hash(teststring, hlong_sequence));
TEST_ASSERT(calc_and_compare_hash_wrapper(teststring, hlong_sequence));
}
Test *tests_hashes_sha224_tests(void)
{
EMB_UNIT_TESTFIXTURES(fixtures) {
new_TestFixture(test_hashes_sha224_hash_sequence_empty),
new_TestFixture(test_hashes_sha224_hash_sequence_abc),
new_TestFixture(test_hashes_sha224_hash_sequence_abc_long),
new_TestFixture(test_hashes_sha256_hash_long_sequence),
};
EMB_UNIT_TESTCALLER(hashes_sha224_tests, NULL, NULL,
fixtures);
return (Test *)&hashes_sha224_tests;
}