2017-11-24 09:33:42 +00:00
|
|
|
#include "test.h"
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
|
|
|
|
#include <base/system.h>
|
|
|
|
#include <engine/engine.h>
|
2020-09-26 19:41:58 +00:00
|
|
|
#include <engine/shared/jobs.h>
|
2017-11-24 09:33:42 +00:00
|
|
|
|
|
|
|
#include <functional>
|
|
|
|
|
|
|
|
static const int TEST_NUM_THREADS = 4;
|
|
|
|
|
|
|
|
class Jobs : public ::testing::Test
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
CJobPool m_Pool;
|
|
|
|
|
|
|
|
Jobs()
|
|
|
|
{
|
|
|
|
m_Pool.Init(TEST_NUM_THREADS);
|
|
|
|
}
|
|
|
|
|
|
|
|
void Add(std::shared_ptr<IJob> pJob)
|
|
|
|
{
|
|
|
|
m_Pool.Add(std::move(pJob));
|
|
|
|
}
|
2021-03-13 17:10:59 +00:00
|
|
|
void RunBlocking(IJob *pJob)
|
|
|
|
{
|
|
|
|
CJobPool::RunBlocking(pJob);
|
|
|
|
}
|
2017-11-24 09:33:42 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
class CJob : public IJob
|
|
|
|
{
|
|
|
|
std::function<void()> m_JobFunction;
|
2022-05-17 21:51:51 +00:00
|
|
|
void Run() override { m_JobFunction(); }
|
2020-09-26 19:41:58 +00:00
|
|
|
|
2017-11-24 09:33:42 +00:00
|
|
|
public:
|
2020-09-26 19:41:58 +00:00
|
|
|
CJob(std::function<void()> &&JobFunction) :
|
|
|
|
m_JobFunction(JobFunction) {}
|
2017-11-24 09:33:42 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(Jobs, Constructor)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(Jobs, Simple)
|
|
|
|
{
|
|
|
|
Add(std::make_shared<CJob>([] {}));
|
|
|
|
}
|
|
|
|
|
2021-03-13 17:10:59 +00:00
|
|
|
TEST_F(Jobs, RunBlocking)
|
|
|
|
{
|
|
|
|
int Result = 0;
|
|
|
|
CJob Job([&] { Result = 1; });
|
|
|
|
EXPECT_EQ(Result, 0);
|
|
|
|
RunBlocking(&Job);
|
|
|
|
EXPECT_EQ(Result, 1);
|
|
|
|
}
|
|
|
|
|
2017-11-24 09:33:42 +00:00
|
|
|
TEST_F(Jobs, Wait)
|
|
|
|
{
|
|
|
|
SEMAPHORE sphore;
|
|
|
|
sphore_init(&sphore);
|
|
|
|
Add(std::make_shared<CJob>([&] { sphore_signal(&sphore); }));
|
|
|
|
sphore_wait(&sphore);
|
|
|
|
sphore_destroy(&sphore);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(Jobs, LookupHost)
|
|
|
|
{
|
|
|
|
static const char *HOST = "example.com";
|
|
|
|
static const int NETTYPE = NETTYPE_ALL;
|
|
|
|
auto pJob = std::make_shared<CHostLookup>(HOST, NETTYPE);
|
|
|
|
|
|
|
|
EXPECT_STREQ(pJob->m_aHostname, HOST);
|
|
|
|
EXPECT_EQ(pJob->m_Nettype, NETTYPE);
|
|
|
|
|
|
|
|
Add(pJob);
|
|
|
|
while(pJob->Status() != IJob::STATE_DONE)
|
|
|
|
{
|
|
|
|
// yay, busy loop...
|
|
|
|
thread_yield();
|
|
|
|
}
|
|
|
|
|
|
|
|
EXPECT_STREQ(pJob->m_aHostname, HOST);
|
|
|
|
EXPECT_EQ(pJob->m_Nettype, NETTYPE);
|
|
|
|
ASSERT_EQ(pJob->m_Result, 0);
|
|
|
|
EXPECT_EQ(pJob->m_Addr.type & NETTYPE, pJob->m_Addr.type);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(Jobs, Many)
|
|
|
|
{
|
|
|
|
std::atomic<int> ThreadsRunning(0);
|
|
|
|
std::vector<std::shared_ptr<IJob>> apJobs;
|
|
|
|
SEMAPHORE sphore;
|
|
|
|
sphore_init(&sphore);
|
|
|
|
for(int i = 0; i < TEST_NUM_THREADS; i++)
|
|
|
|
{
|
2020-09-26 19:41:58 +00:00
|
|
|
std::shared_ptr<IJob> pJob = std::make_shared<CJob>([&] {
|
2017-11-24 09:33:42 +00:00
|
|
|
int Prev = ThreadsRunning.fetch_add(1);
|
|
|
|
if(Prev == TEST_NUM_THREADS - 1)
|
|
|
|
{
|
|
|
|
sphore_signal(&sphore);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
EXPECT_EQ(pJob->Status(), IJob::STATE_PENDING);
|
|
|
|
apJobs.push_back(pJob);
|
|
|
|
}
|
2020-09-26 19:41:58 +00:00
|
|
|
for(auto &pJob : apJobs)
|
2017-11-24 09:33:42 +00:00
|
|
|
{
|
|
|
|
Add(pJob);
|
|
|
|
}
|
|
|
|
sphore_wait(&sphore);
|
|
|
|
sphore_destroy(&sphore);
|
|
|
|
m_Pool.~CJobPool();
|
2020-09-26 19:41:58 +00:00
|
|
|
for(auto &pJob : apJobs)
|
2017-11-24 09:33:42 +00:00
|
|
|
{
|
|
|
|
EXPECT_EQ(pJob->Status(), IJob::STATE_DONE);
|
|
|
|
}
|
|
|
|
new(&m_Pool) CJobPool();
|
|
|
|
}
|