/* * 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 #include #include #include #include #include #include #include #include #include #include #include #include #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()); }