redict/deps/jemalloc/test/unit/bitmap.c

160 lines
3.5 KiB
C
Raw Normal View History

#include "test/jemalloc_test.h"
2011-05-09 04:52:55 -04:00
TEST_BEGIN(test_bitmap_size)
2011-05-09 04:52:55 -04:00
{
size_t i, prev_size;
prev_size = 0;
2015-10-06 10:18:30 -04:00
for (i = 1; i <= BITMAP_MAXBITS; i++) {
2011-05-09 04:52:55 -04:00
size_t size = bitmap_size(i);
assert_true(size >= prev_size,
"Bitmap size is smaller than expected");
2011-05-09 04:52:55 -04:00
prev_size = size;
}
}
TEST_END
2011-05-09 04:52:55 -04:00
TEST_BEGIN(test_bitmap_init)
2011-05-09 04:52:55 -04:00
{
size_t i;
2015-10-06 10:18:30 -04:00
for (i = 1; i <= BITMAP_MAXBITS; i++) {
2011-05-09 04:52:55 -04:00
bitmap_info_t binfo;
bitmap_info_init(&binfo, i);
{
size_t j;
2015-10-06 10:18:30 -04:00
bitmap_t *bitmap = (bitmap_t *)malloc(sizeof(bitmap_t) *
bitmap_info_ngroups(&binfo));
2011-05-09 04:52:55 -04:00
bitmap_init(bitmap, &binfo);
for (j = 0; j < i; j++) {
assert_false(bitmap_get(bitmap, &binfo, j),
"Bit should be unset");
}
free(bitmap);
2011-05-09 04:52:55 -04:00
}
}
}
TEST_END
2011-05-09 04:52:55 -04:00
TEST_BEGIN(test_bitmap_set)
2011-05-09 04:52:55 -04:00
{
size_t i;
2015-10-06 10:18:30 -04:00
for (i = 1; i <= BITMAP_MAXBITS; i++) {
2011-05-09 04:52:55 -04:00
bitmap_info_t binfo;
bitmap_info_init(&binfo, i);
{
size_t j;
2015-10-06 10:18:30 -04:00
bitmap_t *bitmap = (bitmap_t *)malloc(sizeof(bitmap_t) *
bitmap_info_ngroups(&binfo));
2011-05-09 04:52:55 -04:00
bitmap_init(bitmap, &binfo);
for (j = 0; j < i; j++)
bitmap_set(bitmap, &binfo, j);
assert_true(bitmap_full(bitmap, &binfo),
"All bits should be set");
free(bitmap);
2011-05-09 04:52:55 -04:00
}
}
}
TEST_END
2011-05-09 04:52:55 -04:00
TEST_BEGIN(test_bitmap_unset)
2011-05-09 04:52:55 -04:00
{
size_t i;
2015-10-06 10:18:30 -04:00
for (i = 1; i <= BITMAP_MAXBITS; i++) {
2011-05-09 04:52:55 -04:00
bitmap_info_t binfo;
bitmap_info_init(&binfo, i);
{
size_t j;
2015-10-06 10:18:30 -04:00
bitmap_t *bitmap = (bitmap_t *)malloc(sizeof(bitmap_t) *
bitmap_info_ngroups(&binfo));
2011-05-09 04:52:55 -04:00
bitmap_init(bitmap, &binfo);
for (j = 0; j < i; j++)
bitmap_set(bitmap, &binfo, j);
assert_true(bitmap_full(bitmap, &binfo),
"All bits should be set");
2011-05-09 04:52:55 -04:00
for (j = 0; j < i; j++)
bitmap_unset(bitmap, &binfo, j);
for (j = 0; j < i; j++)
bitmap_set(bitmap, &binfo, j);
assert_true(bitmap_full(bitmap, &binfo),
"All bits should be set");
free(bitmap);
2011-05-09 04:52:55 -04:00
}
}
}
TEST_END
2011-05-09 04:52:55 -04:00
TEST_BEGIN(test_bitmap_sfu)
2011-05-09 04:52:55 -04:00
{
size_t i;
2015-10-06 10:18:30 -04:00
for (i = 1; i <= BITMAP_MAXBITS; i++) {
2011-05-09 04:52:55 -04:00
bitmap_info_t binfo;
bitmap_info_init(&binfo, i);
{
ssize_t j;
2015-10-06 10:18:30 -04:00
bitmap_t *bitmap = (bitmap_t *)malloc(sizeof(bitmap_t) *
bitmap_info_ngroups(&binfo));
2011-05-09 04:52:55 -04:00
bitmap_init(bitmap, &binfo);
/* Iteratively set bits starting at the beginning. */
for (j = 0; j < i; j++) {
assert_zd_eq(bitmap_sfu(bitmap, &binfo), j,
"First unset bit should be just after "
"previous first unset bit");
}
assert_true(bitmap_full(bitmap, &binfo),
"All bits should be set");
2011-05-09 04:52:55 -04:00
/*
* Iteratively unset bits starting at the end, and
* verify that bitmap_sfu() reaches the unset bits.
*/
for (j = i - 1; j >= 0; j--) {
bitmap_unset(bitmap, &binfo, j);
assert_zd_eq(bitmap_sfu(bitmap, &binfo), j,
"First unset bit should the bit previously "
"unset");
2011-05-09 04:52:55 -04:00
bitmap_unset(bitmap, &binfo, j);
}
assert_false(bitmap_get(bitmap, &binfo, 0),
"Bit should be unset");
2011-05-09 04:52:55 -04:00
/*
* Iteratively set bits starting at the beginning, and
* verify that bitmap_sfu() looks past them.
*/
for (j = 1; j < i; j++) {
bitmap_set(bitmap, &binfo, j - 1);
assert_zd_eq(bitmap_sfu(bitmap, &binfo), j,
"First unset bit should be just after the "
"bit previously set");
2011-05-09 04:52:55 -04:00
bitmap_unset(bitmap, &binfo, j);
}
assert_zd_eq(bitmap_sfu(bitmap, &binfo), i - 1,
"First unset bit should be the last bit");
assert_true(bitmap_full(bitmap, &binfo),
"All bits should be set");
free(bitmap);
2011-05-09 04:52:55 -04:00
}
}
}
TEST_END
2011-05-09 04:52:55 -04:00
int
main(void)
{
return (test(
test_bitmap_size,
test_bitmap_init,
test_bitmap_set,
test_bitmap_unset,
test_bitmap_sfu));
2011-05-09 04:52:55 -04:00
}