Blame tests/core/oidmap.c

Packit ae9e2a
#include "clar_libgit2.h"
Packit ae9e2a
#include "oidmap.h"
Packit ae9e2a
Packit ae9e2a
typedef struct {
Packit ae9e2a
	git_oid oid;
Packit ae9e2a
	size_t extra;
Packit ae9e2a
} oidmap_item;
Packit ae9e2a
Packit ae9e2a
#define NITEMS 0x0fff
Packit ae9e2a
Packit ae9e2a
void test_core_oidmap__basic(void)
Packit ae9e2a
{
Packit ae9e2a
	git_oidmap *map;
Packit ae9e2a
	oidmap_item items[NITEMS];
Packit ae9e2a
	uint32_t i, j;
Packit ae9e2a
Packit ae9e2a
	for (i = 0; i < NITEMS; ++i) {
Packit ae9e2a
		items[i].extra = i;
Packit ae9e2a
		for (j = 0; j < GIT_OID_RAWSZ / 4; ++j) {
Packit ae9e2a
			items[i].oid.id[j * 4    ] = (unsigned char)i;
Packit ae9e2a
			items[i].oid.id[j * 4 + 1] = (unsigned char)(i >> 8);
Packit ae9e2a
			items[i].oid.id[j * 4 + 2] = (unsigned char)(i >> 16);
Packit ae9e2a
			items[i].oid.id[j * 4 + 3] = (unsigned char)(i >> 24);
Packit ae9e2a
		}
Packit ae9e2a
	}
Packit ae9e2a
Packit ae9e2a
	map = git_oidmap_alloc();
Packit ae9e2a
	cl_assert(map != NULL);
Packit ae9e2a
Packit ae9e2a
	for (i = 0; i < NITEMS; ++i) {
Packit ae9e2a
		khiter_t pos;
Packit ae9e2a
		int ret;
Packit ae9e2a
Packit ae9e2a
		pos = git_oidmap_lookup_index(map, &items[i].oid);
Packit ae9e2a
		cl_assert(!git_oidmap_valid_index(map, pos));
Packit ae9e2a
Packit ae9e2a
		pos = git_oidmap_put(map, &items[i].oid, &ret;;
Packit ae9e2a
		cl_assert(ret != 0);
Packit ae9e2a
Packit ae9e2a
		git_oidmap_set_value_at(map, pos, &items[i]);
Packit ae9e2a
	}
Packit ae9e2a
Packit ae9e2a
Packit ae9e2a
	for (i = 0; i < NITEMS; ++i) {
Packit ae9e2a
		khiter_t pos;
Packit ae9e2a
Packit ae9e2a
		pos = git_oidmap_lookup_index(map, &items[i].oid);
Packit ae9e2a
		cl_assert(git_oidmap_valid_index(map, pos));
Packit ae9e2a
Packit ae9e2a
		cl_assert_equal_p(git_oidmap_value_at(map, pos), &items[i]);
Packit ae9e2a
	}
Packit ae9e2a
Packit ae9e2a
	git_oidmap_free(map);
Packit ae9e2a
}
Packit ae9e2a
Packit ae9e2a
void test_core_oidmap__hash_collision(void)
Packit ae9e2a
{
Packit ae9e2a
	git_oidmap *map;
Packit ae9e2a
	oidmap_item items[NITEMS];
Packit ae9e2a
	uint32_t i, j;
Packit ae9e2a
Packit ae9e2a
	for (i = 0; i < NITEMS; ++i) {
Packit ae9e2a
		uint32_t segment = i / 8;
Packit ae9e2a
		int modi = i - (segment * 8);
Packit ae9e2a
Packit ae9e2a
		items[i].extra = i;
Packit ae9e2a
Packit ae9e2a
		for (j = 0; j < GIT_OID_RAWSZ / 4; ++j) {
Packit ae9e2a
			items[i].oid.id[j * 4    ] = (unsigned char)modi;
Packit ae9e2a
			items[i].oid.id[j * 4 + 1] = (unsigned char)(modi >> 8);
Packit ae9e2a
			items[i].oid.id[j * 4 + 2] = (unsigned char)(modi >> 16);
Packit ae9e2a
			items[i].oid.id[j * 4 + 3] = (unsigned char)(modi >> 24);
Packit ae9e2a
		}
Packit ae9e2a
Packit ae9e2a
		items[i].oid.id[ 8] = (unsigned char)i;
Packit ae9e2a
		items[i].oid.id[ 9] = (unsigned char)(i >> 8);
Packit ae9e2a
		items[i].oid.id[10] = (unsigned char)(i >> 16);
Packit ae9e2a
		items[i].oid.id[11] = (unsigned char)(i >> 24);
Packit ae9e2a
	}
Packit ae9e2a
Packit ae9e2a
	map = git_oidmap_alloc();
Packit ae9e2a
	cl_assert(map != NULL);
Packit ae9e2a
Packit ae9e2a
	for (i = 0; i < NITEMS; ++i) {
Packit ae9e2a
		khiter_t pos;
Packit ae9e2a
		int ret;
Packit ae9e2a
Packit ae9e2a
		pos = git_oidmap_lookup_index(map, &items[i].oid);
Packit ae9e2a
		cl_assert(!git_oidmap_valid_index(map, pos));
Packit ae9e2a
Packit ae9e2a
		pos = git_oidmap_put(map, &items[i].oid, &ret;;
Packit ae9e2a
		cl_assert(ret != 0);
Packit ae9e2a
Packit ae9e2a
		git_oidmap_set_value_at(map, pos, &items[i]);
Packit ae9e2a
	}
Packit ae9e2a
Packit ae9e2a
Packit ae9e2a
	for (i = 0; i < NITEMS; ++i) {
Packit ae9e2a
		khiter_t pos;
Packit ae9e2a
Packit ae9e2a
		pos = git_oidmap_lookup_index(map, &items[i].oid);
Packit ae9e2a
		cl_assert(git_oidmap_valid_index(map, pos));
Packit ae9e2a
Packit ae9e2a
		cl_assert_equal_p(git_oidmap_value_at(map, pos), &items[i]);
Packit ae9e2a
	}
Packit ae9e2a
Packit ae9e2a
	git_oidmap_free(map);
Packit ae9e2a
}