1 /*
2  * Copyright (c) 2016-present, Facebook, Inc.
3  * All rights reserved.
4  *
5  * This source code is licensed under both the BSD-style license (found in the
6  * LICENSE file in the root directory of this source tree) and the GPLv2 (found
7  * in the COPYING file in the root directory of this source tree).
8  */
9 #include "utils/ThreadPool.h"
10 
11 #include <gtest/gtest.h>
12 #include <atomic>
13 #include <iostream>
14 #include <thread>
15 #include <vector>
16 
17 using namespace pzstd;
18 
TEST(ThreadPool,Ordering)19 TEST(ThreadPool, Ordering) {
20   std::vector<int> results;
21 
22   {
23     ThreadPool executor(1);
24     for (int i = 0; i < 10; ++i) {
25       executor.add([ &results, i ] { results.push_back(i); });
26     }
27   }
28 
29   for (int i = 0; i < 10; ++i) {
30     EXPECT_EQ(i, results[i]);
31   }
32 }
33 
TEST(ThreadPool,AllJobsFinished)34 TEST(ThreadPool, AllJobsFinished) {
35   std::atomic<unsigned> numFinished{0};
36   std::atomic<bool> start{false};
37   {
38     std::cerr << "Creating executor" << std::endl;
39     ThreadPool executor(5);
40     for (int i = 0; i < 10; ++i) {
41       executor.add([ &numFinished, &start ] {
42         while (!start.load()) {
43           std::this_thread::yield();
44         }
45         ++numFinished;
46       });
47     }
48     std::cerr << "Starting" << std::endl;
49     start.store(true);
50     std::cerr << "Finishing" << std::endl;
51   }
52   EXPECT_EQ(10, numFinished.load());
53 }
54 
TEST(ThreadPool,AddJobWhileJoining)55 TEST(ThreadPool, AddJobWhileJoining) {
56   std::atomic<bool> done{false};
57   {
58     ThreadPool executor(1);
59     executor.add([&executor, &done] {
60       while (!done.load()) {
61         std::this_thread::yield();
62       }
63       // Sleep for a second to be sure that we are joining
64       std::this_thread::sleep_for(std::chrono::seconds(1));
65       executor.add([] {
66         EXPECT_TRUE(false);
67       });
68     });
69     done.store(true);
70   }
71 }
72