2021-10-26 14:53:56 +08:00
|
|
|
// Copyright 2021 Memgraph Ltd.
|
|
|
|
//
|
|
|
|
// Use of this software is governed by the Business Source License
|
|
|
|
// included in the file licenses/BSL.txt; by using this file, you agree to be bound by the terms of the Business Source
|
|
|
|
// License, and you may not use this file except in compliance with the Business Source License.
|
|
|
|
//
|
|
|
|
// As of the Change Date specified in that file, in accordance with
|
|
|
|
// the Business Source License, use of this software will be governed
|
|
|
|
// by the Apache License, Version 2.0, included in the file
|
|
|
|
// licenses/APL.txt.
|
|
|
|
|
2020-11-19 21:26:03 +08:00
|
|
|
#include <gtest/gtest.h>
|
|
|
|
|
|
|
|
#include <atomic>
|
|
|
|
#include <chrono>
|
|
|
|
#include <thread>
|
|
|
|
|
|
|
|
#include <utils/thread_pool.hpp>
|
|
|
|
|
|
|
|
using namespace std::chrono_literals;
|
|
|
|
|
|
|
|
TEST(ThreadPool, Basic) {
|
2021-01-21 22:47:56 +08:00
|
|
|
constexpr size_t adder_count = 500000;
|
|
|
|
constexpr std::array<size_t, 5> pool_sizes{1, 2, 4, 8, 100};
|
2020-11-19 21:26:03 +08:00
|
|
|
|
|
|
|
for (const auto pool_size : pool_sizes) {
|
|
|
|
utils::ThreadPool pool{pool_size};
|
|
|
|
|
|
|
|
std::atomic<int> count{0};
|
|
|
|
for (size_t i = 0; i < adder_count; ++i) {
|
|
|
|
pool.AddTask([&] { count.fetch_add(1); });
|
|
|
|
}
|
|
|
|
|
2020-11-19 23:46:01 +08:00
|
|
|
while (pool.UnfinishedTasksNum() != 0) {
|
2020-11-19 21:26:03 +08:00
|
|
|
std::this_thread::sleep_for(std::chrono::milliseconds(10));
|
|
|
|
}
|
|
|
|
|
|
|
|
ASSERT_EQ(count.load(), adder_count);
|
|
|
|
}
|
|
|
|
}
|