API
 
Loading...
Searching...
No Matches
telem_fgtimings_generated_tests.cpp
Go to the documentation of this file.
1#include <assert.h>
2#include "../../../../tests/catch2/catch.hpp"
3#include "../generated/logCodes.hpp"
4#include "../types/telem_fgtimings.hpp"
5#include "../types/generated/telem_fgtimings_generated.h"
6#include "../types/flatbuffer_log.hpp"
7
8/*
9 * GENERATED TEST FILE for types/telem_fgtimings.hpp
10 * generated by generateTemplateCatch2Tests.py
11 */
12
13const double telemFgtimingsAtime_0 = 0.09281941433482; // dummy atime
14const double telemFgtimingsAtime_jitter_0 = 0.64712944805278; // dummy atime_jitter
15const double telemFgtimingsWtime_0 = 0.88990783780534; // dummy wtime
16const double telemFgtimingsWtime_jitter_0 = 0.94675596502473; // dummy wtime_jitter
17const double telemFgtimingsMawtime_0 = 0.47603912070956; // dummy mawtime
18const double telemFgtimingsMawtime_jitter_0 = 0.29069173978694; // dummy mawtime_jitter
19
20
21/** Class to encapsulate telem_fgtimings flatbuffer data using
22 ** => types/telem_fgtimings.hpp
23 ** => types/generated/telem_fgtimings_generated.h
24 **/
26{
27public:
28 // Saved input parameter value; unused
35
36 // Parameters retrieved from flatbuffer
37 double m_atime;
39 double m_wtime;
41 double m_mawtime;
43
44 // Flatbuffers verifier success/failure
45 bool m_verify{false};
46
47 // flatbuffer data length; used in ::verify
48 int L;
49
50 // Constructor
51 CTelemFgtimings_0(double atime_, double atime_jitter_, double wtime_, double wtime_jitter_, double mawtime_, double mawtime_jitter_) {
52 // Save input parameters
53 m_saveTfAtime = atime_;
54 m_saveTfAtime_jitter = atime_jitter_;
55 m_saveTfWtime = wtime_;
56 m_saveTfWtime_jitter = wtime_jitter_;
57 m_saveTfMawtime = mawtime_;
58 m_saveTfMawtime_jitter = mawtime_jitter_;
59
60 // Create the flatbuffer messageT using the input parameters
61 auto tf = MagAOX::logger::telem_fgtimings::messageT(atime_, atime_jitter_, wtime_, wtime_jitter_, mawtime_, mawtime_jitter_);
62
63 // Retrieve flatbuffer pointer (if not an empty_log type) and length
64 void* buffPtr = tf.builder.GetBufferPointer();
66
67 // Retrieve the flatbuffer parameters for Catch2 comparison below
74
75 // Run the telem_fgtimings verifier
76 m_verify = verify(tf);
77 }
78
79 // Run the flatbuffer Verifier for this log type
80 // - requires bufferPtrT (shared_ptr<char*>) to full log entry
81 // comprising log header plus flatbuffer log message
83
84 // Timestamp, prioriy (use nominal value here)
85 flatlogs::timespecX tsx{0,0};
87
88 // Create full log: log header(*); log message (+)
89 // * Log level (priority)
90 // * Event code (implicit in <MagAOX::logger::type>)
91 // * Timestamp
92 // * Message size (variable length; 1, 2, or 8 bytes)
93 // + Message (variable length)
94
95 // N.G. allocates space and writes pointer value to logBuffer
96 flatlogs::bufferPtrT logBuffer;
97 flatlogs::logHeader::createLog<MagAOX::logger::telem_fgtimings>(logBuffer
98 , tsx, msg
99 , prio);
100 // Run full log through flatbuffer Verifier
102 }
103};
104
105SCENARIO( "Create telem_fgtimings 0", "[a log item]")
106{
107 GIVEN("a telem_fgtimings log code")
108 {
109 WHEN("random values for fields")
110 {
111 // Create flatbuffer
113 // Compare flatbuffer parameters
114 REQUIRE(tf.m_atime == telemFgtimingsAtime_0);
116 REQUIRE(tf.m_wtime == telemFgtimingsWtime_0);
118 REQUIRE(tf.m_mawtime == telemFgtimingsMawtime_0);
120 REQUIRE(tf.m_verify);
121 }
122 }
123}
124
125
bool verify(const typename MagAOX::logger::telem_fgtimings::messageT &msg)
CTelemFgtimings_0(double atime_, double atime_jitter_, double wtime_, double wtime_jitter_, double mawtime_, double mawtime_jitter_)
int8_t logPrioT
The type of the log priority code.
Definition logDefs.hpp:21
std::shared_ptr< char > bufferPtrT
The log entry buffer smart pointer.
Definition logHeader.hpp:58
const MagAOX::logger::Telem_fgtimings_fb * GetTelem_fgtimings_fb(const void *buf)
static constexpr logPrioT LOG_DEFAULT
Used to denote "use the default level for this log type".
static flatlogs::msgLenT length(const fbMessage &msg)
Get the length of the message.
static bool verify(flatlogs::bufferPtrT &logBuff, flatlogs::msgLenT len)
A fixed-width timespec structure.
Definition timespecX.hpp:35
const double telemFgtimingsAtime_jitter_0
SCENARIO("Create telem_fgtimings 0", "[a log item]")
const double telemFgtimingsMawtime_0
const double telemFgtimingsAtime_0
const double telemFgtimingsWtime_0
const double telemFgtimingsWtime_jitter_0
const double telemFgtimingsMawtime_jitter_0