summaryrefslogtreecommitdiff
path: root/tests/pool_tests.c
diff options
context:
space:
mode:
authorJoshua Rowe <17525998+omnisci3nce@users.noreply.github.com>2024-05-20 10:50:11 +1000
committerGitHub <noreply@github.com>2024-05-20 10:50:11 +1000
commite904c22003c3a134201b222e6619e782fbe63947 (patch)
tree5295c8ce5f855ca4a0f1bebe50beee80bae66682 /tests/pool_tests.c
parent02e84ee4d18e705e3362be1e327fdb6f1397a032 (diff)
parent73d4145f46d2305f45761b8e456df692d1962dfb (diff)
Merge pull request #14 from omnisci3nce/realign
Realign
Diffstat (limited to 'tests/pool_tests.c')
-rw-r--r--tests/pool_tests.c72
1 files changed, 72 insertions, 0 deletions
diff --git a/tests/pool_tests.c b/tests/pool_tests.c
new file mode 100644
index 0000000..df65773
--- /dev/null
+++ b/tests/pool_tests.c
@@ -0,0 +1,72 @@
+#include <stdbool.h>
+#include <stdlib.h>
+#include "defines.h"
+#include "unity.h"
+#include "unity_fixture.h"
+
+#include "mem.h"
+
+#define ARENA_SIZE (1024 * 1024)
+
+static arena a;
+
+TEST_GROUP(Pool);
+
+TEST_SETUP(Pool) { a = arena_create(malloc(ARENA_SIZE), ARENA_SIZE); }
+
+TEST_TEAR_DOWN(Pool) { arena_free_all(&a); }
+
+TEST(Pool, SanityCheckTest) { TEST_ASSERT_EQUAL(true, true); }
+
+TEST(Pool, Initialisation) {
+ // u32 pool
+ void_pool pool = void_pool_create(&a, 256, sizeof(u32));
+ u32 x_handle;
+ u32* x_ptr = (u32*)void_pool_alloc(&pool, &x_handle);
+ // store something in it
+ *x_ptr = 1024;
+ u32* x = void_pool_get(&pool, x_handle);
+
+ TEST_ASSERT_EQUAL_UINT32(1024, *x);
+ /* TEST_ASSERT_EQUAL_MEMORY(&expected, &actual, sizeof(vec3)); */
+}
+
+typedef struct foo {
+ u32 a;
+ f32 b;
+ char c;
+} foo;
+
+CORE_DEFINE_HANDLE(bar);
+typedef struct bar_handle {
+ u32 raw;
+} bar_handle;
+TYPED_POOL(foo, bar);
+
+TEST(Pool, TypedPool) {
+ printf("Typed pool test\n");
+ // create pool
+ bar_pool pool = bar_pool_create(&a, 2, sizeof(foo));
+
+ bar_handle first_handle, second_handle, third_handle;
+ foo* first = bar_pool_alloc(&pool, &first_handle);
+ foo* second = bar_pool_alloc(&pool, &second_handle);
+ // Third one shouldnt work
+ foo* third = bar_pool_alloc(&pool, &third_handle);
+ TEST_ASSERT_NULL(third);
+
+ first->a = 32;
+ first->b = 2.0;
+ first->c = 'X';
+
+ foo* my_foo = bar_pool_get(&pool, first_handle);
+ TEST_ASSERT_EQUAL_UINT32(32, my_foo->a);
+ TEST_ASSERT_EQUAL(2.0, my_foo->b);
+ TEST_ASSERT_EQUAL_CHAR('X', my_foo->c);
+
+ bar_pool_dealloc(&pool, first_handle);
+
+ // next alloc should succeed
+ third = bar_pool_alloc(&pool, &third_handle);
+ TEST_ASSERT_NOT_NULL(third);
+}