1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-05 13:18:20 +03:00
lvm2/test/unit/dmhash_t.c
Zdenek Kabelac a0c5b2c9fd tests: add basics for dm_hash unit testing
Better code coverage.
2024-05-14 17:59:26 +02:00

62 lines
1.8 KiB
C

/*
* Copyright (C) 2024 Red Hat, Inc. All rights reserved.
*
* This file is part of LVM2.
*
* This copyrighted material is made available to anyone wishing to use,
* modify, copy, or redistribute it subject to the terms and conditions
* of the GNU General Public License v.2.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include "units.h"
#include "device_mapper/all.h"
static void test_hash_insert(void *fixture)
{
static const char _keys[] = { '1', '2', '3', '4', '5' };
static const long _vals[] = { 'a', 'b', 'c', 'd', 'e' };
struct dm_hash_node *node;
unsigned i;
struct dm_hash_table *hash = dm_hash_create(10);
T_ASSERT(hash);
for (i = 0; i < DM_ARRAY_SIZE(_keys); i++)
T_ASSERT(dm_hash_insert_binary(hash, &_keys[i], sizeof(_keys[0]), (void*)_vals[i]));
T_ASSERT(dm_hash_get_num_entries(hash) == DM_ARRAY_SIZE(_keys));
/* list unsorted elements */
for (node = dm_hash_get_first(hash); node; node = dm_hash_get_next(hash, node), --i) {
const char *k = dm_hash_get_key(hash, node);
char key = k[0];
void *d = dm_hash_get_data(hash, node);
//long v = (long) d;
//printf("key: %c val: %c\n", key, (char)v);
T_ASSERT(d == dm_hash_lookup_binary(hash, &key, sizeof(key)));
}
T_ASSERT(i == 0);
dm_hash_destroy(hash);
}
#define T(path, desc, fn) register_test(ts, "/base/data-struct/hash/" path, desc, fn)
void dm_hash_tests(struct dm_list *all_tests)
{
struct test_suite *ts = test_suite_create(NULL, NULL);
if (!ts) {
fprintf(stderr, "out of memory\n");
exit(1);
}
T("insert", "inserting hash elements", test_hash_insert);
dm_list_add(all_tests, &ts->list);
}