[threading linux] Fix events with closed handles
Linux: Remove copy and destroy call in make_unique invokation which closes handles on all events. Testing: Add Wait test for Events set and unset.
This commit is contained in:
parent
a0bdb3d3c2
commit
9137e56381
|
@ -174,8 +174,23 @@ TEST_CASE("Signal and Wait") {
|
|||
}
|
||||
|
||||
TEST_CASE("Wait on Event", "Event") {
|
||||
// TODO(bwrsandman):
|
||||
REQUIRE(true);
|
||||
auto evt = Event::CreateAutoResetEvent(false);
|
||||
WaitResult result;
|
||||
|
||||
// Call wait on unset Event
|
||||
result = Wait(evt.get(), false, 50ms);
|
||||
REQUIRE(result == WaitResult::kTimeout);
|
||||
|
||||
// Call wait on set Event
|
||||
evt->Set();
|
||||
result = Wait(evt.get(), false, 50ms);
|
||||
REQUIRE(result == WaitResult::kSuccess);
|
||||
|
||||
// Call wait on now consumed Event
|
||||
result = Wait(evt.get(), false, 50ms);
|
||||
REQUIRE(result == WaitResult::kTimeout);
|
||||
|
||||
// TODO(bwrsandman): test Reset() and Pulse()
|
||||
}
|
||||
|
||||
TEST_CASE("Wait on Semaphore", "Semaphore") {
|
||||
|
|
|
@ -357,7 +357,7 @@ std::unique_ptr<Event> Event::CreateAutoResetEvent(bool initial_state) {
|
|||
return nullptr;
|
||||
}
|
||||
|
||||
return std::make_unique<PosixEvent>(PosixEvent(fd));
|
||||
return std::make_unique<PosixEvent>(fd);
|
||||
}
|
||||
|
||||
// TODO(dougvj)
|
||||
|
|
Loading…
Reference in New Issue