GCC Code Coverage Report


Directory: ./
File: TESTS/TEST_SUB_MESSAGE_PARSING/main.cpp
Date: 2026-01-15 15:40:41
Exec Total Coverage
Lines: 58 58 100.0%
Functions: 2 2 100.0%
Branches: 133 133 100.0%

Line Branch Exec Source
1 /***************************************
2 Auteur : Pierre Aubert
3 Mail : pierre.aubert@lapp.in2p3.fr
4 Licence : CeCILL-C
5 ****************************************/
6
7 #include "phoenix_assert.h"
8 #include "phoenix_check.h"
9 #include "data_all.h"
10 #include "FieldParser.h"
11
12 typedef std::vector<char> Message;
13 typedef std::vector<Message > VecMessage;
14
15
16 ///Dump all the messages bytes
17 /** @param fileName : input file name
18 */
19 1 void testSubMessageParsing(const std::string & fileName){
20 1 VecMessage vecInMessage;
21
5/5
✓ Branch 0 (5→6) taken 1 times.
✓ Branch 2 (8→9) taken 1 times.
✓ Branch 4 (11→12) taken 1 times.
✓ Branch 6 (12→13) taken 1 times.
✓ Branch 8 (13→14) taken 1 times.
5 phoenix_assert(data_load(fileName, vecInMessage));
22
23
1/1
✓ Branch 0 (20→21) taken 1 times.
1 FieldParser parser;
24 1 size_t field1(0lu), configurationId(0lu), eventId(0lu), telEventId(0lu);
25 1 unsigned int field3(0), triggerTimeS(0), triggerTimeQns(0), triggerType(0);
26
2/2
✓ Branch 0 (21→22) taken 1 times.
✓ Branch 2 (22→23) taken 1 times.
1 parser.addParseFieldEnum(&field1, 1lu, "Field 1");
27
2/2
✓ Branch 0 (24→25) taken 1 times.
✓ Branch 2 (25→26) taken 1 times.
1 parser.addParseFieldValue(&field3, 3lu, "Field 3");
28
29
2/2
✓ Branch 0 (27→28) taken 1 times.
✓ Branch 2 (28→29) taken 1 times.
1 FieldParser* eventParser = parser.addSubMessage(4lu, "Event");
30
2/2
✓ Branch 0 (30→31) taken 1 times.
✓ Branch 2 (31→32) taken 1 times.
1 eventParser->addParseFieldValue(&configurationId, 1lu, "configuration_id");
31
2/2
✓ Branch 0 (33→34) taken 1 times.
✓ Branch 2 (34→35) taken 1 times.
1 eventParser->addParseFieldValue(&eventId, 2lu, "event_id");
32
2/2
✓ Branch 0 (36→37) taken 1 times.
✓ Branch 2 (37→38) taken 1 times.
1 eventParser->addParseFieldValue(&telEventId, 3lu, "tel_event_id");
33
2/2
✓ Branch 0 (39→40) taken 1 times.
✓ Branch 2 (40→41) taken 1 times.
1 eventParser->addParseFieldValue(&triggerTimeS, 4lu, "trigger_time_s");
34
2/2
✓ Branch 0 (42→43) taken 1 times.
✓ Branch 2 (43→44) taken 1 times.
1 eventParser->addParseFieldValue(&triggerTimeQns, 5lu, "trigger_time_qns");
35
2/2
✓ Branch 0 (45→46) taken 1 times.
✓ Branch 2 (46→47) taken 1 times.
1 eventParser->addParseFieldValue(&triggerType, 6lu, "trigger_type");
36
37 1 unsigned short* tabWaveform = NULL;
38 1 size_t nbPixelSliceGain(0lu);
39
2/2
✓ Branch 0 (48→49) taken 1 times.
✓ Branch 2 (49→50) taken 1 times.
1 FieldParser * waveformParser = eventParser->addSubMessage(7lu, "waveform");
40
3/3
✓ Branch 0 (51→52) taken 1 times.
✓ Branch 2 (52→53) taken 1 times.
✓ Branch 4 (54→55) taken 1 times.
1 waveformParser->addParseFieldArray(&tabWaveform, &nbPixelSliceGain, 4lu, "data");
41
42
1/1
✓ Branch 0 (55→56) taken 1 times.
1 parser.print();
43
44 //Expected values of field 3
45
1/1
✓ Branch 0 (59→60) taken 1 times.
2 std::vector<unsigned int> vecExpectedField3 = {628325 ,628326, 628327,628328,628329,628330,628331,628332,628333,628334};
46
47 1 size_t i(0lu);
48 1 std::vector<unsigned int>::iterator itCheckField3 = vecExpectedField3.begin();
49
2/2
✓ Branch 0 (285→63) taken 10 times.
✓ Branch 1 (285→286) taken 1 times.
22 for(VecMessage::iterator it(vecInMessage.begin()); it != vecInMessage.end(); ++it){
50
5/5
✓ Branch 0 (65→66) taken 10 times.
✓ Branch 2 (68→69) taken 10 times.
✓ Branch 4 (71→72) taken 10 times.
✓ Branch 6 (74→75) taken 10 times.
✓ Branch 8 (75→76) taken 10 times.
60 phoenix_assert(parser.load(*it));
51
3/3
✓ Branch 0 (82→83) taken 10 times.
✓ Branch 2 (83→84) taken 10 times.
✓ Branch 4 (84→85) taken 10 times.
10 std::cout << "Parse Event " << i << std::endl;
52
5/5
✓ Branch 0 (85→86) taken 10 times.
✓ Branch 2 (86→87) taken 10 times.
✓ Branch 4 (87→88) taken 10 times.
✓ Branch 6 (88→89) taken 10 times.
✓ Branch 8 (89→90) taken 10 times.
10 std::cout << "testSubMessageParsing("<<i<<") : field 1 = " << field1 << std::endl;
53
4/4
✓ Branch 0 (92→93) taken 10 times.
✓ Branch 2 (95→96) taken 10 times.
✓ Branch 4 (98→99) taken 10 times.
✓ Branch 6 (99→100) taken 10 times.
50 phoenix_assert(field1 == 16lu);
54
5/5
✓ Branch 0 (106→107) taken 10 times.
✓ Branch 2 (107→108) taken 10 times.
✓ Branch 4 (108→109) taken 10 times.
✓ Branch 6 (109→110) taken 10 times.
✓ Branch 8 (110→111) taken 10 times.
10 std::cout << "testSubMessageParsing("<<i<<") : field 3 = " << field3 << std::endl;
55
4/4
✓ Branch 0 (113→114) taken 10 times.
✓ Branch 2 (116→117) taken 10 times.
✓ Branch 4 (119→120) taken 10 times.
✓ Branch 6 (122→123) taken 10 times.
60 phoenix_assert(*itCheckField3 == field3);
56
57
5/5
✓ Branch 0 (129→130) taken 10 times.
✓ Branch 2 (130→131) taken 10 times.
✓ Branch 4 (131→132) taken 10 times.
✓ Branch 6 (132→133) taken 10 times.
✓ Branch 8 (133→134) taken 10 times.
10 std::cout << "testSubMessageParsing("<<i<<") : configuration_id = " << configurationId << std::endl;
58
4/4
✓ Branch 0 (136→137) taken 10 times.
✓ Branch 2 (139→140) taken 10 times.
✓ Branch 4 (142→143) taken 10 times.
✓ Branch 6 (143→144) taken 10 times.
50 phoenix_assert(configurationId == 0);
59 10 size_t expectedEventId = 2417265 + 4lu*i;
60
5/5
✓ Branch 0 (150→151) taken 10 times.
✓ Branch 2 (151→152) taken 10 times.
✓ Branch 4 (152→153) taken 10 times.
✓ Branch 6 (153→154) taken 10 times.
✓ Branch 8 (154→155) taken 10 times.
10 std::cout << "testSubMessageParsing("<<i<<") : event_id = " << eventId << std::endl;
61
4/4
✓ Branch 0 (157→158) taken 10 times.
✓ Branch 2 (160→161) taken 10 times.
✓ Branch 4 (163→164) taken 10 times.
✓ Branch 6 (164→165) taken 10 times.
50 phoenix_assert(eventId == expectedEventId);
62
5/5
✓ Branch 0 (171→172) taken 10 times.
✓ Branch 2 (172→173) taken 10 times.
✓ Branch 4 (173→174) taken 10 times.
✓ Branch 6 (174→175) taken 10 times.
✓ Branch 8 (175→176) taken 10 times.
10 std::cout << "testSubMessageParsing("<<i<<") : tel_event_id = " << telEventId << std::endl;
63
4/4
✓ Branch 0 (178→179) taken 10 times.
✓ Branch 2 (181→182) taken 10 times.
✓ Branch 4 (184→185) taken 10 times.
✓ Branch 6 (185→186) taken 10 times.
50 phoenix_assert(eventId == telEventId);
64
5/5
✓ Branch 0 (192→193) taken 10 times.
✓ Branch 2 (193→194) taken 10 times.
✓ Branch 4 (194→195) taken 10 times.
✓ Branch 6 (195→196) taken 10 times.
✓ Branch 8 (196→197) taken 10 times.
10 std::cout << "testSubMessageParsing("<<i<<") : trigger_time_s = " << triggerTimeS << std::endl;
65
4/4
✓ Branch 0 (199→200) taken 10 times.
✓ Branch 2 (202→203) taken 10 times.
✓ Branch 4 (205→206) taken 10 times.
✓ Branch 6 (206→207) taken 10 times.
50 phoenix_assert(triggerTimeS == 1625787312u);
66
5/5
✓ Branch 0 (213→214) taken 10 times.
✓ Branch 2 (214→215) taken 10 times.
✓ Branch 4 (215→216) taken 10 times.
✓ Branch 6 (216→217) taken 10 times.
✓ Branch 8 (217→218) taken 10 times.
10 std::cout << "testSubMessageParsing("<<i<<") : trigger_time_qns = " << triggerTimeQns << std::endl;
67
5/5
✓ Branch 0 (218→219) taken 10 times.
✓ Branch 2 (219→220) taken 10 times.
✓ Branch 4 (220→221) taken 10 times.
✓ Branch 6 (221→222) taken 10 times.
✓ Branch 8 (222→223) taken 10 times.
10 std::cout << "testSubMessageParsing("<<i<<") : trigger_type = " << triggerType << std::endl;
68
69
6/6
✓ Branch 0 (223→224) taken 10 times.
✓ Branch 2 (224→225) taken 10 times.
✓ Branch 4 (225→226) taken 10 times.
✓ Branch 6 (226→227) taken 10 times.
✓ Branch 8 (227→228) taken 10 times.
✓ Branch 10 (228→229) taken 10 times.
10 std::cout << "testSubMessageParsing("<<i<<") : nbValue = "<<nbPixelSliceGain<<", waveform = " << tabWaveform;
70
6/6
✓ Branch 0 (231→232) taken 10 times.
✓ Branch 2 (234→235) taken 10 times.
✓ Branch 4 (237→238) taken 10 times.
✓ Branch 6 (240→241) taken 10 times.
✓ Branch 8 (241→242) taken 10 times.
✓ Branch 10 (242→243) taken 10 times.
70 phoenix_assert(phoenix_check("Check nbPixelSliceGain", nbPixelSliceGain, 148400lu));
71
2/2
✓ Branch 0 (255→252) taken 100 times.
✓ Branch 1 (255→256) taken 10 times.
110 for(size_t j(0lu); j < 10lu; ++j){
72
2/2
✓ Branch 0 (252→253) taken 100 times.
✓ Branch 2 (253→254) taken 100 times.
100 std::cout << ", " << tabWaveform[j];
73 }
74
1/1
✓ Branch 0 (256→257) taken 10 times.
10 std::cout << std::endl;
75
76
4/4
✓ Branch 0 (259→260) taken 10 times.
✓ Branch 2 (262→263) taken 10 times.
✓ Branch 4 (265→266) taken 10 times.
✓ Branch 6 (266→267) taken 10 times.
60 phoenix_assert(triggerType == 1);
77 ++itCheckField3;
78 10 ++i;
79 }
80
1/1
✓ Branch 0 (287→288) taken 1 times.
1 parser.print();
81
2/2
✓ Branch 0 (289→290) taken 1 times.
✓ Branch 2 (290→291) taken 1 times.
1 std::cout << "testSubMessageParsing : Let's reset the offsets :" << std::endl;
82
1/1
✓ Branch 0 (291→292) taken 1 times.
1 parser.resetOffset();
83
1/1
✓ Branch 0 (293→294) taken 1 times.
1 parser.print();
84 1 }
85
86
87 1 int main(){
88
1/1
✓ Branch 0 (4→5) taken 1 times.
1 std::string fileName(STREAM_DATA_CUT);
89
1/1
✓ Branch 0 (6→7) taken 1 times.
1 testSubMessageParsing(fileName);
90 1 return 0;
91 1 }
92