API
 
Loading...
Searching...
No Matches
telem_stage_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_stage.hpp"
5#include "../types/generated/telem_stage_generated.h"
6#include "../types/flatbuffer_log.hpp"
7
8/*
9 * GENERATED TEST FILE for types/telem_stage.hpp
10 * generated by generateTemplateCatch2Tests.py
11 */
12
13const int8_t telemStageMoving_0 = 92; // dummy moving
14const float telemStagePreset_0 = 0.089952; // dummy preset
15const std::string telemStagePresetName_0 = "cxcl6akubh"; // dummy presetName
16
17
18/** Class to encapsulate telem_stage flatbuffer data using
19 ** => types/telem_stage.hpp
20 ** => types/generated/telem_stage_generated.h
21 **/
23{
24public:
25 // Saved input parameter value; unused
28 std::string m_saveTsPresetName;
29
30 // Parameters retrieved from flatbuffer
31 int8_t m_moving;
32 float m_preset;
33 std::string m_presetName;
34
35 // Flatbuffers verifier success/failure
36 bool m_verify{false};
37
38 // flatbuffer data length; used in ::verify
39 int L;
40
41 // Constructor
42 CTelemStage_0(int8_t moving_, float preset_, std::string presetName_) {
43 // Save input parameters
44 m_saveTsMoving = moving_;
45 m_saveTsPreset = preset_;
46 m_saveTsPresetName = presetName_;
47
48 // Create the flatbuffer messageT using the input parameters
49 auto ts = MagAOX::logger::telem_stage::messageT(moving_, preset_, presetName_);
50
51 // Retrieve flatbuffer pointer (if not an empty_log type) and length
52 void* buffPtr = ts.builder.GetBufferPointer();
54
55 // Retrieve the flatbuffer parameters for Catch2 comparison below
58 m_presetName = std::string(MagAOX::logger::GetTelem_stage_fb(buffPtr)->presetName()->c_str());
59
60 // Run the telem_stage verifier
61 m_verify = verify(ts);
62 }
63
64 // Run the flatbuffer Verifier for this log type
65 // - requires bufferPtrT (shared_ptr<char*>) to full log entry
66 // comprising log header plus flatbuffer log message
68
69 // Timestamp, prioriy (use nominal value here)
70 flatlogs::timespecX tsx{0,0};
72
73 // Create full log: log header(*); log message (+)
74 // * Log level (priority)
75 // * Event code (implicit in <MagAOX::logger::type>)
76 // * Timestamp
77 // * Message size (variable length; 1, 2, or 8 bytes)
78 // + Message (variable length)
79
80 // N.G. allocates space and writes pointer value to logBuffer
81 flatlogs::bufferPtrT logBuffer;
82 flatlogs::logHeader::createLog<MagAOX::logger::telem_stage>(logBuffer
83 , tsx, msg
84 , prio);
85 // Run full log through flatbuffer Verifier
86 return MagAOX::logger::telem_stage::verify(logBuffer,L);
87 }
88};
89
90SCENARIO( "Create telem_stage 0", "[a log item]")
91{
92 GIVEN("a telem_stage log code")
93 {
94 WHEN("random values for fields")
95 {
96 // Create flatbuffer
98 // Compare flatbuffer parameters
99 REQUIRE(ts.m_moving == telemStageMoving_0);
100 REQUIRE(ts.m_preset == telemStagePreset_0);
102 REQUIRE(ts.m_verify);
103 }
104 }
105}
106
107
CTelemStage_0(int8_t moving_, float preset_, std::string presetName_)
bool verify(const typename MagAOX::logger::telem_stage::messageT &msg)
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_stage_fb * GetTelem_stage_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.
The type of the input message.
static bool verify(flatlogs::bufferPtrT &logBuff, flatlogs::msgLenT len)
A fixed-width timespec structure.
Definition timespecX.hpp:35
SCENARIO("Create telem_stage 0", "[a log item]")
const std::string telemStagePresetName_0
const float telemStagePreset_0
const int8_t telemStageMoving_0