mirror of
https://github.com/isc-projects/bind9.git
synced 2026-04-28 01:28:05 -04:00
172 lines
4 KiB
C
172 lines
4 KiB
C
/*
|
|
* Copyright (C) Internet Systems Consortium, Inc. ("ISC")
|
|
*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
*
|
|
* See the COPYRIGHT file distributed with this work for additional
|
|
* information regarding copyright ownership.
|
|
*/
|
|
|
|
/* ! \file */
|
|
|
|
#include <config.h>
|
|
|
|
#include <atf-c.h>
|
|
|
|
#include <inttypes.h>
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
|
|
#include <isc/buffer.h>
|
|
#include <isc/hash.h>
|
|
#include <isc/hex.h>
|
|
#include <isc/region.h>
|
|
|
|
#include <isc/util.h>
|
|
#include <isc/print.h>
|
|
#include <isc/string.h>
|
|
|
|
#include <pk11/site.h>
|
|
|
|
#define TEST_INPUT(x) (x), sizeof(x)-1
|
|
|
|
typedef struct hash_testcase {
|
|
const char *input;
|
|
size_t input_len;
|
|
const char *result;
|
|
int repeats;
|
|
} hash_testcase_t;
|
|
|
|
ATF_TC(isc_hash_function);
|
|
ATF_TC_HEAD(isc_hash_function, tc) {
|
|
atf_tc_set_md_var(tc, "descr", "Hash function test");
|
|
}
|
|
ATF_TC_BODY(isc_hash_function, tc) {
|
|
unsigned int h1;
|
|
unsigned int h2;
|
|
|
|
UNUSED(tc);
|
|
|
|
/* Incremental hashing */
|
|
|
|
h1 = isc_hash_function(NULL, 0, true, NULL);
|
|
h1 = isc_hash_function("This ", 5, true, &h1);
|
|
h1 = isc_hash_function("is ", 3, true, &h1);
|
|
h1 = isc_hash_function("a long test", 12, true, &h1);
|
|
|
|
h2 = isc_hash_function("This is a long test", 20,
|
|
true, NULL);
|
|
|
|
ATF_CHECK_EQ(h1, h2);
|
|
|
|
/* Immutability of hash function */
|
|
h1 = isc_hash_function(NULL, 0, true, NULL);
|
|
h2 = isc_hash_function(NULL, 0, true, NULL);
|
|
|
|
ATF_CHECK_EQ(h1, h2);
|
|
|
|
/* Hash function characteristics */
|
|
h1 = isc_hash_function("Hello world", 12, true, NULL);
|
|
h2 = isc_hash_function("Hello world", 12, true, NULL);
|
|
|
|
ATF_CHECK_EQ(h1, h2);
|
|
|
|
/* Case */
|
|
h1 = isc_hash_function("Hello world", 12, false, NULL);
|
|
h2 = isc_hash_function("heLLo WorLd", 12, false, NULL);
|
|
|
|
ATF_CHECK_EQ(h1, h2);
|
|
|
|
/* Unequal */
|
|
h1 = isc_hash_function("Hello world", 12, true, NULL);
|
|
h2 = isc_hash_function("heLLo WorLd", 12, true, NULL);
|
|
|
|
ATF_CHECK(h1 != h2);
|
|
}
|
|
|
|
ATF_TC(isc_hash_function_reverse);
|
|
ATF_TC_HEAD(isc_hash_function_reverse, tc) {
|
|
atf_tc_set_md_var(tc, "descr", "Reverse hash function test");
|
|
}
|
|
ATF_TC_BODY(isc_hash_function_reverse, tc) {
|
|
unsigned int h1;
|
|
unsigned int h2;
|
|
|
|
UNUSED(tc);
|
|
|
|
/* Incremental hashing */
|
|
|
|
h1 = isc_hash_function_reverse(NULL, 0, true, NULL);
|
|
h1 = isc_hash_function_reverse("\000", 1, true, &h1);
|
|
h1 = isc_hash_function_reverse("\003org", 4, true, &h1);
|
|
h1 = isc_hash_function_reverse("\007example", 8, true, &h1);
|
|
|
|
h2 = isc_hash_function_reverse("\007example\003org\000", 13,
|
|
true, NULL);
|
|
|
|
ATF_CHECK_EQ(h1, h2);
|
|
|
|
/* Immutability of hash function */
|
|
h1 = isc_hash_function_reverse(NULL, 0, true, NULL);
|
|
h2 = isc_hash_function_reverse(NULL, 0, true, NULL);
|
|
|
|
ATF_CHECK_EQ(h1, h2);
|
|
|
|
/* Hash function characteristics */
|
|
h1 = isc_hash_function_reverse("Hello world", 12, true, NULL);
|
|
h2 = isc_hash_function_reverse("Hello world", 12, true, NULL);
|
|
|
|
ATF_CHECK_EQ(h1, h2);
|
|
|
|
/* Case */
|
|
h1 = isc_hash_function_reverse("Hello world", 12, false, NULL);
|
|
h2 = isc_hash_function_reverse("heLLo WorLd", 12, false, NULL);
|
|
|
|
ATF_CHECK_EQ(h1, h2);
|
|
|
|
/* Unequal */
|
|
h1 = isc_hash_function_reverse("Hello world", 12, true, NULL);
|
|
h2 = isc_hash_function_reverse("heLLo WorLd", 12, true, NULL);
|
|
|
|
ATF_CHECK(h1 != h2);
|
|
}
|
|
|
|
ATF_TC(isc_hash_initializer);
|
|
ATF_TC_HEAD(isc_hash_initializer, tc) {
|
|
atf_tc_set_md_var(tc, "descr", "Hash function initializer test");
|
|
}
|
|
ATF_TC_BODY(isc_hash_initializer, tc) {
|
|
unsigned int h1;
|
|
unsigned int h2;
|
|
|
|
UNUSED(tc);
|
|
|
|
h1 = isc_hash_function("Hello world", 12, true, NULL);
|
|
h2 = isc_hash_function("Hello world", 12, true, NULL);
|
|
|
|
ATF_CHECK_EQ(h1, h2);
|
|
|
|
isc_hash_set_initializer(isc_hash_get_initializer());
|
|
|
|
/* Hash value must not change */
|
|
h2 = isc_hash_function("Hello world", 12, true, NULL);
|
|
|
|
ATF_CHECK_EQ(h1, h2);
|
|
}
|
|
|
|
/*
|
|
* Main
|
|
*/
|
|
ATF_TP_ADD_TCS(tp) {
|
|
/*
|
|
* Tests of isc_hash functions.
|
|
*/
|
|
|
|
ATF_TP_ADD_TC(tp, isc_hash_function);
|
|
ATF_TP_ADD_TC(tp, isc_hash_function_reverse);
|
|
ATF_TP_ADD_TC(tp, isc_hash_initializer);
|
|
|
|
return (atf_no_error());
|
|
}
|