2016-04-24 02:45:01 +08:00
|
|
|
#include <chrono>
|
2017-02-18 18:54:37 +08:00
|
|
|
#include <iostream>
|
2016-04-24 02:45:01 +08:00
|
|
|
|
2016-12-22 22:51:16 +08:00
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
2016-08-11 11:47:30 +08:00
|
|
|
#include "logging/default.cpp"
|
2016-12-22 22:51:16 +08:00
|
|
|
#include "utils/assert.hpp"
|
2017-02-18 18:54:37 +08:00
|
|
|
#include "utils/timer/timer.hpp"
|
2016-04-24 02:45:01 +08:00
|
|
|
|
|
|
|
using namespace std::chrono_literals;
|
2017-02-18 21:36:50 +08:00
|
|
|
using namespace utils;
|
2016-04-24 02:45:01 +08:00
|
|
|
|
2016-12-22 22:51:16 +08:00
|
|
|
/**
|
|
|
|
* Creates a test timer which will log timeout message at the timeout event.
|
|
|
|
*
|
|
|
|
* @param counter how many time units the timer has to wait
|
|
|
|
*
|
|
|
|
* @return shared pointer to a timer
|
|
|
|
*/
|
2017-02-18 18:54:37 +08:00
|
|
|
Timer::sptr create_test_timer(int64_t counter) {
|
|
|
|
return std::make_shared<Timer>(counter,
|
|
|
|
[]() { logging::info("Timer timeout"); });
|
2016-04-24 02:45:01 +08:00
|
|
|
}
|
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
TEST(TimerSchedulerTest, TimerSchedulerExecution) {
|
|
|
|
// initialize the timer
|
|
|
|
TimerScheduler<TimerSet, std::chrono::seconds> timer_scheduler;
|
|
|
|
|
|
|
|
// run the timer
|
|
|
|
timer_scheduler.run();
|
2016-12-22 22:51:16 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
// add a couple of test timers
|
|
|
|
for (int64_t i = 1; i <= 3; ++i) {
|
|
|
|
timer_scheduler.add(create_test_timer(i));
|
|
|
|
}
|
2016-12-22 22:51:16 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
// wait for that timers
|
|
|
|
std::this_thread::sleep_for(4s);
|
2016-12-22 22:51:16 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
ASSERT_EQ(timer_scheduler.size(), 0);
|
2016-12-22 22:51:16 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
// add another test timer
|
|
|
|
timer_scheduler.add(create_test_timer(1));
|
2016-12-22 22:51:16 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
// wait for another timer
|
|
|
|
std::this_thread::sleep_for(2s);
|
2016-12-22 22:51:16 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
// the test is done
|
|
|
|
timer_scheduler.stop();
|
2016-12-22 22:51:16 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
ASSERT_EQ(timer_scheduler.size(), 0);
|
2016-12-22 22:51:16 +08:00
|
|
|
}
|
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
int main(int argc, char **argv) {
|
|
|
|
::testing::InitGoogleTest(&argc, argv);
|
|
|
|
return RUN_ALL_TESTS();
|
2016-04-24 02:45:01 +08:00
|
|
|
}
|