mirror of
https://github.com/tailix/libkernaux.git
synced 2024-11-13 11:04:27 -05:00
107 lines
2.8 KiB
C
107 lines
2.8 KiB
C
|
#ifdef HAVE_CONFIG_H
|
||
|
#include "config.h"
|
||
|
#endif
|
||
|
|
||
|
#define KERNAUX_ACCESS_PRIVATE
|
||
|
|
||
|
#include <kernaux/free_list.h>
|
||
|
|
||
|
#include <assert.h>
|
||
|
#include <stddef.h>
|
||
|
#include <string.h>
|
||
|
|
||
|
static void test_default();
|
||
|
static void test_calloc();
|
||
|
static void test_calloc_nomem();
|
||
|
static void test_cross_zone_defrag();
|
||
|
|
||
|
void test_main()
|
||
|
{
|
||
|
test_default();
|
||
|
test_calloc();
|
||
|
test_calloc_nomem();
|
||
|
test_cross_zone_defrag();
|
||
|
}
|
||
|
|
||
|
void test_default()
|
||
|
{
|
||
|
char memory_block[1000];
|
||
|
struct KernAux_FreeList free_list = KernAux_FreeList_create(NULL);
|
||
|
KernAux_FreeList_add_zone(&free_list, memory_block, sizeof(memory_block));
|
||
|
|
||
|
char *const ptr1 = KernAux_Malloc_malloc(&free_list.malloc, 100);
|
||
|
assert(ptr1);
|
||
|
assert(ptr1 > memory_block);
|
||
|
assert(ptr1 < &memory_block[1000]);
|
||
|
|
||
|
char *const ptr2 = KernAux_Malloc_calloc(&free_list.malloc, 100, 1);
|
||
|
assert(ptr2);
|
||
|
assert(ptr2 > ptr1);
|
||
|
assert(ptr2 < &memory_block[1000]);
|
||
|
|
||
|
char *const ptr3 = KernAux_Malloc_calloc(&free_list.malloc, 1, 100);
|
||
|
assert(ptr3);
|
||
|
assert(ptr3 > ptr2);
|
||
|
assert(ptr3 < &memory_block[1000]);
|
||
|
|
||
|
char *const ptr4 = KernAux_Malloc_malloc(&free_list.malloc, 100);
|
||
|
assert(ptr4);
|
||
|
assert(ptr4 > ptr3);
|
||
|
assert(ptr4 < &memory_block[1000]);
|
||
|
|
||
|
KernAux_Malloc_free(&free_list.malloc, ptr2);
|
||
|
KernAux_Malloc_free(&free_list.malloc, ptr3);
|
||
|
|
||
|
char *const ptr5 = KernAux_Malloc_malloc(&free_list.malloc, 100);
|
||
|
assert(ptr5 == ptr2);
|
||
|
|
||
|
char *const ptr6 = KernAux_Malloc_calloc(&free_list.malloc, 10, 10);
|
||
|
assert(ptr6 == ptr3);
|
||
|
|
||
|
KernAux_Malloc_free(&free_list.malloc, ptr2);
|
||
|
KernAux_Malloc_free(&free_list.malloc, ptr3);
|
||
|
|
||
|
char *const ptr7 = KernAux_Malloc_malloc(&free_list.malloc, 200);
|
||
|
assert(ptr7 == ptr2);
|
||
|
}
|
||
|
|
||
|
void test_calloc()
|
||
|
{
|
||
|
char zone[1000];
|
||
|
struct KernAux_FreeList free_list = KernAux_FreeList_create(NULL);
|
||
|
KernAux_FreeList_add_zone(&free_list, zone, 1000);
|
||
|
char *const ptr = KernAux_Malloc_calloc(&free_list.malloc, 1, 900);
|
||
|
for (size_t index = 0; index < 900; ++index) {
|
||
|
assert(ptr[index] == 0);
|
||
|
}
|
||
|
KernAux_Malloc_free(&free_list.malloc, ptr);
|
||
|
}
|
||
|
|
||
|
void test_calloc_nomem()
|
||
|
{
|
||
|
char zone[1000];
|
||
|
struct KernAux_FreeList free_list = KernAux_FreeList_create(NULL);
|
||
|
KernAux_FreeList_add_zone(&free_list, zone, sizeof(zone));
|
||
|
void *const ptr = KernAux_Malloc_calloc(&free_list.malloc, 1, sizeof(zone));
|
||
|
assert(ptr == NULL);
|
||
|
}
|
||
|
|
||
|
void test_cross_zone_defrag()
|
||
|
{
|
||
|
char zone[1000];
|
||
|
struct KernAux_FreeList free_list = KernAux_FreeList_create(NULL);
|
||
|
KernAux_FreeList_add_zone(&free_list, &zone[0], 500);
|
||
|
KernAux_FreeList_add_zone(&free_list, &zone[500], 500);
|
||
|
|
||
|
size_t nodes_count = 0;
|
||
|
for (
|
||
|
KernAux_FreeList_Node item_node = free_list.head;
|
||
|
item_node;
|
||
|
item_node = item_node->next
|
||
|
) {
|
||
|
++nodes_count;
|
||
|
}
|
||
|
|
||
|
assert(nodes_count == 1);
|
||
|
}
|