Added Tests for CCSDS Time, fixed LPM Test
Changed behaviour of Host and Linux Clock
This commit is contained in:
parent
5912ddd2a2
commit
8b1af232c3
@ -150,17 +150,14 @@ ReturnValue_t Clock::convertTimeOfDayToTimeval(const TimeOfDay_t* from, timeval*
|
|||||||
time_tm.tm_hour = from->hour;
|
time_tm.tm_hour = from->hour;
|
||||||
time_tm.tm_min = from->minute;
|
time_tm.tm_min = from->minute;
|
||||||
time_tm.tm_sec = from->second;
|
time_tm.tm_sec = from->second;
|
||||||
|
time_tm.tm_isdst = 0;
|
||||||
|
|
||||||
time_t seconds = mktime(&time_tm);
|
time_t seconds = timegm(&time_tm);
|
||||||
|
|
||||||
to->tv_sec = seconds;
|
to->tv_sec = seconds;
|
||||||
to->tv_usec = from->usecond;
|
to->tv_usec = from->usecond;
|
||||||
// Fails in 2038..
|
// Fails in 2038..
|
||||||
return HasReturnvaluesIF::RETURN_OK;
|
return HasReturnvaluesIF::RETURN_OK;
|
||||||
#if FSFW_CPP_OSTREAM_ENABLED == 1
|
|
||||||
sif::warning << "Clock::convertTimeBla: not implemented yet" << std::endl;
|
|
||||||
#endif
|
|
||||||
return HasReturnvaluesIF::RETURN_OK;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ReturnValue_t Clock::convertTimevalToJD2000(timeval time, double* JD2000) {
|
ReturnValue_t Clock::convertTimevalToJD2000(timeval time, double* JD2000) {
|
||||||
|
@ -140,8 +140,9 @@ ReturnValue_t Clock::convertTimeOfDayToTimeval(const TimeOfDay_t* from, timeval*
|
|||||||
fromTm.tm_hour = from->hour;
|
fromTm.tm_hour = from->hour;
|
||||||
fromTm.tm_min = from->minute;
|
fromTm.tm_min = from->minute;
|
||||||
fromTm.tm_sec = from->second;
|
fromTm.tm_sec = from->second;
|
||||||
|
fromTm.tm_isdst = 0;
|
||||||
|
|
||||||
to->tv_sec = mktime(&fromTm);
|
to->tv_sec = timegm(&fromTm);
|
||||||
to->tv_usec = from->usecond;
|
to->tv_usec = from->usecond;
|
||||||
return HasReturnvaluesIF::RETURN_OK;
|
return HasReturnvaluesIF::RETURN_OK;
|
||||||
}
|
}
|
||||||
|
@ -557,6 +557,35 @@ ReturnValue_t CCSDSTime::convertFromCDS(timeval* to, const uint8_t* from, size_t
|
|||||||
return RETURN_OK;
|
return RETURN_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ReturnValue_t CCSDSTime::convertFromCDS(timeval* to, const CCSDSTime::CDS_short* from) {
|
||||||
|
if (to == nullptr or from == nullptr) {
|
||||||
|
return HasReturnvaluesIF::RETURN_FAILED;
|
||||||
|
}
|
||||||
|
uint16_t days = (from->dayMSB << 8) + from->dayLSB;
|
||||||
|
if (days <= DAYS_CCSDS_TO_UNIX_EPOCH) {
|
||||||
|
return INVALID_TIME_FORMAT;
|
||||||
|
}
|
||||||
|
days -= DAYS_CCSDS_TO_UNIX_EPOCH;
|
||||||
|
to->tv_sec = days * SECONDS_PER_DAY;
|
||||||
|
uint32_t msDay =
|
||||||
|
(from->msDay_hh << 24) + (from->msDay_h << 16) + (from->msDay_l << 8) + from->msDay_ll;
|
||||||
|
to->tv_sec += (msDay / 1000);
|
||||||
|
to->tv_usec = (msDay % 1000) * 1000;
|
||||||
|
return HasReturnvaluesIF::RETURN_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
ReturnValue_t CCSDSTime::convertFromCDS(Clock::TimeOfDay_t* to, const CCSDSTime::CDS_short* from) {
|
||||||
|
if (to == nullptr or from == nullptr) {
|
||||||
|
return HasReturnvaluesIF::RETURN_FAILED;
|
||||||
|
}
|
||||||
|
timeval tempTimeval;
|
||||||
|
ReturnValue_t result = convertFromCDS(&tempTimeval, from);
|
||||||
|
if (result != HasReturnvaluesIF::RETURN_OK) {
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
return CCSDSTime::convertTimevalToTimeOfDay(to, &tempTimeval);
|
||||||
|
}
|
||||||
|
|
||||||
ReturnValue_t CCSDSTime::convertFromCUC(timeval* to, uint8_t pField, const uint8_t* from,
|
ReturnValue_t CCSDSTime::convertFromCUC(timeval* to, uint8_t pField, const uint8_t* from,
|
||||||
size_t* foundLength, size_t maxLength) {
|
size_t* foundLength, size_t maxLength) {
|
||||||
uint32_t secs = 0;
|
uint32_t secs = 0;
|
||||||
|
@ -180,6 +180,8 @@ class CCSDSTime : public HasReturnvaluesIF {
|
|||||||
|
|
||||||
static ReturnValue_t convertFromCDS(timeval *to, uint8_t const *from, size_t *foundLength,
|
static ReturnValue_t convertFromCDS(timeval *to, uint8_t const *from, size_t *foundLength,
|
||||||
size_t maxLength);
|
size_t maxLength);
|
||||||
|
static ReturnValue_t convertFromCDS(timeval *to, const CCSDSTime::CDS_short *from);
|
||||||
|
static ReturnValue_t convertFromCDS(Clock::TimeOfDay_t *to, const CCSDSTime::CDS_short *from);
|
||||||
|
|
||||||
static ReturnValue_t convertFromCCS(Clock::TimeOfDay_t *to, uint8_t const *from,
|
static ReturnValue_t convertFromCCS(Clock::TimeOfDay_t *to, uint8_t const *from,
|
||||||
size_t *foundLength, size_t maxLength);
|
size_t *foundLength, size_t maxLength);
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include <fsfw/datapool/PoolReadGuard.h>
|
#include <fsfw/datapool/PoolReadGuard.h>
|
||||||
#include <fsfw/datapoollocal/HasLocalDataPoolIF.h>
|
#include <fsfw/datapoollocal/HasLocalDataPoolIF.h>
|
||||||
#include <fsfw/datapoollocal/StaticLocalDataSet.h>
|
#include <fsfw/datapoollocal/StaticLocalDataSet.h>
|
||||||
|
#include <fsfw/globalfunctions/timevalOperations.h>
|
||||||
#include <fsfw/housekeeping/HousekeepingSnapshot.h>
|
#include <fsfw/housekeeping/HousekeepingSnapshot.h>
|
||||||
#include <fsfw/ipc/CommandMessageCleaner.h>
|
#include <fsfw/ipc/CommandMessageCleaner.h>
|
||||||
#include <fsfw/objectmanager/ObjectManager.h>
|
#include <fsfw/objectmanager/ObjectManager.h>
|
||||||
@ -158,13 +159,10 @@ TEST_CASE("LocalPoolManagerTest", "[LocManTest]") {
|
|||||||
}
|
}
|
||||||
|
|
||||||
poolVar->setChanged(true);
|
poolVar->setChanged(true);
|
||||||
|
|
||||||
/* Store current time, we are going to check the (approximate) time equality later */
|
/* Store current time, we are going to check the (approximate) time equality later */
|
||||||
CCSDSTime::CDS_short timeCdsNow;
|
CCSDSTime::CDS_short timeCdsNow;
|
||||||
timeval now;
|
timeval now;
|
||||||
Clock::getClock_timeval(&now);
|
Clock::getClock_timeval(&now);
|
||||||
CCSDSTime::convertToCcsds(&timeCdsNow, &now);
|
|
||||||
|
|
||||||
REQUIRE(poolOwner->poolManager.performHkOperation() == retval::CATCH_OK);
|
REQUIRE(poolOwner->poolManager.performHkOperation() == retval::CATCH_OK);
|
||||||
|
|
||||||
/* Check update snapshot was sent. */
|
/* Check update snapshot was sent. */
|
||||||
@ -192,14 +190,12 @@ TEST_CASE("LocalPoolManagerTest", "[LocManTest]") {
|
|||||||
SerializeIF::Endianness::MACHINE) == retval::CATCH_OK);
|
SerializeIF::Endianness::MACHINE) == retval::CATCH_OK);
|
||||||
CHECK(varCopy.value == 25);
|
CHECK(varCopy.value == 25);
|
||||||
|
|
||||||
/* Now we check that both times are equal */
|
timeval timeFromHK;
|
||||||
CHECK(cdsShort.pField == timeCdsNow.pField);
|
auto result = CCSDSTime::convertFromCDS(&timeFromHK, &cdsShort);
|
||||||
CHECK(cdsShort.dayLSB == Catch::Approx(timeCdsNow.dayLSB).margin(1));
|
CHECK(result == HasReturnvaluesIF::RETURN_OK);
|
||||||
CHECK(cdsShort.dayMSB == Catch::Approx(timeCdsNow.dayMSB).margin(1));
|
/// timeval* to, const uint8_t* from, size_t* foundLength,size_t maxLength)
|
||||||
CHECK(cdsShort.msDay_h == Catch::Approx(timeCdsNow.msDay_h).margin(1));
|
timeval difference = timeFromHK - now;
|
||||||
CHECK(cdsShort.msDay_hh == Catch::Approx(timeCdsNow.msDay_hh).margin(1));
|
CHECK(timevalOperations::toDouble(difference) < 1.0);
|
||||||
CHECK(cdsShort.msDay_l == Catch::Approx(timeCdsNow.msDay_l).margin(1));
|
|
||||||
CHECK(cdsShort.msDay_ll == Catch::Approx(timeCdsNow.msDay_ll).margin(5));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
SECTION("VariableNotificationTest") {
|
SECTION("VariableNotificationTest") {
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
#include <fsfw/globalfunctions/timevalOperations.h>
|
||||||
#include <fsfw/timemanager/CCSDSTime.h>
|
#include <fsfw/timemanager/CCSDSTime.h>
|
||||||
|
|
||||||
#include <array>
|
#include <array>
|
||||||
@ -89,4 +90,35 @@ TEST_CASE("CCSDSTime Tests", "[TestCCSDSTime]") {
|
|||||||
REQUIRE(timeTo.second == 59);
|
REQUIRE(timeTo.second == 59);
|
||||||
REQUIRE(timeTo.usecond == Catch::Approx(123000));
|
REQUIRE(timeTo.usecond == Catch::Approx(123000));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SECTION("CDS Conversions") {
|
||||||
|
// Preperation
|
||||||
|
Clock::TimeOfDay_t time;
|
||||||
|
time.year = 2020;
|
||||||
|
time.month = 2;
|
||||||
|
time.day = 29;
|
||||||
|
time.hour = 13;
|
||||||
|
time.minute = 24;
|
||||||
|
time.second = 45;
|
||||||
|
time.usecond = 123456;
|
||||||
|
timeval timeAsTimeval;
|
||||||
|
auto result = Clock::convertTimeOfDayToTimeval(&time, &timeAsTimeval);
|
||||||
|
CHECK(result == HasReturnvaluesIF::RETURN_OK);
|
||||||
|
CHECK(timeAsTimeval.tv_sec == 1582982685);
|
||||||
|
CHECK(timeAsTimeval.tv_usec == 123456);
|
||||||
|
|
||||||
|
// Conversion to CDS Short
|
||||||
|
CCSDSTime::CDS_short cdsTime;
|
||||||
|
result = CCSDSTime::convertToCcsds(&cdsTime, &timeAsTimeval);
|
||||||
|
CHECK(result == HasReturnvaluesIF::RETURN_OK);
|
||||||
|
|
||||||
|
// Conversion back to timeval
|
||||||
|
timeval timeReturnAsTimeval;
|
||||||
|
result = CCSDSTime::convertFromCDS(&timeReturnAsTimeval, &cdsTime);
|
||||||
|
CHECK(result == HasReturnvaluesIF::RETURN_OK);
|
||||||
|
// us precision is lost
|
||||||
|
timeval difference = timeAsTimeval - timeReturnAsTimeval;
|
||||||
|
CHECK(difference.tv_usec == 456);
|
||||||
|
CHECK(difference.tv_sec == 0);
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user