| 1 | // SPDX-License-Identifier: GPL-2.0 |
| 2 | #include "tests.h" |
| 3 | #include "util/debug.h" |
| 4 | #include "util/sha1.h" |
| 5 | |
| 6 | #include <linux/compiler.h> |
| 7 | #include <stdlib.h> |
| 8 | #include <string2.h> |
| 9 | |
| 10 | static int test_strreplace(char needle, const char *haystack, |
| 11 | const char *replace, const char *expected) |
| 12 | { |
| 13 | char *new = strreplace_chars(needle, haystack, replace); |
| 14 | int ret = strcmp(new, expected); |
| 15 | |
| 16 | free(new); |
| 17 | return ret == 0; |
| 18 | } |
| 19 | |
| 20 | #define MAX_LEN 512 |
| 21 | |
| 22 | /* Test sha1() for all lengths from 0 to MAX_LEN inclusively. */ |
| 23 | static int test_sha1(void) |
| 24 | { |
| 25 | u8 data[MAX_LEN]; |
| 26 | size_t digests_size = (MAX_LEN + 1) * SHA1_DIGEST_SIZE; |
| 27 | u8 *digests; |
| 28 | u8 digest_of_digests[SHA1_DIGEST_SIZE]; |
| 29 | /* |
| 30 | * The correctness of this value was verified by running this test with |
| 31 | * sha1() replaced by OpenSSL's SHA1(). |
| 32 | */ |
| 33 | static const u8 expected_digest_of_digests[SHA1_DIGEST_SIZE] = { |
| 34 | 0x74, 0xcd, 0x4c, 0xb9, 0xd8, 0xa6, 0xd5, 0x95, 0x22, 0x8b, |
| 35 | 0x7e, 0xd6, 0x8b, 0x7e, 0x46, 0x95, 0x31, 0x9b, 0xa2, 0x43, |
| 36 | }; |
| 37 | size_t i; |
| 38 | |
| 39 | digests = malloc(digests_size); |
| 40 | TEST_ASSERT_VAL("failed to allocate digests" , digests != NULL); |
| 41 | |
| 42 | /* Generate MAX_LEN bytes of data. */ |
| 43 | for (i = 0; i < MAX_LEN; i++) |
| 44 | data[i] = i; |
| 45 | |
| 46 | /* Calculate a SHA-1 for each length 0 through MAX_LEN inclusively. */ |
| 47 | for (i = 0; i <= MAX_LEN; i++) |
| 48 | sha1(data, i, &digests[i * SHA1_DIGEST_SIZE]); |
| 49 | |
| 50 | /* Calculate digest of all digests calculated above. */ |
| 51 | sha1(digests, digests_size, digest_of_digests); |
| 52 | |
| 53 | free(digests); |
| 54 | |
| 55 | /* Check for the expected result. */ |
| 56 | TEST_ASSERT_VAL("wrong output from sha1()" , |
| 57 | memcmp(digest_of_digests, expected_digest_of_digests, |
| 58 | SHA1_DIGEST_SIZE) == 0); |
| 59 | return 0; |
| 60 | } |
| 61 | |
| 62 | static int test__util(struct test_suite *t __maybe_unused, int subtest __maybe_unused) |
| 63 | { |
| 64 | TEST_ASSERT_VAL("empty string" , test_strreplace(' ', "" , "123" , "" )); |
| 65 | TEST_ASSERT_VAL("no match" , test_strreplace('5', "123" , "4" , "123" )); |
| 66 | TEST_ASSERT_VAL("replace 1" , test_strreplace('3', "123" , "4" , "124" )); |
| 67 | TEST_ASSERT_VAL("replace 2" , test_strreplace('a', "abcabc" , "ef" , "efbcefbc" )); |
| 68 | TEST_ASSERT_VAL("replace long" , test_strreplace('a', "abcabc" , "longlong" , |
| 69 | "longlongbclonglongbc" )); |
| 70 | |
| 71 | return test_sha1(); |
| 72 | } |
| 73 | |
| 74 | DEFINE_SUITE("util" , util); |
| 75 | |