mirror of
https://github.com/nasa/trick.git
synced 2025-01-15 17:29:48 +00:00
106 lines
3.0 KiB
C++
106 lines
3.0 KiB
C++
|
/*
|
||
|
* $Id: TPROCTEClock_test.cpp 6601 2013-06-24 (Lindsay Landry)
|
||
|
*/
|
||
|
|
||
|
/******************NOTES**********************************************
|
||
|
* The TPRO CTE clock requires special hardware to work. These tests
|
||
|
* ensure that the TPRO class properly handles cases in which no
|
||
|
* hardware is in use.
|
||
|
*
|
||
|
* Listed requirements are under requirement Trick-153 (3.7.1.2)
|
||
|
* Real-time control shall be able to use an external clock source
|
||
|
*********************************************************************/
|
||
|
|
||
|
|
||
|
|
||
|
#include <iostream>
|
||
|
#include <sys/types.h>
|
||
|
#include <signal.h>
|
||
|
#include <map>
|
||
|
|
||
|
|
||
|
#include "gtest/gtest.h"
|
||
|
#include "sim_services/Clock/include/Clock.hh"
|
||
|
#include "sim_services/Clock/include/clock_proto.h"
|
||
|
#include "sim_services/Clock/include/GetTimeOfDayClock.hh"
|
||
|
#include "sim_services/Clock/include/TPROCTEClock.hh"
|
||
|
#include "sim_services/Clock/include/BC635Clock.hh"
|
||
|
#include "sim_services/SimObject/include/JobData.hh"
|
||
|
#include "trick_utils/reqs/include/RequirementScribe.hh"
|
||
|
|
||
|
namespace Trick {
|
||
|
|
||
|
class TPROCTEClockTest : public ::testing::Test {
|
||
|
|
||
|
protected:
|
||
|
Trick::TPROCTEClock proclk;
|
||
|
|
||
|
TPROCTEClockTest() {}
|
||
|
~TPROCTEClockTest() {}
|
||
|
virtual void SetUp() {}
|
||
|
virtual void TearDown() {}
|
||
|
|
||
|
Trick::RequirementScribe req;
|
||
|
} ;
|
||
|
|
||
|
//std::map< std::string , unsigned int > TPROCTEClockTest::num_reqs;
|
||
|
|
||
|
/* Ensure clock initializes correctly */
|
||
|
TEST_F(TPROCTEClockTest, Initialize) {
|
||
|
req.add_requirement("TPROCTE_clock");
|
||
|
//"The TPROCTE clock shall initialize reference time of 0, and all ratios set to 1.");
|
||
|
|
||
|
/* General expected clock initialization */
|
||
|
EXPECT_EQ(proclk.get_rt_clock_ratio() , 1.0);
|
||
|
EXPECT_EQ(proclk.sim_tic_ratio, 1.0);
|
||
|
EXPECT_EQ(proclk.ref_time_tics, 0);
|
||
|
|
||
|
/* TPROCTEClock initialization tests */
|
||
|
EXPECT_STREQ(proclk.get_name() , "TPROCTE");
|
||
|
|
||
|
}
|
||
|
|
||
|
/* Run tests for when no hardware is available */
|
||
|
#ifndef _TPRO_CTE
|
||
|
TEST_F(TPROCTEClockTest, NoHardware) {
|
||
|
req.add_requirement("TPROCTE_clock");
|
||
|
//"The TPROCTE clock shall display error messages when attempting to use its functions with no hardware");
|
||
|
|
||
|
long long req_time = rand();
|
||
|
|
||
|
EXPECT_EQ(proclk.clock_init(), -1);
|
||
|
EXPECT_EQ(proclk.wall_clock_time(), 0);
|
||
|
EXPECT_EQ(proclk.clock_spin(req_time), req_time);
|
||
|
EXPECT_EQ(proclk.clock_stop(), 0);
|
||
|
|
||
|
proclk.set_reference(req_time);
|
||
|
EXPECT_EQ(proclk.clock_time(), -req_time);
|
||
|
|
||
|
proclk.adjust_ref_time(req_time);
|
||
|
EXPECT_EQ(proclk.clock_time(), -2*req_time);
|
||
|
|
||
|
|
||
|
}
|
||
|
|
||
|
#endif
|
||
|
|
||
|
/* Ensure generic clock functions work properly */
|
||
|
TEST_F(TPROCTEClockTest, TestRefTimes) {
|
||
|
req.add_requirement("TPROCTE_clock");
|
||
|
//"The TPROCTE clock shall provide the ability to adjust the reference time");
|
||
|
|
||
|
long long secs_remainder;
|
||
|
int tics_per_s = 1000000000;
|
||
|
double align_tics_mult = 1.5;
|
||
|
|
||
|
int clock_unit = int((tics_per_s * align_tics_mult)/(proclk.rt_clock_ratio * proclk.sim_tic_ratio));
|
||
|
|
||
|
proclk.sync_to_wall_clock(align_tics_mult, tics_per_s);
|
||
|
secs_remainder = proclk.ref_time_tics% clock_unit;
|
||
|
EXPECT_EQ(secs_remainder, 0);
|
||
|
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|