light/modules/time/timer.test.cpp

64 lines
1.8 KiB
C++
Raw Normal View History

2026-01-20 13:22:30 +03:30
import test;
import time;
using ::lt::time::Timer;
2026-01-20 13:22:30 +03:30
/* @note: error margin is high since run-time may slow down extremely due to
* sanitization/debugging or execution through valgrind...
* <1us error margin is tested manually in release builds and it works fine.
**/
constexpr auto max_error_margin = std::chrono::milliseconds { 1 };
2025-09-30 06:44:09 +03:30
Suite raii = "raii"_suite = [] {
2025-07-15 15:53:30 +03:30
using std::chrono::microseconds;
2026-01-20 13:22:30 +03:30
Case { "happy paths" } = [] {
2025-07-15 15:53:30 +03:30
Timer {};
};
2026-01-20 13:22:30 +03:30
Case { "many" } = [] {
2025-07-25 15:07:13 +03:30
for (auto idx : std::views::iota(0, 100'001))
{
2026-01-20 09:58:35 +03:30
ignore = idx;
2025-07-15 15:53:30 +03:30
Timer {};
}
};
2025-07-15 15:53:30 +03:30
};
2025-09-30 06:44:09 +03:30
Suite reset_and_elapsed_time = "reset_and_elapsed_time"_suite = [] {
2025-07-15 15:53:30 +03:30
using std::chrono::hours;
using std::chrono::microseconds;
2026-01-20 13:22:30 +03:30
Case { "happy path" } = [] {
2025-07-15 15:53:30 +03:30
Timer {}.reset();
2026-01-20 09:58:35 +03:30
ignore = Timer {}.elapsed_time();
};
2025-09-30 06:44:09 +03:30
Case { "elapsed time is sane" } = [] {
expect_le(Timer {}.elapsed_time(), max_error_margin);
};
2025-09-30 06:44:09 +03:30
Case { "elapsed time is sane - constructed with old now" } = [] {
2025-07-15 15:53:30 +03:30
const auto timepoint = Timer::Clock::now() - hours { 1 };
// This fails sometimes in debug if error-range is under 10us
expect_le(Timer { timepoint }.elapsed_time(), hours { 1 } + max_error_margin);
2025-07-15 15:53:30 +03:30
};
2025-09-30 06:44:09 +03:30
Case { "reset -> elapsed time is sane - constructed with old now" } = [] {
2025-07-15 15:53:30 +03:30
auto timer = Timer { Timer::Clock::now() - microseconds { 100 } };
const auto old_elapsed_time = timer.elapsed_time();
timer.reset();
2025-07-15 15:53:30 +03:30
expect_le(timer.elapsed_time() - old_elapsed_time, microseconds { 100 } + max_error_margin);
};
2025-09-30 06:44:09 +03:30
Case { "reset -> elapsed time is sane - reset with future now" } = [] {
auto timer = Timer {};
2025-07-15 15:53:30 +03:30
const auto old_elapsed_time = timer.elapsed_time();
timer.reset(Timer::Clock::now() + microseconds { 100 });
expect_le(timer.elapsed_time() - old_elapsed_time, microseconds { 100 } + max_error_margin);
};
};