2015-06-18 21:27:06 +08:00
|
|
|
#include <thread>
|
|
|
|
#include <chrono>
|
|
|
|
#include <vector>
|
2015-06-28 17:43:52 +08:00
|
|
|
#include <mutex>
|
|
|
|
#include <atomic>
|
2015-06-18 21:27:06 +08:00
|
|
|
|
|
|
|
#include "catch.hpp"
|
|
|
|
#include "utils/sync/spinlock.hpp"
|
|
|
|
|
|
|
|
TEST_CASE("a thread can acquire and release the lock", "[spinlock]")
|
|
|
|
{
|
2015-06-28 17:43:52 +08:00
|
|
|
{
|
|
|
|
std::unique_lock<SpinLock> lock;
|
|
|
|
// I HAS A LOCK!
|
|
|
|
}
|
2015-06-18 21:27:06 +08:00
|
|
|
|
|
|
|
REQUIRE(true);
|
|
|
|
}
|
|
|
|
|
|
|
|
int x = 0;
|
|
|
|
|
|
|
|
SpinLock lock;
|
|
|
|
|
|
|
|
void test_lock()
|
|
|
|
{
|
|
|
|
using namespace std::literals;
|
|
|
|
|
2015-06-28 17:43:52 +08:00
|
|
|
{
|
|
|
|
std::unique_lock<SpinLock> guard(lock);
|
|
|
|
x++;
|
2015-06-18 21:27:06 +08:00
|
|
|
|
2015-06-28 17:43:52 +08:00
|
|
|
std::this_thread::sleep_for(25ms);
|
2015-06-18 21:27:06 +08:00
|
|
|
|
2015-06-28 17:43:52 +08:00
|
|
|
REQUIRE(x < 2);
|
|
|
|
x--;
|
|
|
|
}
|
2015-06-18 21:27:06 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE("only one thread at a time can own the lock", "[spinlock]")
|
|
|
|
{
|
2015-06-22 20:31:26 +08:00
|
|
|
constexpr int N = 64;
|
|
|
|
|
2015-06-18 21:27:06 +08:00
|
|
|
std::vector<std::thread> threads;
|
|
|
|
|
2015-06-22 20:31:26 +08:00
|
|
|
for(int i = 0; i < N; ++i)
|
2015-06-18 21:27:06 +08:00
|
|
|
threads.push_back(std::thread(test_lock));
|
|
|
|
|
|
|
|
for(auto& thread : threads){
|
|
|
|
thread.join();
|
|
|
|
}
|
|
|
|
}
|