blob: 5b893327d6598334df16902390302a338b1c5831 [file] [log] [blame]
/*
* Copyright (c) 2022 Meta
*
* SPDX-License-Identifier: Apache-2.0
*/
#include <zephyr/ztest.h>
#include <zephyr/sys/hash_map.h>
#include "_main.h"
ZTEST(hash_map, test_load_factor_default)
{
int ret;
uint32_t load_factor;
zassert_true(sys_hashmap_is_empty(&map));
zassert_equal(0, sys_hashmap_load_factor(&map));
for (size_t i = 0; i < MANY; ++i) {
ret = sys_hashmap_insert(&map, i, i, NULL);
zassert_equal(1, ret, "failed to insert (%zu, %zu): %d", i, i, ret);
load_factor = sys_hashmap_load_factor(&map);
zassert_true(load_factor > 0 && load_factor <= SYS_HASHMAP_DEFAULT_LOAD_FACTOR);
}
for (size_t i = MANY; i > 0; --i) {
zassert_equal(true, sys_hashmap_remove(&map, i - 1, NULL));
load_factor = sys_hashmap_load_factor(&map);
zassert_true(load_factor <= SYS_HASHMAP_DEFAULT_LOAD_FACTOR);
}
}
ZTEST(hash_map, test_load_factor_custom)
{
int ret;
uint32_t load_factor;
struct sys_hashmap *const map = &custom_load_factor_map;
zassert_equal(map->config->load_factor, CUSTOM_LOAD_FACTOR);
zassert_true(sys_hashmap_is_empty(map));
zassert_equal(0, sys_hashmap_load_factor(map));
for (size_t i = 0; i < MANY; ++i) {
ret = sys_hashmap_insert(map, i, i, NULL);
zassert_equal(1, ret, "failed to insert (%zu, %zu): %d", i, i, ret);
load_factor = sys_hashmap_load_factor(map);
zassert_true(load_factor > 0 && load_factor <= CUSTOM_LOAD_FACTOR);
}
for (size_t i = MANY; i > 0; --i) {
zassert_equal(true, sys_hashmap_remove(map, i - 1, NULL));
load_factor = sys_hashmap_load_factor(map);
zassert_true(load_factor <= CUSTOM_LOAD_FACTOR);
}
}