Files
c3c/test/unit/stdlib/threads/pool.c3
Christoffer Lerno c4212c4649 - Test runner will also check for leaks.
- `write` of qoi would leak memory.
- Issue when having an empty `Path` or just "."
- `set_env` would leak memory.
2025-02-10 00:39:02 +01:00

79 lines
1.3 KiB
Plaintext

module thread_pool_test;
import std::io;
import std::thread;
import std::thread::pool;
def Pool = ThreadPool(<4>);
fn void init_destroy() @test => mem::@scoped(&allocator::LIBC_ALLOCATOR)
{
for (usz i = 0; i < 20; i++)
{
Pool pool;
pool.init()!!;
pool.destroy()!!;
}
}
fn void push_destroy() @test => mem::@scoped(&allocator::LIBC_ALLOCATOR)
{
for FOO: (usz i = 0; i < 20; i++)
{
x = 0;
int y = 20;
Pool pool;
pool.init()!!;
defer pool.destroy()!!;
work_done.lock()!!;
pool.push(&do_work, &y)!!;
work_done.unlock()!!;
for (int j = 0; j < 1000; j++)
{
work_done.lock()!!;
if (@atomic_load(x) == @atomic_load(y))
{
(void)work_done.unlock();
break FOO;
}
(void)work_done.unlock();
thread::yield();
}
assert(false, "y never changed");
}
}
fn void push_stop() @test => mem::@scoped(&allocator::LIBC_ALLOCATOR)
{
for (usz i = 0; i < 20; i++)
{
x = 0;
int y = 20;
Pool pool;
pool.init()!!;
work_done.lock()!!;
pool.push(&do_work, &y)!!;
work_done.unlock()!!;
pool.stop_and_destroy()!!;
assert(x == y, "%d: %d != %d", i, x, y);
}
}
int x;
Mutex work_done;
fn void startup() @init {
work_done.init()!!;
}
fn void shutdown() @finalizer {
(void)work_done.destroy();
}
fn int do_work(void* arg)
{
work_done.lock()!!;
x = *(int*)arg;
work_done.unlock()!!;
return 0;
}