tests: speed up timer tests using smaller sleep times

This commit is contained in:
Yonas Habteab 2025-08-29 16:06:07 +02:00
parent 97ad0fc552
commit a2b44c0fbb

View File

@ -22,40 +22,40 @@ BOOST_AUTO_TEST_CASE(interval)
BOOST_CHECK(timer->GetInterval() == 1.5); BOOST_CHECK(timer->GetInterval() == 1.5);
} }
int counter = 0;
static void Callback(const Timer * const&)
{
counter++;
}
BOOST_AUTO_TEST_CASE(invoke) BOOST_AUTO_TEST_CASE(invoke)
{ {
Timer::Ptr timer = Timer::Create(); int counter = 0;
timer->OnTimerExpired.connect(&Callback);
timer->SetInterval(1); Timer::Ptr timer = Timer::Create();
timer->OnTimerExpired.connect([&counter](const Timer* const&) { counter++; });
timer->SetInterval(.1);
counter = 0;
timer->Start(); timer->Start();
Utility::Sleep(5.5); Utility::Sleep(.55);
timer->Stop(); timer->Stop();
BOOST_CHECK(counter >= 4 && counter <= 6); // 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);
} }
BOOST_AUTO_TEST_CASE(scope) BOOST_AUTO_TEST_CASE(scope)
{ {
int counter = 0;
Timer::Ptr timer = Timer::Create(); Timer::Ptr timer = Timer::Create();
timer->OnTimerExpired.connect(&Callback); timer->OnTimerExpired.connect([&counter](const Timer* const&) { counter++; });
timer->SetInterval(1); timer->SetInterval(.1);
counter = 0;
timer->Start(); timer->Start();
Utility::Sleep(5.5); Utility::Sleep(.55);
timer.reset(); timer.reset();
Utility::Sleep(5.5); Utility::Sleep(.1);
BOOST_CHECK(counter >= 4 && counter <= 6); // 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);
} }
BOOST_AUTO_TEST_SUITE_END() BOOST_AUTO_TEST_SUITE_END()