2019-02-25 08:48:22 -05:00
|
|
|
/* Icinga 2 | (c) 2012 Icinga GmbH | GPLv2+ */
|
2013-04-19 06:58:16 -04:00
|
|
|
|
2014-05-25 10:23:35 -04:00
|
|
|
#include "base/timer.hpp"
|
|
|
|
|
#include "base/utility.hpp"
|
|
|
|
|
#include "base/application.hpp"
|
2016-09-07 02:20:51 -04:00
|
|
|
#include <BoostTestTargetConfig.h>
|
2013-04-19 06:58:16 -04:00
|
|
|
|
|
|
|
|
using namespace icinga;
|
|
|
|
|
|
2014-11-12 03:33:13 -05:00
|
|
|
BOOST_AUTO_TEST_SUITE(base_timer)
|
2013-04-19 06:58:16 -04:00
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(construct)
|
|
|
|
|
{
|
2023-03-21 05:30:15 -04:00
|
|
|
Timer::Ptr timer = Timer::Create();
|
2013-04-19 06:58:16 -04:00
|
|
|
BOOST_CHECK(timer);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(interval)
|
|
|
|
|
{
|
2023-03-21 05:30:15 -04:00
|
|
|
Timer::Ptr timer = Timer::Create();
|
2013-04-19 06:58:16 -04:00
|
|
|
timer->SetInterval(1.5);
|
|
|
|
|
BOOST_CHECK(timer->GetInterval() == 1.5);
|
|
|
|
|
}
|
|
|
|
|
|
2014-05-09 13:26:31 -04:00
|
|
|
BOOST_AUTO_TEST_CASE(invoke)
|
2013-04-19 06:58:16 -04:00
|
|
|
{
|
2025-08-29 10:06:07 -04:00
|
|
|
int counter = 0;
|
|
|
|
|
|
2023-03-21 05:30:15 -04:00
|
|
|
Timer::Ptr timer = Timer::Create();
|
2025-08-29 10:06:07 -04:00
|
|
|
timer->OnTimerExpired.connect([&counter](const Timer* const&) { counter++; });
|
|
|
|
|
timer->SetInterval(.1);
|
2013-04-19 06:58:16 -04:00
|
|
|
|
|
|
|
|
timer->Start();
|
2025-08-29 10:06:07 -04:00
|
|
|
Utility::Sleep(.55);
|
2013-04-19 06:58:16 -04:00
|
|
|
timer->Stop();
|
|
|
|
|
|
2025-08-29 10:06:07 -04:00
|
|
|
// At this point, the timer should have fired exactly 5 times (0.5 / 0.1) and the sixth time
|
|
|
|
|
// should not have fired yet as we stopped the timer after 0.55 seconds (0.6 would be needed).
|
|
|
|
|
BOOST_CHECK_EQUAL(5, counter);
|
2013-04-19 06:58:16 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(scope)
|
|
|
|
|
{
|
2025-08-29 10:06:07 -04:00
|
|
|
int counter = 0;
|
|
|
|
|
|
2023-03-21 05:30:15 -04:00
|
|
|
Timer::Ptr timer = Timer::Create();
|
2025-08-29 10:06:07 -04:00
|
|
|
timer->OnTimerExpired.connect([&counter](const Timer* const&) { counter++; });
|
|
|
|
|
timer->SetInterval(.1);
|
2013-04-19 06:58:16 -04:00
|
|
|
|
|
|
|
|
timer->Start();
|
2025-08-29 10:06:07 -04:00
|
|
|
Utility::Sleep(.55);
|
2013-04-19 06:58:16 -04:00
|
|
|
timer.reset();
|
2025-08-29 10:06:07 -04:00
|
|
|
Utility::Sleep(.1);
|
2013-04-19 06:58:16 -04:00
|
|
|
|
2025-08-29 10:06:07 -04:00
|
|
|
// At this point, the timer should have fired exactly 5 times (0.5 / 0.1) and the sixth time
|
|
|
|
|
// should not have fired yet as we destroyed the timer after 0.55 seconds (0.6 would be needed),
|
|
|
|
|
// and even if we wait another 0.1 seconds after its destruction, it should not fire again.
|
|
|
|
|
BOOST_CHECK_EQUAL(5, counter);
|
2014-05-09 13:26:31 -04:00
|
|
|
}
|
2013-04-19 06:58:16 -04:00
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_SUITE_END()
|