2014-03-09 14:27:04 +01:00
|
|
|
// Copyright 2014 Dolphin Emulator Project
|
2015-05-18 01:08:10 +02:00
|
|
|
// Licensed under GPLv2+
|
2014-03-09 14:27:04 +01:00
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
2015-03-01 14:52:09 +01:00
|
|
|
#include <gtest/gtest.h>
|
2016-06-24 10:43:46 +02:00
|
|
|
#include <thread>
|
2014-03-09 14:27:04 +01:00
|
|
|
|
2017-08-23 16:45:42 -07:00
|
|
|
#include "Common/SPSCQueue.h"
|
2014-03-09 14:27:04 +01:00
|
|
|
|
2017-08-23 16:45:42 -07:00
|
|
|
TEST(SPSCQueue, Simple)
|
2014-03-09 14:27:04 +01:00
|
|
|
{
|
2017-08-23 16:45:42 -07:00
|
|
|
Common::SPSCQueue<u32> q;
|
2014-03-09 14:27:04 +01:00
|
|
|
|
2016-06-24 10:43:46 +02:00
|
|
|
EXPECT_EQ(0u, q.Size());
|
|
|
|
EXPECT_TRUE(q.Empty());
|
2014-03-09 14:27:04 +01:00
|
|
|
|
2016-06-24 10:43:46 +02:00
|
|
|
q.Push(1);
|
|
|
|
EXPECT_EQ(1u, q.Size());
|
|
|
|
EXPECT_FALSE(q.Empty());
|
2014-03-09 14:27:04 +01:00
|
|
|
|
2016-06-24 10:43:46 +02:00
|
|
|
u32 v;
|
|
|
|
q.Pop(v);
|
|
|
|
EXPECT_EQ(1u, v);
|
|
|
|
EXPECT_EQ(0u, q.Size());
|
|
|
|
EXPECT_TRUE(q.Empty());
|
2014-03-09 14:27:04 +01:00
|
|
|
|
2016-06-24 10:43:46 +02:00
|
|
|
// Test the FIFO order.
|
|
|
|
for (u32 i = 0; i < 1000; ++i)
|
|
|
|
q.Push(i);
|
|
|
|
EXPECT_EQ(1000u, q.Size());
|
|
|
|
for (u32 i = 0; i < 1000; ++i)
|
|
|
|
{
|
|
|
|
u32 v2;
|
|
|
|
q.Pop(v2);
|
|
|
|
EXPECT_EQ(i, v2);
|
|
|
|
}
|
|
|
|
EXPECT_TRUE(q.Empty());
|
2014-03-09 14:27:04 +01:00
|
|
|
|
2016-06-24 10:43:46 +02:00
|
|
|
for (u32 i = 0; i < 1000; ++i)
|
|
|
|
q.Push(i);
|
|
|
|
EXPECT_FALSE(q.Empty());
|
|
|
|
q.Clear();
|
|
|
|
EXPECT_TRUE(q.Empty());
|
2014-03-09 14:27:04 +01:00
|
|
|
}
|
|
|
|
|
2017-08-23 16:45:42 -07:00
|
|
|
TEST(SPSCQueue, MultiThreaded)
|
2014-03-09 14:27:04 +01:00
|
|
|
{
|
2017-08-23 16:45:42 -07:00
|
|
|
Common::SPSCQueue<u32> q;
|
2014-03-09 14:27:04 +01:00
|
|
|
|
2016-06-24 10:43:46 +02:00
|
|
|
auto inserter = [&q]() {
|
|
|
|
for (u32 i = 0; i < 100000; ++i)
|
|
|
|
q.Push(i);
|
|
|
|
};
|
2014-03-09 14:27:04 +01:00
|
|
|
|
2016-06-24 10:43:46 +02:00
|
|
|
auto popper = [&q]() {
|
|
|
|
for (u32 i = 0; i < 100000; ++i)
|
|
|
|
{
|
|
|
|
while (q.Empty())
|
|
|
|
;
|
|
|
|
u32 v;
|
|
|
|
q.Pop(v);
|
|
|
|
EXPECT_EQ(i, v);
|
|
|
|
}
|
|
|
|
};
|
2014-03-09 14:27:04 +01:00
|
|
|
|
2016-06-24 10:43:46 +02:00
|
|
|
std::thread popper_thread(popper);
|
|
|
|
std::thread inserter_thread(inserter);
|
2014-03-09 14:27:04 +01:00
|
|
|
|
2016-06-24 10:43:46 +02:00
|
|
|
popper_thread.join();
|
|
|
|
inserter_thread.join();
|
2014-03-09 14:27:04 +01:00
|
|
|
}
|