polardbxengine/extra/IS/dependency/easy/test/util/easy_pool_test.c

272 lines
6.8 KiB
C

#include "easy_pool.h"
#include <easy_test.h>
/**
* 测试 easy_pool
*/
static int test_alloc_byte = 0;
static void *test_realloc (void *ptr, size_t size)
{
return NULL;
}
static void *test_realloc_2 (void *ptr, size_t size)
{
char *p1, *p = (char *)ptr;
if (p) p -= 8;
if (size) {
test_alloc_byte += size;
p1 = (char *)easy_realloc(p, size + 8);
if (p1) {
*((int *)p1) = size;
p1 += 8;
}
return p1;
} else if (p) {
test_alloc_byte -= *((int *)p);
easy_free(p);
}
return NULL;
}
TEST(easy_pool, create)
{
easy_pool_t *pool;
pool = easy_pool_create(0);
EXPECT_TRUE(pool != NULL);
EXPECT_TRUE(pool->end == ((uint8_t *)pool) + EASY_POOL_ALIGNMENT);
easy_pool_destroy(pool);
pool = easy_pool_create(1);
EXPECT_TRUE(pool != NULL);
EXPECT_TRUE(pool->end == ((uint8_t *)pool) + EASY_POOL_ALIGNMENT);
easy_pool_destroy(pool);
pool = easy_pool_create(EASY_POOL_ALIGNMENT - sizeof(easy_pool_t));
EXPECT_TRUE(pool != NULL);
EXPECT_TRUE(pool->end == ((uint8_t *)pool) + EASY_POOL_ALIGNMENT);
easy_pool_destroy(pool);
pool = easy_pool_create(EASY_POOL_ALIGNMENT - sizeof(easy_pool_t) + 1);
EXPECT_TRUE(pool != NULL);
EXPECT_TRUE(pool->end == ((uint8_t *)pool) + EASY_POOL_ALIGNMENT * 2);
easy_pool_destroy(pool);
// set realloc
easy_pool_set_allocator(test_realloc);
pool = easy_pool_create(0);
EXPECT_TRUE(pool == NULL);
easy_pool_set_allocator(easy_test_realloc);
}
// easy_pool_clear
TEST(easy_pool, clear)
{
int i;
easy_pool_t *pool;
test_alloc_byte = 0;
easy_pool_set_allocator(test_realloc_2);
pool = easy_pool_create(0);
EXPECT_EQ(pool->end - pool->last, EASY_POOL_ALIGNMENT - sizeof(easy_pool_t));
// large alloc
for(i = 0; i < 10; i++) {
easy_pool_alloc(pool, EASY_POOL_ALIGNMENT);
}
EXPECT_EQ(test_alloc_byte, EASY_POOL_ALIGNMENT * 11);
easy_pool_clear(pool);
EXPECT_EQ(test_alloc_byte, EASY_POOL_ALIGNMENT);
EXPECT_EQ(pool->last - (uint8_t *)pool, sizeof(easy_pool_t));
easy_pool_destroy(pool);
EXPECT_EQ(test_alloc_byte, 0);
easy_pool_set_allocator(easy_test_realloc);
}
TEST(easy_pool, alloc)
{
easy_pool_t *pool;
int i, size, msize;
void *p;
pool = easy_pool_create(0);
EXPECT_TRUE(pool != NULL);
EXPECT_TRUE(pool->end - pool->last == EASY_POOL_ALIGNMENT - sizeof(easy_pool_t));
size = pool->end - pool->last;
msize = size - 64 + 1;
for(i = 0; i < 3; i++) {
size -= 63;
p = easy_pool_alloc(pool, 63);
EXPECT_TRUE(p != NULL);
EXPECT_EQ(pool->end - pool->last, size);
EXPECT_TRUE(pool->next == NULL);
size --;
}
size ++;
p = easy_pool_alloc(pool, size);
EXPECT_TRUE(p != NULL);
EXPECT_TRUE(pool->next != NULL);
EXPECT_EQ(pool->end - pool->last, size);
EXPECT_TRUE(pool->large == NULL);
p = easy_pool_alloc(pool, EASY_POOL_ALIGNMENT);
EXPECT_TRUE(p != NULL);
EXPECT_TRUE(pool->large != NULL);
EXPECT_TRUE(pool->current == pool);
for(i = 0; i < 6; i++) p = easy_pool_alloc(pool, msize);
EXPECT_TRUE(pool->current != pool);
size = 0;
for(i = 0; i < 1024; i++) {
p = easy_pool_alloc(pool, i + 1);
if (p) size ++;
}
EXPECT_EQ(size, 1024);
easy_pool_destroy(pool);
}
TEST(easy_pool, nalloc)
{
easy_pool_t *pool;
int i, size, msize;
void *p;
pool = easy_pool_create(0);
EXPECT_TRUE(pool != NULL);
EXPECT_TRUE(pool->end - pool->last == EASY_POOL_ALIGNMENT - sizeof(easy_pool_t));
size = pool->end - pool->last;
msize = size - 64 + 1;
for(i = 0; i < 3; i++) {
size -= 63;
p = easy_pool_nalloc(pool, 63);
EXPECT_TRUE(p != NULL);
EXPECT_EQ(pool->end - pool->last, size);
EXPECT_TRUE(pool->next == NULL);
}
p = easy_pool_nalloc(pool, size + 1);
EXPECT_TRUE(p != NULL);
EXPECT_TRUE(pool->next != NULL);
EXPECT_EQ(pool->end - pool->last, size);
EXPECT_TRUE(pool->large == NULL);
p = easy_pool_nalloc(pool, EASY_POOL_ALIGNMENT);
EXPECT_TRUE(p != NULL);
EXPECT_TRUE(pool->large != NULL);
EXPECT_TRUE(pool->current == pool);
for(i = 0; i < 6; i++) {
if (i % 2) pool->ref ++;
p = easy_pool_nalloc(pool, msize);
if (i % 2) pool->ref --;
}
EXPECT_TRUE(pool->current != pool);
easy_pool_destroy(pool);
}
TEST(easy_pool, calloc)
{
easy_pool_t *pool;
char *p;
int i, cnt, size;
size = EASY_POOL_ALIGNMENT / 2;
pool = easy_pool_create(0);
p = (char *)easy_pool_calloc(pool, size);
cnt = 0;
for(i = 0; i < size; i++)
if (p[i]) cnt ++;
EXPECT_EQ(cnt, 0);
easy_pool_set_allocator(test_realloc);
p = (char *)easy_pool_calloc(pool, size);
EXPECT_TRUE(p == NULL);
p = (char *)easy_pool_calloc(pool, 1);
EXPECT_TRUE(p != NULL);
p = (char *)easy_pool_calloc(pool, EASY_POOL_ALIGNMENT);
EXPECT_TRUE(p == NULL);
// easy_pool_default_realloc
easy_pool_set_allocator(NULL);
p = (char *)easy_pool_realloc(NULL, 1);
EXPECT_TRUE(p != NULL);
p = (char *)easy_pool_realloc(p, 2);
EXPECT_TRUE(p != NULL);
p = (char *)easy_pool_realloc(p, 0);
EXPECT_TRUE(p == NULL);
p = (char *)easy_pool_realloc(p, 0);
EXPECT_TRUE(p == NULL);
easy_pool_set_allocator(easy_test_realloc);
easy_pool_destroy(pool);
}
TEST(easy_pool, realloc)
{
char *ptr;
ptr = (char *)easy_pool_realloc(NULL, 1);
EXPECT_TRUE(ptr != NULL);
ptr = (char *)easy_pool_realloc(ptr, 1);
EXPECT_TRUE(ptr != NULL);
ptr = (char *)easy_pool_realloc(ptr, 0);
EXPECT_TRUE(ptr == NULL);
ptr = (char *)easy_pool_realloc(ptr, 0);
EXPECT_TRUE(ptr == NULL);
}
//char *easy_pool_strdup(easy_pool_t *pool, const char *str)
TEST(easy_pool, strdup)
{
easy_pool_t *pool;
char *p;
pool = easy_pool_create(0);
char data[EASY_POOL_ALIGNMENT];
memset(data, 'A', EASY_POOL_ALIGNMENT);
data[EASY_POOL_ALIGNMENT - 1] = '\0';
// null
p = easy_pool_strdup(pool, NULL);
EXPECT_TRUE(p == NULL);
p = easy_pool_strdup(pool, "ABC");
EXPECT_TRUE(memcmp(p, "ABC", 4) == 0);
p = easy_pool_strdup(pool, data);
EXPECT_TRUE(memcmp(p, data, EASY_POOL_ALIGNMENT) == 0);
// alloc failure
easy_pool_set_allocator(test_realloc);
p = easy_pool_strdup(pool, "ABC");
EXPECT_TRUE(p != NULL);
p = easy_pool_strdup(pool, data);
EXPECT_TRUE(p == NULL);
easy_pool_set_allocator(easy_test_realloc);
easy_pool_destroy(pool);
}