test/refactor: changed things for working with more edge cases
This commit is contained in:
@@ -108,6 +108,34 @@ static void test_arena_alloc_size_max(void **state) {
|
||||
arena_destroy(&arena);
|
||||
}
|
||||
|
||||
static void test_arena_alloc_align_0(void **state) {
|
||||
(void) state;
|
||||
|
||||
ArenaResult value = arena_init(64);
|
||||
assert_true(value.is_valid);
|
||||
Arena arena = value.arena;
|
||||
|
||||
ArenaPointer pointer = arena_alloc(&arena, sizeof(int), 0);
|
||||
assert_false(pointer.is_valid);
|
||||
assert_int_equal(pointer.err, ARENA_INVALID_ALIGN);
|
||||
|
||||
arena_destroy(&arena);
|
||||
}
|
||||
|
||||
static void test_arena_alloc_align_max(void **state) {
|
||||
(void) state;
|
||||
|
||||
ArenaResult value = arena_init(64);
|
||||
assert_true(value.is_valid);
|
||||
Arena arena = value.arena;
|
||||
|
||||
ArenaPointer pointer = arena_alloc(&arena, sizeof(int), SIZE_MAX);
|
||||
assert_false(pointer.is_valid);
|
||||
assert_int_equal(pointer.err, ARENA_INVALID_ALIGN);
|
||||
|
||||
arena_destroy(&arena);
|
||||
}
|
||||
|
||||
static void test_arena_align_size_0(void **state) {
|
||||
(void) state;
|
||||
|
||||
@@ -122,6 +150,58 @@ static void test_arena_align_size_0(void **state) {
|
||||
arena_destroy(&arena);
|
||||
}
|
||||
|
||||
static void test_arena_ensure_capacity_size_0(void **state) {
|
||||
(void) state;
|
||||
|
||||
ArenaResult value = arena_init(64);
|
||||
assert_true(value.is_valid);
|
||||
Arena arena = value.arena;
|
||||
|
||||
ArenaErr err = arena_ensure_capacity(&arena, 0, alignof(int));
|
||||
assert_int_equal(err, ARENA_INVALID_SIZE);
|
||||
|
||||
arena_destroy(&arena);
|
||||
}
|
||||
|
||||
static void test_arena_ensure_capacity_size_max(void **state) {
|
||||
(void) state;
|
||||
|
||||
ArenaResult value = arena_init(64);
|
||||
assert_true(value.is_valid);
|
||||
Arena arena = value.arena;
|
||||
|
||||
ArenaErr err = arena_ensure_capacity(&arena, SIZE_MAX, alignof(int));
|
||||
assert_int_equal(err, ARENA_INVALID_SIZE);
|
||||
|
||||
arena_destroy(&arena);
|
||||
}
|
||||
|
||||
static void test_arena_ensure_capacity_align_0(void **state) {
|
||||
(void) state;
|
||||
|
||||
ArenaResult value = arena_init(64);
|
||||
assert_true(value.is_valid);
|
||||
Arena arena = value.arena;
|
||||
|
||||
ArenaErr err = arena_ensure_capacity(&arena, sizeof(int), 0);
|
||||
assert_int_equal(err, ARENA_INVALID_ALIGN);
|
||||
|
||||
arena_destroy(&arena);
|
||||
}
|
||||
|
||||
static void test_arena_ensure_capacity_align_max(void **state) {
|
||||
(void) state;
|
||||
|
||||
ArenaResult value = arena_init(64);
|
||||
assert_true(value.is_valid);
|
||||
Arena arena = value.arena;
|
||||
|
||||
ArenaErr err = arena_ensure_capacity(&arena, sizeof(int), SIZE_MAX);
|
||||
assert_int_equal(err, ARENA_INVALID_ALIGN);
|
||||
|
||||
arena_destroy(&arena);
|
||||
}
|
||||
|
||||
int main(void) {
|
||||
const struct CMUnitTest tests[] = {
|
||||
cmocka_unit_test(test_push_3_ints),
|
||||
@@ -129,7 +209,13 @@ int main(void) {
|
||||
cmocka_unit_test(test_init_arena_0_cap),
|
||||
cmocka_unit_test(test_arena_alloc_size_0),
|
||||
cmocka_unit_test(test_arena_alloc_size_max),
|
||||
cmocka_unit_test(test_arena_alloc_align_0),
|
||||
cmocka_unit_test(test_arena_alloc_align_max),
|
||||
cmocka_unit_test(test_arena_align_size_0),
|
||||
cmocka_unit_test(test_arena_ensure_capacity_align_0),
|
||||
cmocka_unit_test(test_arena_ensure_capacity_align_max),
|
||||
cmocka_unit_test(test_arena_ensure_capacity_size_0),
|
||||
cmocka_unit_test(test_arena_ensure_capacity_size_max),
|
||||
};
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user