mirror of
https://gitlab.freedesktop.org/xorg/xserver.git
synced 2025-12-20 04:40:02 +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',
|
||||
'list.c',
|
||||
'misc.c',
|
||||
'sha1.c',
|
||||
'signal-logging.c',
|
||||
'string.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)
|
||||
{
|
||||
run_test(list_test);
|
||||
run_test(sha1_test);
|
||||
run_test(string_test);
|
||||
|
||||
#ifdef XORG_TESTS
|
||||
|
|
|
|||
|
|
@ -28,6 +28,7 @@ const testfunc_t* hashtabletest_test(void);
|
|||
const testfunc_t* input_test(void);
|
||||
const testfunc_t* list_test(void);
|
||||
const testfunc_t* misc_test(void);
|
||||
const testfunc_t* sha1_test(void);
|
||||
const testfunc_t* signal_logging_test(void);
|
||||
const testfunc_t* string_test(void);
|
||||
const testfunc_t* touch_test(void);
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue