mirror of
https://gitlab.freedesktop.org/xorg/xserver.git
synced 2025-12-20 07:00:03 +01:00
test: add unit tests for x_sha1_* functions in os/xsha1.c
Simple confirmation of known values, not exhaustive testing. Tested with SHA-1 implementations from: - libcrypto (OpenSSL 3) - libgcrypt - libnettle - Solaris libmd Signed-off-by: Alan Coopersmith <alan.coopersmith@oracle.com> Part-of: <https://gitlab.freedesktop.org/xorg/xserver/-/merge_requests/2066>
This commit is contained in:
parent
23c103d41f
commit
7013984b5f
4 changed files with 133 additions and 0 deletions
|
|
@ -179,6 +179,7 @@ if build_xorg
|
||||||
'input.c',
|
'input.c',
|
||||||
'list.c',
|
'list.c',
|
||||||
'misc.c',
|
'misc.c',
|
||||||
|
'sha1.c',
|
||||||
'signal-logging.c',
|
'signal-logging.c',
|
||||||
'string.c',
|
'string.c',
|
||||||
'test_xkb.c',
|
'test_xkb.c',
|
||||||
|
|
|
||||||
130
test/sha1.c
Normal file
130
test/sha1.c
Normal file
|
|
@ -0,0 +1,130 @@
|
||||||
|
/* SPDX-License-Identifier: MIT
|
||||||
|
*
|
||||||
|
* Copyright (c) 2025, Oracle and/or its affiliates.
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
* copy of this software and associated documentation files (the "Software"),
|
||||||
|
* to deal in the Software without restriction, including without limitation
|
||||||
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||||
|
* and/or sell copies of the Software, and to permit persons to whom the
|
||||||
|
* Software is furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice (including the next
|
||||||
|
* paragraph) shall be included in all copies or substantial portions of the
|
||||||
|
* Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||||
|
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||||
|
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
|
* DEALINGS IN THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests for x_sha1_* functions provided in os/xsha1.c.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Test relies on assert() */
|
||||||
|
#undef NDEBUG
|
||||||
|
|
||||||
|
#include <dix-config.h>
|
||||||
|
|
||||||
|
#include <assert.h>
|
||||||
|
#include "os.h"
|
||||||
|
#include "os/xsha1.h"
|
||||||
|
#include "tests-common.h"
|
||||||
|
|
||||||
|
static void
|
||||||
|
raw_to_hex(const unsigned char *raw, size_t raw_size,
|
||||||
|
unsigned char *hex, size_t hex_size)
|
||||||
|
{
|
||||||
|
static const char *hex_digits = "0123456789abcdef";
|
||||||
|
size_t i, o;
|
||||||
|
|
||||||
|
assert(hex_size >= (raw_size * 2) + 1);
|
||||||
|
|
||||||
|
for (i = o = 0; i < raw_size; i++) {
|
||||||
|
hex[o++] = hex_digits[raw[i] >> 4];
|
||||||
|
hex[o++] = hex_digits[raw[i] & 0x0f];
|
||||||
|
}
|
||||||
|
hex[o] = '\0';
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
sha1_test_repeated_blocks(void *data, size_t length, unsigned int repeat,
|
||||||
|
const char *expected_hash)
|
||||||
|
{
|
||||||
|
void *ctx;
|
||||||
|
unsigned char raw_result[20];
|
||||||
|
unsigned char hex_result[41];
|
||||||
|
|
||||||
|
assert((ctx = x_sha1_init()) != NULL);
|
||||||
|
for (unsigned int i = 0; i < repeat; i++) {
|
||||||
|
assert(x_sha1_update(ctx, data, length) == 1);
|
||||||
|
}
|
||||||
|
assert(x_sha1_final(ctx, raw_result) == 1);
|
||||||
|
raw_to_hex(raw_result, sizeof(raw_result), hex_result, sizeof(hex_result));
|
||||||
|
assert(strcmp((char *)hex_result, expected_hash) == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
sha1_test_string(const char *string, const char *expected_hash)
|
||||||
|
{
|
||||||
|
sha1_test_repeated_blocks((void *) string, strlen(string), 1, expected_hash);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
sha1_checks(void)
|
||||||
|
{
|
||||||
|
char test_data[4096];
|
||||||
|
|
||||||
|
/* some test data of our own */
|
||||||
|
sha1_test_string("This is a test. This is only a test.\n",
|
||||||
|
"7679a5fb1320e69f4550c84560fc6ef10ace4550");
|
||||||
|
|
||||||
|
memset(test_data, 'X', sizeof(test_data));
|
||||||
|
sha1_test_repeated_blocks(test_data, sizeof(test_data), 11,
|
||||||
|
"5392c69de307625c9ff5e7d8190332857deac9f9");
|
||||||
|
|
||||||
|
/* Test data from https://di-mgt.com.au/sha_testvectors.html */
|
||||||
|
sha1_test_string("abc",
|
||||||
|
"a9993e364706816aba3e25717850c26c9cd0d89d");
|
||||||
|
|
||||||
|
sha1_test_string("",
|
||||||
|
"da39a3ee5e6b4b0d3255bfef95601890afd80709");
|
||||||
|
|
||||||
|
sha1_test_string("abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq",
|
||||||
|
"84983e441c3bd26ebaae4aa1f95129e5e54670f1");
|
||||||
|
|
||||||
|
sha1_test_string("abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmn"
|
||||||
|
"hijklmnoijklmnopjklmnopqklmnopqrlmnopqrsmnopqrstnopqrstu",
|
||||||
|
"a49b2446a02c645bf419f995b67091253a04a259");
|
||||||
|
|
||||||
|
memset(test_data, 'a', 4000);
|
||||||
|
sha1_test_repeated_blocks(test_data, 4000, 250, /* 4000 * 250 = 1 million */
|
||||||
|
"34aa973cd4c4daa4f61eeb2bdbad27316534016f");
|
||||||
|
|
||||||
|
const char *long_string = /* 64 bytes long */
|
||||||
|
"abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmnhijklmno";
|
||||||
|
const size_t long_length = strlen(long_string);
|
||||||
|
assert((sizeof(test_data) % long_length) == 0);
|
||||||
|
for (size_t i = 0; i < (sizeof(test_data) / long_length) ; i++) {
|
||||||
|
memcpy(test_data + (i * long_length), long_string, long_length);
|
||||||
|
}
|
||||||
|
sha1_test_repeated_blocks(test_data, sizeof(test_data),
|
||||||
|
16777216 / (sizeof(test_data) / long_length),
|
||||||
|
"7789f0c9ef7bfc40d93311143dfbe69e2017f592");
|
||||||
|
}
|
||||||
|
|
||||||
|
const testfunc_t*
|
||||||
|
sha1_test(void)
|
||||||
|
{
|
||||||
|
static const testfunc_t testfuncs[] = {
|
||||||
|
sha1_checks,
|
||||||
|
NULL,
|
||||||
|
};
|
||||||
|
|
||||||
|
return testfuncs;
|
||||||
|
}
|
||||||
|
|
@ -8,6 +8,7 @@ int
|
||||||
main(int argc, char **argv)
|
main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
run_test(list_test);
|
run_test(list_test);
|
||||||
|
run_test(sha1_test);
|
||||||
run_test(string_test);
|
run_test(string_test);
|
||||||
|
|
||||||
#ifdef XORG_TESTS
|
#ifdef XORG_TESTS
|
||||||
|
|
|
||||||
|
|
@ -28,6 +28,7 @@ const testfunc_t* hashtabletest_test(void);
|
||||||
const testfunc_t* input_test(void);
|
const testfunc_t* input_test(void);
|
||||||
const testfunc_t* list_test(void);
|
const testfunc_t* list_test(void);
|
||||||
const testfunc_t* misc_test(void);
|
const testfunc_t* misc_test(void);
|
||||||
|
const testfunc_t* sha1_test(void);
|
||||||
const testfunc_t* signal_logging_test(void);
|
const testfunc_t* signal_logging_test(void);
|
||||||
const testfunc_t* string_test(void);
|
const testfunc_t* string_test(void);
|
||||||
const testfunc_t* touch_test(void);
|
const testfunc_t* touch_test(void);
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue