| 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 |