| 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 |
3/3✓ Branch 0 (21→22) taken 1 times.
✓ Branch 2 (22→23) taken 1 times.
✓ Branch 4 (23→24) taken 1 times.
|
1 | parser.addParseFieldEnum(&field1, phoenix_createField(FieldType::ENUM_TYPE, 1lu, "Field 1")); |
| 27 |
3/3✓ Branch 0 (26→27) taken 1 times.
✓ Branch 2 (27→28) taken 1 times.
✓ Branch 4 (28→29) taken 1 times.
|
1 | parser.addParseFieldValue(&field3, phoenix_createField(FieldType::UINT32, 3lu, "Field 3")); |
| 28 | |||
| 29 |
3/3✓ Branch 0 (31→32) taken 1 times.
✓ Branch 2 (32→33) taken 1 times.
✓ Branch 4 (33→34) taken 1 times.
|
1 | FieldParser* eventParser = parser.addSubMessage(phoenix_createField(FieldType::SUBMESSAGE, 4lu, "Event")); |
| 30 |
3/3✓ Branch 0 (36→37) taken 1 times.
✓ Branch 2 (37→38) taken 1 times.
✓ Branch 4 (38→39) taken 1 times.
|
1 | eventParser->addParseFieldValue(&configurationId, phoenix_createField(FieldType::UINT64, 1lu, "configuration_id")); |
| 31 |
3/3✓ Branch 0 (41→42) taken 1 times.
✓ Branch 2 (42→43) taken 1 times.
✓ Branch 4 (43→44) taken 1 times.
|
1 | eventParser->addParseFieldValue(&eventId, phoenix_createField(FieldType::UINT64, 2lu, "event_id")); |
| 32 |
3/3✓ Branch 0 (46→47) taken 1 times.
✓ Branch 2 (47→48) taken 1 times.
✓ Branch 4 (48→49) taken 1 times.
|
1 | eventParser->addParseFieldValue(&telEventId, phoenix_createField(FieldType::UINT64, 3lu, "tel_event_id")); |
| 33 |
3/3✓ Branch 0 (51→52) taken 1 times.
✓ Branch 2 (52→53) taken 1 times.
✓ Branch 4 (53→54) taken 1 times.
|
1 | eventParser->addParseFieldValue(&triggerTimeS, phoenix_createField(FieldType::UINT32, 4lu, "trigger_time_s")); |
| 34 |
3/3✓ Branch 0 (56→57) taken 1 times.
✓ Branch 2 (57→58) taken 1 times.
✓ Branch 4 (58→59) taken 1 times.
|
1 | eventParser->addParseFieldValue(&triggerTimeQns, phoenix_createField(FieldType::UINT32, 5lu, "trigger_time_qns")); |
| 35 |
3/3✓ Branch 0 (61→62) taken 1 times.
✓ Branch 2 (62→63) taken 1 times.
✓ Branch 4 (63→64) taken 1 times.
|
1 | eventParser->addParseFieldValue(&triggerType, phoenix_createField(FieldType::UINT32, 6lu, "trigger_type")); |
| 36 | |||
| 37 | 1 | unsigned short* tabWaveform = NULL; | |
| 38 | 1 | size_t nbPixelSliceGain(0lu); | |
| 39 |
3/3✓ Branch 0 (66→67) taken 1 times.
✓ Branch 2 (67→68) taken 1 times.
✓ Branch 4 (68→69) taken 1 times.
|
1 | FieldParser * waveformParser = eventParser->addSubMessage(phoenix_createField(FieldType::SUBMESSAGE, 7lu, "waveform")); |
| 40 |
4/4✓ Branch 0 (71→72) taken 1 times.
✓ Branch 2 (72→73) taken 1 times.
✓ Branch 4 (73→74) taken 1 times.
✓ Branch 6 (76→77) taken 1 times.
|
1 | waveformParser->addParseFieldArray(&tabWaveform, &nbPixelSliceGain, phoenix_createField(FieldType::UINT16, 4lu, "data", true)); |
| 41 | |||
| 42 |
1/1✓ Branch 0 (77→78) taken 1 times.
|
1 | parser.print(); |
| 43 | |||
| 44 | //Expected values of field 3 | ||
| 45 |
1/1✓ Branch 0 (81→82) 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 (307→85) taken 10 times.
✓ Branch 1 (307→308) taken 1 times.
|
22 | for(VecMessage::iterator it(vecInMessage.begin()); it != vecInMessage.end(); ++it){ |
| 50 |
5/5✓ Branch 0 (87→88) taken 10 times.
✓ Branch 2 (90→91) taken 10 times.
✓ Branch 4 (93→94) taken 10 times.
✓ Branch 6 (96→97) taken 10 times.
✓ Branch 8 (97→98) taken 10 times.
|
60 | phoenix_assert(parser.load(*it)); |
| 51 |
3/3✓ Branch 0 (104→105) taken 10 times.
✓ Branch 2 (105→106) taken 10 times.
✓ Branch 4 (106→107) taken 10 times.
|
10 | std::cout << "Parse Event " << i << std::endl; |
| 52 |
5/5✓ Branch 0 (107→108) taken 10 times.
✓ Branch 2 (108→109) taken 10 times.
✓ Branch 4 (109→110) taken 10 times.
✓ Branch 6 (110→111) taken 10 times.
✓ Branch 8 (111→112) taken 10 times.
|
10 | std::cout << "testSubMessageParsing("<<i<<") : field 1 = " << field1 << std::endl; |
| 53 |
4/4✓ Branch 0 (114→115) taken 10 times.
✓ Branch 2 (117→118) taken 10 times.
✓ Branch 4 (120→121) taken 10 times.
✓ Branch 6 (121→122) taken 10 times.
|
50 | phoenix_assert(field1 == 16lu); |
| 54 |
5/5✓ Branch 0 (128→129) taken 10 times.
✓ Branch 2 (129→130) taken 10 times.
✓ Branch 4 (130→131) taken 10 times.
✓ Branch 6 (131→132) taken 10 times.
✓ Branch 8 (132→133) taken 10 times.
|
10 | std::cout << "testSubMessageParsing("<<i<<") : field 3 = " << field3 << std::endl; |
| 55 |
4/4✓ Branch 0 (135→136) taken 10 times.
✓ Branch 2 (138→139) taken 10 times.
✓ Branch 4 (141→142) taken 10 times.
✓ Branch 6 (144→145) taken 10 times.
|
60 | phoenix_assert(*itCheckField3 == field3); |
| 56 | |||
| 57 |
5/5✓ Branch 0 (151→152) taken 10 times.
✓ Branch 2 (152→153) taken 10 times.
✓ Branch 4 (153→154) taken 10 times.
✓ Branch 6 (154→155) taken 10 times.
✓ Branch 8 (155→156) taken 10 times.
|
10 | std::cout << "testSubMessageParsing("<<i<<") : configuration_id = " << configurationId << std::endl; |
| 58 |
4/4✓ Branch 0 (158→159) taken 10 times.
✓ Branch 2 (161→162) taken 10 times.
✓ Branch 4 (164→165) taken 10 times.
✓ Branch 6 (165→166) taken 10 times.
|
50 | phoenix_assert(configurationId == 0); |
| 59 | 10 | size_t expectedEventId = 2417265 + 4lu*i; | |
| 60 |
5/5✓ Branch 0 (172→173) taken 10 times.
✓ Branch 2 (173→174) taken 10 times.
✓ Branch 4 (174→175) taken 10 times.
✓ Branch 6 (175→176) taken 10 times.
✓ Branch 8 (176→177) taken 10 times.
|
10 | std::cout << "testSubMessageParsing("<<i<<") : event_id = " << eventId << std::endl; |
| 61 |
4/4✓ Branch 0 (179→180) taken 10 times.
✓ Branch 2 (182→183) taken 10 times.
✓ Branch 4 (185→186) taken 10 times.
✓ Branch 6 (186→187) taken 10 times.
|
50 | phoenix_assert(eventId == expectedEventId); |
| 62 |
5/5✓ Branch 0 (193→194) taken 10 times.
✓ Branch 2 (194→195) taken 10 times.
✓ Branch 4 (195→196) taken 10 times.
✓ Branch 6 (196→197) taken 10 times.
✓ Branch 8 (197→198) taken 10 times.
|
10 | std::cout << "testSubMessageParsing("<<i<<") : tel_event_id = " << telEventId << std::endl; |
| 63 |
4/4✓ Branch 0 (200→201) taken 10 times.
✓ Branch 2 (203→204) taken 10 times.
✓ Branch 4 (206→207) taken 10 times.
✓ Branch 6 (207→208) taken 10 times.
|
50 | phoenix_assert(eventId == telEventId); |
| 64 |
5/5✓ Branch 0 (214→215) taken 10 times.
✓ Branch 2 (215→216) taken 10 times.
✓ Branch 4 (216→217) taken 10 times.
✓ Branch 6 (217→218) taken 10 times.
✓ Branch 8 (218→219) taken 10 times.
|
10 | std::cout << "testSubMessageParsing("<<i<<") : trigger_time_s = " << triggerTimeS << std::endl; |
| 65 |
4/4✓ Branch 0 (221→222) taken 10 times.
✓ Branch 2 (224→225) taken 10 times.
✓ Branch 4 (227→228) taken 10 times.
✓ Branch 6 (228→229) taken 10 times.
|
50 | phoenix_assert(triggerTimeS == 1625787312u); |
| 66 |
5/5✓ Branch 0 (235→236) taken 10 times.
✓ Branch 2 (236→237) taken 10 times.
✓ Branch 4 (237→238) taken 10 times.
✓ Branch 6 (238→239) taken 10 times.
✓ Branch 8 (239→240) taken 10 times.
|
10 | std::cout << "testSubMessageParsing("<<i<<") : trigger_time_qns = " << triggerTimeQns << std::endl; |
| 67 |
5/5✓ Branch 0 (240→241) taken 10 times.
✓ Branch 2 (241→242) taken 10 times.
✓ Branch 4 (242→243) taken 10 times.
✓ Branch 6 (243→244) taken 10 times.
✓ Branch 8 (244→245) taken 10 times.
|
10 | std::cout << "testSubMessageParsing("<<i<<") : trigger_type = " << triggerType << std::endl; |
| 68 | |||
| 69 |
6/6✓ Branch 0 (245→246) taken 10 times.
✓ Branch 2 (246→247) taken 10 times.
✓ Branch 4 (247→248) taken 10 times.
✓ Branch 6 (248→249) taken 10 times.
✓ Branch 8 (249→250) taken 10 times.
✓ Branch 10 (250→251) taken 10 times.
|
10 | std::cout << "testSubMessageParsing("<<i<<") : nbValue = "<<nbPixelSliceGain<<", waveform = " << tabWaveform; |
| 70 |
6/6✓ Branch 0 (253→254) taken 10 times.
✓ Branch 2 (256→257) taken 10 times.
✓ Branch 4 (259→260) taken 10 times.
✓ Branch 6 (262→263) taken 10 times.
✓ Branch 8 (263→264) taken 10 times.
✓ Branch 10 (264→265) taken 10 times.
|
70 | phoenix_assert(phoenix_check("Check nbPixelSliceGain", nbPixelSliceGain, 148400lu)); |
| 71 |
2/2✓ Branch 0 (277→274) taken 100 times.
✓ Branch 1 (277→278) taken 10 times.
|
110 | for(size_t j(0lu); j < 10lu; ++j){ |
| 72 |
2/2✓ Branch 0 (274→275) taken 100 times.
✓ Branch 2 (275→276) taken 100 times.
|
100 | std::cout << ", " << tabWaveform[j]; |
| 73 | } | ||
| 74 |
1/1✓ Branch 0 (278→279) taken 10 times.
|
10 | std::cout << std::endl; |
| 75 | |||
| 76 |
4/4✓ Branch 0 (281→282) taken 10 times.
✓ Branch 2 (284→285) taken 10 times.
✓ Branch 4 (287→288) taken 10 times.
✓ Branch 6 (288→289) taken 10 times.
|
60 | phoenix_assert(triggerType == 1); |
| 77 | ++itCheckField3; | ||
| 78 | 10 | ++i; | |
| 79 | } | ||
| 80 |
1/1✓ Branch 0 (309→310) taken 1 times.
|
1 | parser.print(); |
| 81 |
2/2✓ Branch 0 (311→312) taken 1 times.
✓ Branch 2 (312→313) taken 1 times.
|
1 | std::cout << "testSubMessageParsing : Let's reset the offsets :" << std::endl; |
| 82 |
1/1✓ Branch 0 (313→314) taken 1 times.
|
1 | parser.resetOffset(); |
| 83 |
1/1✓ Branch 0 (315→316) 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 |