summaryrefslogtreecommitdiffstats
path: root/src/test/crimson/test_thread_pool.cc
blob: 61e714456e453148b7d46c4c07e7ce86309eb6bd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#include <chrono>
#include <iostream>
#include <numeric>
#include <seastar/core/app-template.hh>
#include "crimson/thread/ThreadPool.h"

using namespace std::chrono_literals;
using ThreadPool = ceph::thread::ThreadPool;

seastar::future<> test_accumulate(ThreadPool& tp) {
  static constexpr auto N = 5;
  static constexpr auto M = 1;
  auto slow_plus = [&tp](int i) {
    return tp.submit([=] {
      std::this_thread::sleep_for(10ns);
      return i + M;
    });
  };
  return seastar::map_reduce(
    boost::irange(0, N), slow_plus, 0, std::plus{}).then([] (int sum) {
    auto r = boost::irange(0 + M, N + M);
    if (sum != std::accumulate(r.begin(), r.end(), 0)) {
      throw std::runtime_error("test_accumulate failed");
    }
  });
}

int main(int argc, char** argv)
{
  ThreadPool tp{2, 128, 0};
  seastar::app_template app;
  return app.run(argc, argv, [&tp] {
      return tp.start().then([&tp] {
          return test_accumulate(tp);
        }).handle_exception([](auto e) {
          std::cerr << "Error: " << e << std::endl;
          seastar::engine().exit(1);
        }).finally([&tp] {
          return tp.stop();
        });
      });
}

/*
 * Local Variables:
 * compile-command: "make -j4 \
 * -C ../../../build \
 * unittest_seastar_thread_pool"
 * End:
 */