From 5e931fe127d9943dbab7a57b65cd2602cbb72581 Mon Sep 17 00:00:00 2001 From: Michael Friedrich Date: Tue, 7 May 2019 17:23:16 +0200 Subject: [PATCH] Tests: Add cases for LegacyTimePeriod::ProcessTimeRangeRaw() --- test/CMakeLists.txt | 1 + test/icinga-legacytimeperiod.cpp | 59 ++++++++++++++++++++++++++++++++ 2 files changed, 60 insertions(+) diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt index b973a4361..f9eb12dc5 100644 --- a/test/CMakeLists.txt +++ b/test/CMakeLists.txt @@ -128,6 +128,7 @@ add_boost_test(base icinga_notification/type_filter icinga_macros/simple icinga_legacytimeperiod/simple + icinga_legacytimeperiod/advanced icinga_perfdata/empty icinga_perfdata/simple icinga_perfdata/quotes diff --git a/test/icinga-legacytimeperiod.cpp b/test/icinga-legacytimeperiod.cpp index 695a2a1cc..1c3e0fd1b 100644 --- a/test/icinga-legacytimeperiod.cpp +++ b/test/icinga-legacytimeperiod.cpp @@ -1,5 +1,6 @@ /* Icinga 2 | (c) 2012 Icinga GmbH | GPLv2+ */ +#include "base/utility.hpp" #include "icinga/legacytimeperiod.hpp" #include @@ -86,4 +87,62 @@ BOOST_AUTO_TEST_CASE(simple) BOOST_CHECK_EQUAL(mktime(&end), (time_t) 1456790400); // 2016-03-01 } +BOOST_AUTO_TEST_CASE(advanced) { + tm beg, end, ref; + time_t ts_beg, ts_end, ts_beg_exp, ts_end_exp; + + //2019-05-06 where Icinga celebrates 10 years #monitoringlove + String timestamp = "22:00-06:00"; + ref.tm_year = 2019 - 1900; + ref.tm_mon = 5 - 1; + ref.tm_mday = 6; + + LegacyTimePeriod::ProcessTimeRangeRaw(timestamp, &ref, &beg, &end); + ts_beg = mktime(&beg); + ts_end = mktime(&end); + ts_beg_exp = 1557180000; // 2019-05-06 22:00:00 + ts_end_exp = 1557208800; // 2019-05-07 06:00:00 + + BOOST_CHECK_EQUAL(ts_beg, ts_beg_exp); + BOOST_TEST_MESSAGE("Begin date: " << Utility::FormatDateTime("%Y-%m-%d %H:%M:%S %z", ts_beg) << " expected " << Utility::FormatDateTime("%Y-%m-%d %H:%M:%S %z", ts_beg_exp)); + BOOST_CHECK_EQUAL(ts_end, ts_end_exp); + BOOST_TEST_MESSAGE("End date: " << Utility::FormatDateTime("%Y-%m-%d %H:%M:%S %z", ts_end) << " expected " << Utility::FormatDateTime("%Y-%m-%d %H:%M:%S %z", ts_end_exp)); + + + //2019-05-06 Icinga is unleashed. + timestamp = "09:00-17:00"; + ref.tm_year = 2009 - 1900; + ref.tm_mon = 5 - 1; + ref.tm_mday = 6; + + LegacyTimePeriod::ProcessTimeRangeRaw(timestamp, &ref, &beg, &end); + ts_beg = mktime(&beg); + ts_end = mktime(&end); + ts_beg_exp = 1241600400; // 2009-05-06 09:00:00 + ts_end_exp = 1241629200; // 2009-05-06 17:00:00 + + BOOST_CHECK_EQUAL(ts_beg, ts_beg_exp); + BOOST_TEST_MESSAGE("Begin date: " << Utility::FormatDateTime("%Y-%m-%d %H:%M:%S %z", ts_beg) << " expected " << Utility::FormatDateTime("%Y-%m-%d %H:%M:%S %z", ts_beg_exp)); + BOOST_CHECK_EQUAL(ts_end, ts_end_exp); + BOOST_TEST_MESSAGE("End date: " << Utility::FormatDateTime("%Y-%m-%d %H:%M:%S %z", ts_end) << " expected " << Utility::FormatDateTime("%Y-%m-%d %H:%M:%S %z", ts_end_exp)); + + //At our first Icinga Camp in SFO 2014 at GitHub HQ, we partied all night long with an overflow. + timestamp = "09:00-30:00"; + ref.tm_year = 2014 - 1900; + ref.tm_mon = 9 - 1; + ref.tm_mday = 25; + + LegacyTimePeriod::ProcessTimeRangeRaw(timestamp, &ref, &beg, &end); + ts_beg = mktime(&beg); + ts_end = mktime(&end); + ts_beg_exp = 1411549200; // 2014-09-24 09:00:00 + ts_end_exp = 1411624800; // 2014-09-25 06:00:00 + + BOOST_CHECK_EQUAL(ts_beg, ts_beg_exp); + BOOST_TEST_MESSAGE("Begin date: " << Utility::FormatDateTime("%Y-%m-%d %H:%M:%S %z", ts_beg) << " expected " << Utility::FormatDateTime("%Y-%m-%d %H:%M:%S %z", ts_beg_exp)); + BOOST_CHECK_EQUAL(ts_end, ts_end_exp); + BOOST_TEST_MESSAGE("End date: " << Utility::FormatDateTime("%Y-%m-%d %H:%M:%S %z", ts_end) << " expected " << Utility::FormatDateTime("%Y-%m-%d %H:%M:%S %z", ts_end_exp)); + + } + BOOST_AUTO_TEST_SUITE_END()