mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
77 lines
2.2 KiB
C
77 lines
2.2 KiB
C
|
/*
|
||
|
* Copyright (C) 2015 Freie Universität Berlin
|
||
|
*
|
||
|
* 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 Test cases for the MD5 hash implementation
|
||
|
*
|
||
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
||
|
*
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
#include <stdio.h>
|
||
|
#include <string.h>
|
||
|
|
||
|
#include "embUnit/embUnit.h"
|
||
|
|
||
|
#include "hashes/md5.h"
|
||
|
|
||
|
#define MD5_DIGEST_LENGTH (16U)
|
||
|
|
||
|
static int calc_and_compare_hash(const char *str, const char *expected)
|
||
|
{
|
||
|
uint8_t hash[MD5_DIGEST_LENGTH];
|
||
|
char tmp[(2 * MD5_DIGEST_LENGTH) + 1];
|
||
|
|
||
|
/* calculate hash */
|
||
|
md5(hash, (const uint8_t *)str, strlen(str));
|
||
|
/* copy hash to string */
|
||
|
for (size_t i = 0; i < MD5_DIGEST_LENGTH; i++) {
|
||
|
sprintf(&(tmp[i * 2]), "%02x", hash[i]);
|
||
|
}
|
||
|
tmp[MD5_DIGEST_LENGTH * 2] = '\0';
|
||
|
/* compare with result string */
|
||
|
return strncmp(tmp, expected, strlen(tmp));
|
||
|
}
|
||
|
|
||
|
/* test cases copied from appendix A.5 of RFC 1321 */
|
||
|
static void test_hashes_md5(void)
|
||
|
{
|
||
|
TEST_ASSERT(calc_and_compare_hash("",
|
||
|
"d41d8cd98f00b204e9800998ecf8427e") == 0);
|
||
|
TEST_ASSERT(calc_and_compare_hash("a",
|
||
|
"0cc175b9c0f1b6a831c399e269772661") == 0);
|
||
|
TEST_ASSERT(calc_and_compare_hash("abc",
|
||
|
"900150983cd24fb0d6963f7d28e17f72") == 0);
|
||
|
TEST_ASSERT(calc_and_compare_hash("message digest",
|
||
|
"f96b697d7cb7938d525a2f31aaf161d0") == 0);
|
||
|
TEST_ASSERT(calc_and_compare_hash("abcdefghijklmnopqrstuvwxyz",
|
||
|
"c3fcd3d76192e4007dfb496cca67e13b") == 0);
|
||
|
TEST_ASSERT(calc_and_compare_hash(
|
||
|
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789",
|
||
|
"d174ab98d277d9f5a5611c2c9f419d9f") == 0);
|
||
|
TEST_ASSERT(calc_and_compare_hash(
|
||
|
"12345678901234567890123456789012345678901234567890123456789012345678901234567890",
|
||
|
"57edf4a22be3c955ac49da2e2107b67a") == 0);
|
||
|
}
|
||
|
|
||
|
Test *tests_hashes_md5_tests(void)
|
||
|
{
|
||
|
EMB_UNIT_TESTFIXTURES(fixtures) {
|
||
|
new_TestFixture(test_hashes_md5),
|
||
|
};
|
||
|
|
||
|
EMB_UNIT_TESTCALLER(test_hashes_md5, NULL, NULL, fixtures);
|
||
|
|
||
|
return (Test *)&test_hashes_md5;
|
||
|
}
|