Home | History | Annotate | Line # | Download | only in isc
crc64_test.c revision 1.1
      1  1.1  christos /*	$NetBSD: crc64_test.c,v 1.1 2024/02/21 21:54:54 christos Exp $	*/
      2  1.1  christos 
      3  1.1  christos /*
      4  1.1  christos  * Copyright (C) Internet Systems Consortium, Inc. ("ISC")
      5  1.1  christos  *
      6  1.1  christos  * SPDX-License-Identifier: MPL-2.0
      7  1.1  christos  *
      8  1.1  christos  * This Source Code Form is subject to the terms of the Mozilla Public
      9  1.1  christos  * License, v. 2.0. If a copy of the MPL was not distributed with this
     10  1.1  christos  * file, you can obtain one at https://mozilla.org/MPL/2.0/.
     11  1.1  christos  *
     12  1.1  christos  * See the COPYRIGHT file distributed with this work for additional
     13  1.1  christos  * information regarding copyright ownership.
     14  1.1  christos  */
     15  1.1  christos 
     16  1.1  christos /* ! \file */
     17  1.1  christos 
     18  1.1  christos #include <inttypes.h>
     19  1.1  christos #include <sched.h> /* IWYU pragma: keep */
     20  1.1  christos #include <setjmp.h>
     21  1.1  christos #include <stdarg.h>
     22  1.1  christos #include <stddef.h>
     23  1.1  christos #include <stdlib.h>
     24  1.1  christos #include <string.h>
     25  1.1  christos 
     26  1.1  christos #define UNIT_TESTING
     27  1.1  christos #include <cmocka.h>
     28  1.1  christos 
     29  1.1  christos #include <isc/crc64.h>
     30  1.1  christos #include <isc/print.h>
     31  1.1  christos #include <isc/result.h>
     32  1.1  christos #include <isc/util.h>
     33  1.1  christos 
     34  1.1  christos #include <tests/isc.h>
     35  1.1  christos 
     36  1.1  christos #define TEST_INPUT(x) (x), sizeof(x) - 1
     37  1.1  christos 
     38  1.1  christos ISC_RUN_TEST_IMPL(isc_crc64_init) {
     39  1.1  christos 	uint64_t crc;
     40  1.1  christos 
     41  1.1  christos 	isc_crc64_init(&crc);
     42  1.1  christos 	assert_int_equal(crc, 0xffffffffffffffffUL);
     43  1.1  christos }
     44  1.1  christos 
     45  1.1  christos static void
     46  1.1  christos _crc64(const char *buf, size_t buflen, const char *result, const int repeats) {
     47  1.1  christos 	uint64_t crc;
     48  1.1  christos 
     49  1.1  christos 	isc_crc64_init(&crc);
     50  1.1  christos 	assert_int_equal(crc, 0xffffffffffffffffUL);
     51  1.1  christos 
     52  1.1  christos 	for (int i = 0; i < repeats; i++) {
     53  1.1  christos 		isc_crc64_update(&crc, buf, buflen);
     54  1.1  christos 	}
     55  1.1  christos 
     56  1.1  christos 	isc_crc64_final(&crc);
     57  1.1  christos 
     58  1.1  christos 	char hex[16 + 1];
     59  1.1  christos 	snprintf(hex, sizeof(hex), "%016" PRIX64, crc);
     60  1.1  christos 
     61  1.1  christos 	assert_memory_equal(hex, result, (result ? strlen(result) : 0));
     62  1.1  christos }
     63  1.1  christos 
     64  1.1  christos /* 64-bit cyclic redundancy check */
     65  1.1  christos ISC_RUN_TEST_IMPL(isc_crc64) {
     66  1.1  christos 	_crc64(TEST_INPUT(""), "0000000000000000", 1);
     67  1.1  christos 	_crc64(TEST_INPUT("a"), "CE73F427ACC0A99A", 1);
     68  1.1  christos 	_crc64(TEST_INPUT("abc"), "048B813AF9F49702", 1);
     69  1.1  christos 	_crc64(TEST_INPUT("message digest"), "5273F9EA7A357BF4", 1);
     70  1.1  christos 	_crc64(TEST_INPUT("abcdefghijklmnopqrstuvwxyz"), "59F079F9218BAAA1", 1);
     71  1.1  christos 	_crc64(TEST_INPUT("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklm"
     72  1.1  christos 			  "nopqrstuvwxyz0123456789"),
     73  1.1  christos 	       "A36DA8F71E78B6FB", 1);
     74  1.1  christos 	_crc64(TEST_INPUT("123456789012345678901234567890123456789"
     75  1.1  christos 			  "01234567890123456789012345678901234567890"),
     76  1.1  christos 	       "81E5EB73C8E7874A", 1);
     77  1.1  christos }
     78  1.1  christos 
     79  1.1  christos ISC_TEST_LIST_START
     80  1.1  christos 
     81  1.1  christos ISC_TEST_ENTRY(isc_crc64_init)
     82  1.1  christos ISC_TEST_ENTRY(isc_crc64)
     83  1.1  christos 
     84  1.1  christos ISC_TEST_LIST_END
     85  1.1  christos 
     86  1.1  christos ISC_TEST_MAIN
     87