feat/support_fiber #6
@ -36,8 +36,8 @@ class CondVarTest : public ::testing::Test {
|
|||||||
protected:
|
protected:
|
||||||
Mutex *m;
|
Mutex *m;
|
||||||
CondVar *cv;
|
CondVar *cv;
|
||||||
volatile bool is_set;
|
bool is_set;
|
||||||
volatile bool is_timeout;
|
bool is_timeout;
|
||||||
std::thread *worker;
|
std::thread *worker;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -69,6 +69,7 @@ TEST_F(CondVarTest, NotifyOne_Wait) {
|
|||||||
TEST_F(CondVarTest, NotifyOne_WaitFor) {
|
TEST_F(CondVarTest, NotifyOne_WaitFor) {
|
||||||
// Wait
|
// Wait
|
||||||
// constexpr auto kWaitTimeoutMs = 100;
|
// constexpr auto kWaitTimeoutMs = 100;
|
||||||
|
auto start = ReadSteadyClock();
|
||||||
constexpr auto kWaitTimeout = std::chrono::milliseconds(50);
|
constexpr auto kWaitTimeout = std::chrono::milliseconds(50);
|
||||||
auto WaitFor = [&] {
|
auto WaitFor = [&] {
|
||||||
UniqueLock<Mutex> inner_locker(*m);
|
UniqueLock<Mutex> inner_locker(*m);
|
||||||
@ -91,9 +92,16 @@ TEST_F(CondVarTest, NotifyOne_WaitFor) {
|
|||||||
cv->NotifyOne();
|
cv->NotifyOne();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
auto now = ReadSteadyClock();
|
||||||
t1.join();
|
t1.join();
|
||||||
ASSERT_TRUE(is_set);
|
if (now - start > kWaitTimeout) {
|
||||||
ASSERT_FALSE(is_timeout);
|
// timeout
|
||||||
|
ASSERT_TRUE(is_timeout);
|
||||||
|
ASSERT_FALSE(is_set);
|
||||||
|
} else {
|
||||||
|
ASSERT_FALSE(is_timeout);
|
||||||
|
ASSERT_TRUE(is_set);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// timeout
|
// timeout
|
||||||
|
Loading…
x
Reference in New Issue
Block a user