2017-07-06 23:47:28 +08:00
|
|
|
#include "common.hpp"
|
2016-08-02 20:23:39 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
constexpr size_t THREADS_NO = std::min(max_no_threads, 8);
|
2016-08-02 20:23:39 +08:00
|
|
|
constexpr size_t elems_per_thread = 1e5;
|
|
|
|
|
2016-12-22 22:51:16 +08:00
|
|
|
// TODO: document the test
|
|
|
|
|
2017-07-06 23:47:28 +08:00
|
|
|
int main(int, char **argv) {
|
2017-06-21 17:29:13 +08:00
|
|
|
google::InitGoogleLogging(argv[0]);
|
2017-09-22 20:24:53 +08:00
|
|
|
std::vector<std::thread> threads;
|
|
|
|
map_t skiplist;
|
2016-08-02 20:23:39 +08:00
|
|
|
|
2017-09-22 20:24:53 +08:00
|
|
|
// put THREADS_NO * elems_per_thread items to the skiplist
|
|
|
|
for (size_t thread_i = 0; thread_i < THREADS_NO; ++thread_i) {
|
|
|
|
threads.emplace_back(
|
|
|
|
[&skiplist](size_t start, size_t end) {
|
|
|
|
auto accessor = skiplist.access();
|
|
|
|
for (size_t elem_i = start; elem_i < end; ++elem_i) {
|
|
|
|
accessor.insert(elem_i, elem_i);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
thread_i * elems_per_thread,
|
|
|
|
thread_i * elems_per_thread + elems_per_thread);
|
|
|
|
}
|
|
|
|
// wait all threads
|
|
|
|
for (auto &thread : threads) {
|
|
|
|
thread.join();
|
|
|
|
}
|
2016-08-02 20:23:39 +08:00
|
|
|
|
2017-09-22 20:24:53 +08:00
|
|
|
// get skiplist size
|
|
|
|
{
|
|
|
|
auto accessor = skiplist.access();
|
2017-10-11 19:19:10 +08:00
|
|
|
CHECK(accessor.size() == THREADS_NO * elems_per_thread)
|
|
|
|
<< "all elements in skiplist";
|
2017-09-22 20:24:53 +08:00
|
|
|
}
|
2016-08-02 20:23:39 +08:00
|
|
|
|
2017-09-22 20:24:53 +08:00
|
|
|
for (size_t thread_i = 0; thread_i < THREADS_NO; ++thread_i) {
|
|
|
|
threads[thread_i] = std::thread(
|
|
|
|
[&skiplist](size_t start, size_t end) {
|
|
|
|
auto accessor = skiplist.access();
|
|
|
|
for (size_t elem_i = start; elem_i < end; ++elem_i) {
|
2017-10-11 19:19:10 +08:00
|
|
|
CHECK(accessor.remove(elem_i) == true) << "";
|
2017-09-22 20:24:53 +08:00
|
|
|
}
|
|
|
|
},
|
|
|
|
thread_i * elems_per_thread,
|
|
|
|
thread_i * elems_per_thread + elems_per_thread);
|
|
|
|
}
|
|
|
|
// // wait all threads
|
|
|
|
for (auto &thread : threads) {
|
|
|
|
thread.join();
|
|
|
|
}
|
2016-08-02 20:23:39 +08:00
|
|
|
|
2017-09-22 20:24:53 +08:00
|
|
|
// check size
|
|
|
|
{
|
|
|
|
auto accessor = skiplist.access();
|
2017-10-11 19:19:10 +08:00
|
|
|
CHECK(accessor.size() == 0)
|
|
|
|
<< "Size should be 0, but size is " << accessor.size();
|
2017-09-22 20:24:53 +08:00
|
|
|
}
|
2017-02-18 18:54:37 +08:00
|
|
|
|
2017-09-22 20:24:53 +08:00
|
|
|
// check count
|
|
|
|
{
|
|
|
|
size_t iterator_counter = 0;
|
|
|
|
auto accessor = skiplist.access();
|
|
|
|
for (auto elem : accessor) {
|
|
|
|
++iterator_counter;
|
|
|
|
cout << elem.first << " ";
|
2017-02-18 18:54:37 +08:00
|
|
|
}
|
2017-10-11 19:19:10 +08:00
|
|
|
CHECK(iterator_counter == 0) << "deleted elements";
|
2017-09-22 20:24:53 +08:00
|
|
|
}
|
2017-02-18 18:54:37 +08:00
|
|
|
|
2017-09-22 20:24:53 +08:00
|
|
|
{
|
|
|
|
auto accessor = skiplist.access();
|
|
|
|
check_order<map_t>(accessor);
|
|
|
|
}
|
2017-10-11 19:19:10 +08:00
|
|
|
return 0;
|
2016-08-02 20:23:39 +08:00
|
|
|
}
|