GCC Code Coverage Report


Directory: ./
File: src/iguana/tests/include/TestBanklist.h
Date: 2025-11-25 17:57:04
Coverage Exec Excl Total
Lines: 95.5% 42 0 44
Functions: 100.0% 1 0 1
Branches: 51.8% 87 0 168

Line Branch Exec Source
1 // test banklist behavior
2
3 #include <cassert>
4 #include <hipo4/reader.h>
5 #include <iguana/algorithms/AlgorithmSequence.h>
6
7 1 inline int TestBanklist(
8 std::string data_file,
9 bool verbose)
10 {
11
12
1/2
✗ Branch 2 → 3 not taken.
✓ Branch 2 → 5 taken 1 time.
1 if(data_file == "") {
13 fmt::print(stderr, "ERROR: need a data file for command 'banklist'\n");
14 return 1;
15 }
16
17 // set the concurrency model to single-threaded, for optimal performance
18
1/2
✓ Branch 6 → 7 taken 1 time.
✗ Branch 6 → 197 not taken.
1 iguana::GlobalConcurrencyModel = "single";
19
20 // input bank names
21 std::vector<std::string> input_bank_names = {
22 "REC::Particle",
23 "RUN::config",
24 "REC::Track",
25 "REC::Calorimeter",
26 "REC::Scintillator",
27
1/2
✓ Branch 13 → 14 taken 1 time.
✗ Branch 13 → 303 not taken.
1 };
28
29 // open the HIPO file
30
1/2
✓ Branch 13 → 14 taken 1 time.
✗ Branch 13 → 303 not taken.
1 hipo::reader reader(data_file.c_str());
31
2/4
✓ Branch 14 → 15 taken 1 time.
✗ Branch 14 → 301 not taken.
✓ Branch 15 → 16 taken 1 time.
✗ Branch 15 → 203 not taken.
1 auto banks = reader.getBanks(input_bank_names);
32
33 // define the algorithm sequence
34 std::vector<std::string> algo_names = {
35 "creator_1a",
36 "creator_2",
37 "creator_1b",
38
1/2
✓ Branch 17 → 18 taken 1 time.
✗ Branch 17 → 299 not taken.
1 };
39
1/2
✓ Branch 18 → 19 taken 1 time.
✗ Branch 18 → 297 not taken.
1 iguana::AlgorithmSequence seq;
40
4/10
✓ Branch 19 → 20 taken 1 time.
✗ Branch 19 → 295 not taken.
✓ Branch 20 → 21 taken 1 time.
✗ Branch 20 → 211 not taken.
✓ Branch 21 → 22 taken 1 time.
✗ Branch 21 → 205 not taken.
✓ Branch 27 → 28 taken 1 time.
✗ Branch 27 → 30 not taken.
✗ Branch 211 → 212 not taken.
✗ Branch 211 → 214 not taken.
2 seq.Add("clas12::SectorFinder", "creator_1a");
41
4/10
✓ Branch 32 → 33 taken 1 time.
✗ Branch 32 → 295 not taken.
✓ Branch 33 → 34 taken 1 time.
✗ Branch 33 → 223 not taken.
✓ Branch 34 → 35 taken 1 time.
✗ Branch 34 → 217 not taken.
✓ Branch 40 → 41 taken 1 time.
✗ Branch 40 → 43 not taken.
✗ Branch 223 → 224 not taken.
✗ Branch 223 → 226 not taken.
2 seq.Add("clas12::CalorimeterLinker", "creator_2");
42
4/10
✓ Branch 45 → 46 taken 1 time.
✗ Branch 45 → 295 not taken.
✓ Branch 46 → 47 taken 1 time.
✗ Branch 46 → 235 not taken.
✓ Branch 47 → 48 taken 1 time.
✗ Branch 47 → 229 not taken.
✓ Branch 53 → 54 taken 1 time.
✗ Branch 53 → 56 not taken.
✗ Branch 235 → 236 not taken.
✗ Branch 235 → 238 not taken.
2 seq.Add("clas12::SectorFinder", "creator_1b");
43
44 // print the sequence
45
1/2
✓ Branch 58 → 59 taken 1 time.
✗ Branch 58 → 295 not taken.
1 seq.PrintSequence();
46
47 // start the sequence
48
1/2
✓ Branch 59 → 60 taken 1 time.
✗ Branch 59 → 295 not taken.
1 seq.Start(banks);
49
50 // print the banklist
51
1/2
✓ Branch 60 → 61 taken 1 time.
✗ Branch 60 → 295 not taken.
1 fmt::println("BANKLIST:");
52
2/2
✓ Branch 76 → 62 taken 8 times.
✓ Branch 76 → 77 taken 1 time.
10 for(decltype(banks)::size_type i = 0; i < banks.size(); i++) {
53
1/2
✓ Branch 62 → 63 taken 8 times.
✗ Branch 62 → 295 not taken.
8 auto& bank = banks.at(i);
54
3/6
✓ Branch 67 → 68 taken 8 times.
✗ Branch 67 → 241 not taken.
✓ Branch 68 → 69 taken 3 times.
✓ Branch 68 → 71 taken 5 times.
✗ Branch 241 → 242 not taken.
✗ Branch 241 → 244 not taken.
16 fmt::println(" - {}: {}", i, bank.getSchema().getName());
55 }
56
57 // assert variants
58
4/8
✓ Branch 77 → 78 taken 1 time.
✗ Branch 77 → 295 not taken.
✓ Branch 78 → 79 taken 1 time.
✗ Branch 78 → 247 not taken.
✓ Branch 79 → 80 taken 1 time.
✗ Branch 79 → 247 not taken.
✗ Branch 80 → 81 not taken.
✓ Branch 80 → 82 taken 1 time.
1 assert((seq.Get("creator_1a")->GetCreatedBankVariant() == 0));
59
4/8
✓ Branch 87 → 88 taken 1 time.
✗ Branch 87 → 295 not taken.
✓ Branch 88 → 89 taken 1 time.
✗ Branch 88 → 253 not taken.
✓ Branch 89 → 90 taken 1 time.
✗ Branch 89 → 253 not taken.
✗ Branch 90 → 91 not taken.
✓ Branch 90 → 92 taken 1 time.
1 assert((seq.Get("creator_1b")->GetCreatedBankVariant() == 1));
60
4/8
✓ Branch 97 → 98 taken 1 time.
✗ Branch 97 → 295 not taken.
✓ Branch 98 → 99 taken 1 time.
✗ Branch 98 → 259 not taken.
✓ Branch 99 → 100 taken 1 time.
✗ Branch 99 → 259 not taken.
✗ Branch 100 → 101 not taken.
✓ Branch 100 → 102 taken 1 time.
1 assert((seq.Get("creator_2")->GetCreatedBankVariant() == 0));
61
62 // assert return values of `iguana::tools::GetBankIndex`
63 //// input banks
64
2/2
✓ Branch 115 → 108 taken 5 times.
✓ Branch 115 → 129 taken 1 time.
12 for(decltype(input_bank_names)::size_type i = 0; i < input_bank_names.size(); i++) {
65
1/2
✓ Branch 108 → 109 taken 5 times.
✗ Branch 108 → 295 not taken.
5 auto const& bank_name = input_bank_names.at(i);
66
1/2
✓ Branch 109 → 110 taken 5 times.
✗ Branch 109 → 295 not taken.
5 auto const idx = iguana::tools::GetBankIndex(banks, bank_name);
67
1/2
✗ Branch 110 → 111 not taken.
✓ Branch 110 → 112 taken 5 times.
5 assert((idx == i));
68 }
69 //// output banks
70
2/2
✓ Branch 131 → 116 taken 3 times.
✓ Branch 131 → 171 taken 1 time.
7 for(decltype(algo_names)::size_type i = 0; i < algo_names.size(); i++) {
71
1/2
✓ Branch 116 → 117 taken 3 times.
✗ Branch 116 → 295 not taken.
3 auto const& algo_name = algo_names.at(i);
72
4/8
✓ Branch 117 → 118 taken 3 times.
✗ Branch 117 → 295 not taken.
✓ Branch 118 → 119 taken 3 times.
✗ Branch 118 → 295 not taken.
✓ Branch 119 → 120 taken 3 times.
✗ Branch 119 → 295 not taken.
✓ Branch 120 → 121 taken 3 times.
✗ Branch 120 → 265 not taken.
3 auto const idx = iguana::tools::GetBankIndex(banks, seq.GetCreatedBankName(algo_name), seq.Get(algo_name)->GetCreatedBankVariant());
73
1/2
✗ Branch 126 → 127 not taken.
✓ Branch 126 → 128 taken 3 times.
3 assert((idx == input_bank_names.size() + i));
74 }
75
76 // assert equivalence to `Algorithm::GetBankIndex` and `AlgorithmSequence::GetBankIndex`
77
2/2
✓ Branch 171 → 141 taken 3 times.
✓ Branch 171 → 189 taken 1 time.
4 for(auto const& algo_name : algo_names) {
78 //// input banks
79
2/2
✓ Branch 141 → 132 taken 15 times.
✓ Branch 141 → 142 taken 3 times.
18 for(auto const& bank_name : input_bank_names) {
80
1/2
✓ Branch 132 → 133 taken 15 times.
✗ Branch 132 → 295 not taken.
15 auto const idx = iguana::tools::GetBankIndex(banks, bank_name);
81
3/6
✓ Branch 133 → 134 taken 15 times.
✗ Branch 133 → 295 not taken.
✓ Branch 134 → 135 taken 15 times.
✗ Branch 134 → 295 not taken.
✗ Branch 135 → 136 not taken.
✓ Branch 135 → 137 taken 15 times.
15 assert((idx == seq.Get(algo_name)->GetBankIndex(banks, bank_name)));
82
2/4
✓ Branch 137 → 138 taken 15 times.
✗ Branch 137 → 295 not taken.
✗ Branch 138 → 139 not taken.
✓ Branch 138 → 140 taken 15 times.
15 assert((idx == seq.GetBankIndex(banks, bank_name, algo_name)));
83 }
84 //// output banks
85
4/8
✓ Branch 142 → 143 taken 3 times.
✗ Branch 142 → 295 not taken.
✓ Branch 143 → 144 taken 3 times.
✗ Branch 143 → 295 not taken.
✓ Branch 144 → 145 taken 3 times.
✗ Branch 144 → 295 not taken.
✓ Branch 145 → 146 taken 3 times.
✗ Branch 145 → 271 not taken.
3 auto const idx = iguana::tools::GetBankIndex(banks, seq.GetCreatedBankName(algo_name), seq.Get(algo_name)->GetCreatedBankVariant());
86
4/8
✓ Branch 151 → 152 taken 3 times.
✗ Branch 151 → 295 not taken.
✓ Branch 152 → 153 taken 3 times.
✗ Branch 152 → 295 not taken.
✓ Branch 153 → 154 taken 3 times.
✗ Branch 153 → 277 not taken.
✗ Branch 154 → 155 not taken.
✓ Branch 154 → 156 taken 3 times.
3 assert((idx == seq.Get(algo_name)->GetBankIndex(banks, seq.GetCreatedBankName(algo_name))));
87
3/6
✓ Branch 161 → 162 taken 3 times.
✗ Branch 161 → 295 not taken.
✓ Branch 162 → 163 taken 3 times.
✗ Branch 162 → 283 not taken.
✗ Branch 163 → 164 not taken.
✓ Branch 163 → 165 taken 3 times.
6 assert((idx == seq.GetBankIndex(banks, seq.GetCreatedBankName(algo_name), algo_name)));
88 }
89
90 // assert equivalence to `Algorithm::GetCreatedBankIndex` and `AlgorithmSequence::GetCreatedBankIndex`
91
2/2
✓ Branch 189 → 172 taken 3 times.
✓ Branch 189 → 190 taken 1 time.
4 for(auto const& algo_name : algo_names) {
92
4/8
✓ Branch 172 → 173 taken 3 times.
✗ Branch 172 → 295 not taken.
✓ Branch 173 → 174 taken 3 times.
✗ Branch 173 → 295 not taken.
✓ Branch 174 → 175 taken 3 times.
✗ Branch 174 → 295 not taken.
✓ Branch 175 → 176 taken 3 times.
✗ Branch 175 → 289 not taken.
3 auto const idx = iguana::tools::GetBankIndex(banks, seq.GetCreatedBankName(algo_name), seq.Get(algo_name)->GetCreatedBankVariant());
93
3/6
✓ Branch 181 → 182 taken 3 times.
✗ Branch 181 → 295 not taken.
✓ Branch 182 → 183 taken 3 times.
✗ Branch 182 → 295 not taken.
✗ Branch 183 → 184 not taken.
✓ Branch 183 → 185 taken 3 times.
3 assert((idx == seq.Get(algo_name)->GetCreatedBankIndex(banks)));
94
2/4
✓ Branch 185 → 186 taken 3 times.
✗ Branch 185 → 295 not taken.
✗ Branch 186 → 187 not taken.
✓ Branch 186 → 188 taken 3 times.
3 assert((idx == seq.GetCreatedBankIndex(banks, algo_name)));
95 }
96
97 // stop the algorithm
98
1/2
✓ Branch 190 → 191 taken 1 time.
✗ Branch 190 → 295 not taken.
1 seq.Stop();
99 return 0;
100 1 }
101