2014-12-10 19:18:42 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 Philipp Rosenkranz
|
|
|
|
* Copyright (C) 2013 Freie Universität Berlin
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
#include "tests-bloom.h"
|
|
|
|
|
|
|
|
#include "hashes.h"
|
|
|
|
#include "bloom.h"
|
2015-09-01 21:44:18 +02:00
|
|
|
#include "bitfield.h"
|
2014-12-10 19:18:42 +01:00
|
|
|
|
|
|
|
#include "tests-bloom-sets.h"
|
|
|
|
|
2015-01-29 15:06:01 +01:00
|
|
|
#define TESTS_BLOOM_BITS (128)
|
2014-12-10 19:18:42 +01:00
|
|
|
#define TESTS_BLOOM_HASHF (6)
|
|
|
|
#define TESTS_BLOOM_PROB_IN_FILTER (4)
|
|
|
|
#define TESTS_BLOOM_NOT_IN_FILTER (996)
|
|
|
|
#define TESTS_BLOOM_FALSE_POS_RATE_THR (0.005)
|
|
|
|
|
2015-09-01 21:44:18 +02:00
|
|
|
static bloom_t bloom;
|
|
|
|
BITFIELD(bf, TESTS_BLOOM_BITS);
|
|
|
|
hashfp_t hashes[TESTS_BLOOM_HASHF] = {
|
|
|
|
(hashfp_t) fnv_hash,
|
|
|
|
(hashfp_t) sax_hash,
|
|
|
|
(hashfp_t) sdbm_hash,
|
|
|
|
(hashfp_t) djb2_hash,
|
|
|
|
(hashfp_t) kr_hash,
|
|
|
|
(hashfp_t) dek_hash,
|
|
|
|
};
|
2014-12-10 19:18:42 +01:00
|
|
|
|
|
|
|
static void load_dictionary_fixture(void)
|
|
|
|
{
|
|
|
|
for (int i = 0; i < lenB; i++)
|
|
|
|
{
|
2015-09-01 21:44:18 +02:00
|
|
|
bloom_add(&bloom, (const uint8_t *) B[i], strlen(B[i]));
|
2014-12-10 19:18:42 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
static void set_up_bloom(void)
|
|
|
|
{
|
2015-09-01 21:44:18 +02:00
|
|
|
bloom_init(&bloom, TESTS_BLOOM_BITS, bf, hashes, TESTS_BLOOM_HASHF);
|
2014-12-10 19:18:42 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static void tear_down_bloom(void)
|
|
|
|
{
|
2015-09-01 21:44:18 +02:00
|
|
|
bloom_del(&bloom);
|
2014-12-10 19:18:42 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static void test_bloom_parameters_bytes_hashf(void)
|
|
|
|
{
|
2015-09-01 21:44:18 +02:00
|
|
|
TEST_ASSERT_EQUAL_INT(TESTS_BLOOM_BITS, bloom.m);
|
|
|
|
TEST_ASSERT_EQUAL_INT(TESTS_BLOOM_HASHF, bloom.k);
|
2014-12-10 19:18:42 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static void test_bloom_based_on_dictionary_fixture(void)
|
|
|
|
{
|
|
|
|
int in = 0;
|
|
|
|
int not_in = 0;
|
2023-02-02 15:18:45 +01:00
|
|
|
int false_positive_rate = 0;
|
2014-12-10 19:18:42 +01:00
|
|
|
|
|
|
|
load_dictionary_fixture();
|
|
|
|
|
|
|
|
for (int i = 0; i < lenA; i++)
|
|
|
|
{
|
2015-09-01 21:44:18 +02:00
|
|
|
if (bloom_check(&bloom, (const uint8_t *) A[i], strlen(A[i])))
|
2014-12-10 19:18:42 +01:00
|
|
|
{
|
|
|
|
in++;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
not_in++;
|
|
|
|
}
|
|
|
|
}
|
2023-02-02 15:18:45 +01:00
|
|
|
false_positive_rate = (1000 * in) / lenA;
|
2014-12-10 19:18:42 +01:00
|
|
|
|
|
|
|
TEST_ASSERT_EQUAL_INT(TESTS_BLOOM_PROB_IN_FILTER, in);
|
|
|
|
TEST_ASSERT_EQUAL_INT(TESTS_BLOOM_NOT_IN_FILTER, not_in);
|
2023-02-02 15:18:45 +01:00
|
|
|
TEST_ASSERT(false_positive_rate < TESTS_BLOOM_FALSE_POS_RATE_THR * 1000);
|
2014-12-10 19:18:42 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
Test *tests_bloom_tests(void)
|
|
|
|
{
|
|
|
|
EMB_UNIT_TESTFIXTURES(fixtures) {
|
|
|
|
new_TestFixture(test_bloom_parameters_bytes_hashf),
|
|
|
|
new_TestFixture(test_bloom_based_on_dictionary_fixture),
|
|
|
|
};
|
|
|
|
|
|
|
|
EMB_UNIT_TESTCALLER(bloom_tests, set_up_bloom, tear_down_bloom, fixtures);
|
|
|
|
|
|
|
|
return (Test *)&bloom_tests;
|
|
|
|
}
|
|
|
|
|
|
|
|
void tests_bloom(void)
|
|
|
|
{
|
|
|
|
TESTS_RUN(tests_bloom_tests());
|
|
|
|
}
|