- add support move & copy semantic - introduce submit method for executor with future result
52 lines
1.1 KiB
C++
52 lines
1.1 KiB
C++
#include "gtest/gtest.h"
|
|
|
|
#include "pithread.h"
|
|
#include "testutil.h"
|
|
|
|
class MutexIntegartionTest : public ::testing::Test, public TestUtil {
|
|
public:
|
|
PIMutex* m = new PIMutex();
|
|
};
|
|
|
|
TEST_F(MutexIntegartionTest, lock_is_protect) {
|
|
m->lock();
|
|
bool* isProtect = new bool(true);
|
|
|
|
createThread([&](){
|
|
m->lock();
|
|
*isProtect = false;
|
|
});
|
|
EXPECT_FALSE(thread->waitForFinish(WAIT_THREAD_TIME_MS));
|
|
ASSERT_TRUE(*isProtect);
|
|
}
|
|
|
|
TEST_F(MutexIntegartionTest, unlock_is_release) {
|
|
m->lock();
|
|
bool* isReleased = new bool(false);
|
|
m->unlock();
|
|
|
|
createThread([&](){
|
|
m->lock();
|
|
*isReleased = true;
|
|
m->unlock();
|
|
});
|
|
ASSERT_TRUE(*isReleased);
|
|
}
|
|
|
|
TEST_F(MutexIntegartionTest, tryLock_is_false_when_locked) {
|
|
createThread([&](){
|
|
m->lock();
|
|
piMSleep(WAIT_THREAD_TIME_MS);
|
|
});
|
|
ASSERT_FALSE(m->tryLock());
|
|
}
|
|
|
|
TEST_F(MutexIntegartionTest, tryLock_is_true_when_unlocked) {
|
|
ASSERT_TRUE(m->tryLock());
|
|
}
|
|
|
|
TEST_F(MutexIntegartionTest, tryLock_is_recursive_lock_enable) {
|
|
m->lock();
|
|
ASSERT_TRUE(m->tryLock());
|
|
}
|