2016-12-23 02:28:21 +08:00
|
|
|
#include "gtest/gtest.h"
|
2016-08-18 22:34:36 +08:00
|
|
|
|
|
|
|
#include "data_structures/concurrent/concurrent_list.hpp"
|
|
|
|
|
2016-12-23 02:28:21 +08:00
|
|
|
TEST(ConncurentList, Insert)
|
2016-08-18 22:34:36 +08:00
|
|
|
{
|
2016-09-13 03:13:04 +08:00
|
|
|
ConcurrentList<int> list;
|
2016-08-18 22:34:36 +08:00
|
|
|
auto it = list.begin();
|
|
|
|
it.push(32);
|
|
|
|
it.reset();
|
2016-12-23 02:28:21 +08:00
|
|
|
ASSERT_EQ(*it, 32);
|
2016-08-18 22:34:36 +08:00
|
|
|
}
|
|
|
|
|
2016-12-23 02:28:21 +08:00
|
|
|
TEST(ConncurentList, Iterate)
|
2016-08-18 22:34:36 +08:00
|
|
|
{
|
2016-09-13 03:13:04 +08:00
|
|
|
ConcurrentList<int> list;
|
2016-08-18 22:34:36 +08:00
|
|
|
auto it = list.begin();
|
|
|
|
it.push(32);
|
|
|
|
it.push(7);
|
|
|
|
it.push(9);
|
|
|
|
it.push(0);
|
|
|
|
it.reset();
|
|
|
|
|
2016-12-23 02:28:21 +08:00
|
|
|
ASSERT_EQ(*it, 0);
|
2016-08-18 22:34:36 +08:00
|
|
|
it++;
|
2016-12-23 02:28:21 +08:00
|
|
|
ASSERT_EQ(*it, 9);
|
2016-08-18 22:34:36 +08:00
|
|
|
it++;
|
2016-12-23 02:28:21 +08:00
|
|
|
ASSERT_EQ(*it, 7);
|
2016-08-18 22:34:36 +08:00
|
|
|
it++;
|
2016-12-23 02:28:21 +08:00
|
|
|
ASSERT_EQ(*it, 32);
|
2016-08-18 22:34:36 +08:00
|
|
|
it++;
|
2016-12-23 02:28:21 +08:00
|
|
|
ASSERT_EQ(it, list.end());
|
2016-08-18 22:34:36 +08:00
|
|
|
}
|
|
|
|
|
2016-12-23 02:28:21 +08:00
|
|
|
TEST(ConncurentList, RemoveHead)
|
2016-08-18 22:34:36 +08:00
|
|
|
{
|
2016-09-13 03:13:04 +08:00
|
|
|
ConcurrentList<int> list;
|
2016-08-18 22:34:36 +08:00
|
|
|
auto it = list.begin();
|
|
|
|
it.push(32);
|
|
|
|
it.reset();
|
|
|
|
|
2016-12-23 02:28:21 +08:00
|
|
|
ASSERT_EQ(it.remove(), true);
|
|
|
|
ASSERT_EQ(it.is_removed(), true);
|
|
|
|
ASSERT_EQ(!it.remove(), true);
|
2016-08-18 22:34:36 +08:00
|
|
|
|
|
|
|
it.reset();
|
2016-12-23 02:28:21 +08:00
|
|
|
ASSERT_EQ(it, list.end());
|
2016-08-18 22:34:36 +08:00
|
|
|
}
|
|
|
|
|
2016-12-23 02:28:21 +08:00
|
|
|
TEST(ConncurentList, Remove)
|
2016-08-18 22:34:36 +08:00
|
|
|
{
|
2016-09-13 03:13:04 +08:00
|
|
|
ConcurrentList<int> list;
|
2016-08-18 22:34:36 +08:00
|
|
|
auto it = list.begin();
|
|
|
|
it.push(32);
|
|
|
|
it.push(7);
|
|
|
|
it.push(9);
|
|
|
|
it.push(0);
|
|
|
|
it.reset();
|
|
|
|
|
|
|
|
it++;
|
|
|
|
it++;
|
2016-12-23 02:28:21 +08:00
|
|
|
ASSERT_EQ(it.remove(), true);
|
|
|
|
ASSERT_EQ(it.is_removed(), true);
|
|
|
|
ASSERT_EQ(!it.remove(), true);
|
2016-08-18 22:34:36 +08:00
|
|
|
|
|
|
|
it.reset();
|
2016-12-23 02:28:21 +08:00
|
|
|
ASSERT_EQ(*it, 0);
|
2016-08-18 22:34:36 +08:00
|
|
|
it++;
|
2016-12-23 02:28:21 +08:00
|
|
|
ASSERT_EQ(*it, 9);
|
2016-08-18 22:34:36 +08:00
|
|
|
it++;
|
2016-12-23 02:28:21 +08:00
|
|
|
ASSERT_EQ(*it, 32);
|
2016-08-18 22:34:36 +08:00
|
|
|
it++;
|
2016-12-23 02:28:21 +08:00
|
|
|
ASSERT_EQ(it, list.end());
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(int argc, char **argv)
|
|
|
|
{
|
|
|
|
::testing::InitGoogleTest(&argc, argv);
|
|
|
|
return RUN_ALL_TESTS();
|
2016-08-18 22:34:36 +08:00
|
|
|
}
|