From 7c4c49ff07de31b1b74f3dc26648ad4000113256 Mon Sep 17 00:00:00 2001 From: afranchuk Date: Tue, 11 Jan 2022 13:04:24 -0500 Subject: Fix a bug in std.Thread.Condition and add a basic Condition test. (#10538) * Fix FUTEX usage in std.Thread.Condition - It was using an old name. --- lib/std/Thread.zig | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) (limited to 'lib/std/Thread.zig') diff --git a/lib/std/Thread.zig b/lib/std/Thread.zig index f2203e2808..83c2992a45 100644 --- a/lib/std/Thread.zig +++ b/lib/std/Thread.zig @@ -1151,3 +1151,27 @@ test "Thread.detach" { event.wait(); try std.testing.expectEqual(value, 1); } + +fn testWaitForSignal(mutex: *Mutex, cond: *Condition) void { + mutex.lock(); + defer mutex.unlock(); + cond.signal(); + cond.wait(mutex); +} + +test "Condition.signal" { + if (builtin.single_threaded) return error.SkipZigTest; + + var mutex = Mutex{}; + var cond = Condition{}; + + var thread: Thread = undefined; + { + mutex.lock(); + defer mutex.unlock(); + thread = try Thread.spawn(.{}, testWaitForSignal, .{ &mutex, &cond }); + cond.wait(&mutex); + cond.signal(); + } + thread.join(); +} -- cgit v1.2.3