1
2 #undef NDEBUG
3 #include <utility>
4
5 #include "benchmark/benchmark.h"
6 #include "output_test.h"
7
8 // ========================================================================= //
9 // ---------------------- Testing Prologue Output -------------------------- //
10 // ========================================================================= //
11
12 ADD_CASES(TC_ConsoleOut, {{"^Benchmark %s Time %s CPU %s Iterations$", MR_Next},
13 {"^[-]+$", MR_Next}});
14 ADD_CASES(TC_CSVOut,
15 {{"name,iterations,real_time,cpu_time,time_unit,bytes_per_second,"
16 "items_per_second,label,error_occurred,error_message"}});
17
18 // ========================================================================= //
19 // ------------------------ Testing Basic Output --------------------------- //
20 // ========================================================================= //
21
BM_basic(benchmark::State & state)22 void BM_basic(benchmark::State& state) {
23 while (state.KeepRunning()) {
24 }
25 }
26 BENCHMARK(BM_basic);
27
28 ADD_CASES(TC_ConsoleOut, {{"^BM_basic %console_report$"}});
29 ADD_CASES(TC_JSONOut, {{"\"name\": \"BM_basic\",$"},
30 {"\"iterations\": %int,$", MR_Next},
31 {"\"real_time\": %int,$", MR_Next},
32 {"\"cpu_time\": %int,$", MR_Next},
33 {"\"time_unit\": \"ns\"$", MR_Next},
34 {"}", MR_Next}});
35 ADD_CASES(TC_CSVOut, {{"^\"BM_basic\",%csv_report$"}});
36
37 // ========================================================================= //
38 // ------------------------ Testing Bytes per Second Output ---------------- //
39 // ========================================================================= //
40
BM_bytes_per_second(benchmark::State & state)41 void BM_bytes_per_second(benchmark::State& state) {
42 while (state.KeepRunning()) {
43 }
44 state.SetBytesProcessed(1);
45 }
46 BENCHMARK(BM_bytes_per_second);
47
48 ADD_CASES(TC_ConsoleOut,
49 {{"^BM_bytes_per_second %console_report +%floatB/s$"}});
50 ADD_CASES(TC_JSONOut, {{"\"name\": \"BM_bytes_per_second\",$"},
51 {"\"iterations\": %int,$", MR_Next},
52 {"\"real_time\": %int,$", MR_Next},
53 {"\"cpu_time\": %int,$", MR_Next},
54 {"\"time_unit\": \"ns\",$", MR_Next},
55 {"\"bytes_per_second\": %int$", MR_Next},
56 {"}", MR_Next}});
57 ADD_CASES(TC_CSVOut, {{"^\"BM_bytes_per_second\",%csv_bytes_report$"}});
58
59 // ========================================================================= //
60 // ------------------------ Testing Items per Second Output ---------------- //
61 // ========================================================================= //
62
BM_items_per_second(benchmark::State & state)63 void BM_items_per_second(benchmark::State& state) {
64 while (state.KeepRunning()) {
65 }
66 state.SetItemsProcessed(1);
67 }
68 BENCHMARK(BM_items_per_second);
69
70 ADD_CASES(TC_ConsoleOut,
71 {{"^BM_items_per_second %console_report +%float items/s$"}});
72 ADD_CASES(TC_JSONOut, {{"\"name\": \"BM_items_per_second\",$"},
73 {"\"iterations\": %int,$", MR_Next},
74 {"\"real_time\": %int,$", MR_Next},
75 {"\"cpu_time\": %int,$", MR_Next},
76 {"\"time_unit\": \"ns\",$", MR_Next},
77 {"\"items_per_second\": %int$", MR_Next},
78 {"}", MR_Next}});
79 ADD_CASES(TC_CSVOut, {{"^\"BM_items_per_second\",%csv_items_report$"}});
80
81 // ========================================================================= //
82 // ------------------------ Testing Label Output --------------------------- //
83 // ========================================================================= //
84
BM_label(benchmark::State & state)85 void BM_label(benchmark::State& state) {
86 while (state.KeepRunning()) {
87 }
88 state.SetLabel("some label");
89 }
90 BENCHMARK(BM_label);
91
92 ADD_CASES(TC_ConsoleOut, {{"^BM_label %console_report some label$"}});
93 ADD_CASES(TC_JSONOut, {{"\"name\": \"BM_label\",$"},
94 {"\"iterations\": %int,$", MR_Next},
95 {"\"real_time\": %int,$", MR_Next},
96 {"\"cpu_time\": %int,$", MR_Next},
97 {"\"time_unit\": \"ns\",$", MR_Next},
98 {"\"label\": \"some label\"$", MR_Next},
99 {"}", MR_Next}});
100 ADD_CASES(TC_CSVOut, {{"^\"BM_label\",%csv_label_report_begin\"some "
101 "label\"%csv_label_report_end$"}});
102
103 // ========================================================================= //
104 // ------------------------ Testing Error Output --------------------------- //
105 // ========================================================================= //
106
BM_error(benchmark::State & state)107 void BM_error(benchmark::State& state) {
108 state.SkipWithError("message");
109 while (state.KeepRunning()) {
110 }
111 }
112 BENCHMARK(BM_error);
113 ADD_CASES(TC_ConsoleOut, {{"^BM_error[ ]+ERROR OCCURRED: 'message'$"}});
114 ADD_CASES(TC_JSONOut, {{"\"name\": \"BM_error\",$"},
115 {"\"error_occurred\": true,$", MR_Next},
116 {"\"error_message\": \"message\",$", MR_Next}});
117
118 ADD_CASES(TC_CSVOut, {{"^\"BM_error\",,,,,,,,true,\"message\"$"}});
119
120 // ========================================================================= //
121 // ------------------------ Testing No Arg Name Output -----------------------
122 // //
123 // ========================================================================= //
124
BM_no_arg_name(benchmark::State & state)125 void BM_no_arg_name(benchmark::State& state) {
126 while (state.KeepRunning()) {
127 }
128 }
129 BENCHMARK(BM_no_arg_name)->Arg(3);
130 ADD_CASES(TC_ConsoleOut, {{"^BM_no_arg_name/3 %console_report$"}});
131 ADD_CASES(TC_JSONOut, {{"\"name\": \"BM_no_arg_name/3\",$"}});
132 ADD_CASES(TC_CSVOut, {{"^\"BM_no_arg_name/3\",%csv_report$"}});
133
134 // ========================================================================= //
135 // ------------------------ Testing Arg Name Output ----------------------- //
136 // ========================================================================= //
137
BM_arg_name(benchmark::State & state)138 void BM_arg_name(benchmark::State& state) {
139 while (state.KeepRunning()) {
140 }
141 }
142 BENCHMARK(BM_arg_name)->ArgName("first")->Arg(3);
143 ADD_CASES(TC_ConsoleOut, {{"^BM_arg_name/first:3 %console_report$"}});
144 ADD_CASES(TC_JSONOut, {{"\"name\": \"BM_arg_name/first:3\",$"}});
145 ADD_CASES(TC_CSVOut, {{"^\"BM_arg_name/first:3\",%csv_report$"}});
146
147 // ========================================================================= //
148 // ------------------------ Testing Arg Names Output ----------------------- //
149 // ========================================================================= //
150
BM_arg_names(benchmark::State & state)151 void BM_arg_names(benchmark::State& state) {
152 while (state.KeepRunning()) {
153 }
154 }
155 BENCHMARK(BM_arg_names)->Args({2, 5, 4})->ArgNames({"first", "", "third"});
156 ADD_CASES(TC_ConsoleOut,
157 {{"^BM_arg_names/first:2/5/third:4 %console_report$"}});
158 ADD_CASES(TC_JSONOut, {{"\"name\": \"BM_arg_names/first:2/5/third:4\",$"}});
159 ADD_CASES(TC_CSVOut, {{"^\"BM_arg_names/first:2/5/third:4\",%csv_report$"}});
160
161 // ========================================================================= //
162 // ----------------------- Testing Complexity Output ----------------------- //
163 // ========================================================================= //
164
BM_Complexity_O1(benchmark::State & state)165 void BM_Complexity_O1(benchmark::State& state) {
166 while (state.KeepRunning()) {
167 }
168 state.SetComplexityN(state.range(0));
169 }
170 BENCHMARK(BM_Complexity_O1)->Range(1, 1 << 18)->Complexity(benchmark::o1);
171 SET_SUBSTITUTIONS({{"%bigOStr", "[ ]* %float \\([0-9]+\\)"},
172 {"%RMS", "[ ]*[0-9]+ %"}});
173 ADD_CASES(TC_ConsoleOut, {{"^BM_Complexity_O1_BigO %bigOStr %bigOStr[ ]*$"},
174 {"^BM_Complexity_O1_RMS %RMS %RMS[ ]*$"}});
175
176 // ========================================================================= //
177 // ----------------------- Testing Aggregate Output ------------------------ //
178 // ========================================================================= //
179
180 // Test that non-aggregate data is printed by default
BM_Repeat(benchmark::State & state)181 void BM_Repeat(benchmark::State& state) {
182 while (state.KeepRunning()) {
183 }
184 }
185 BENCHMARK(BM_Repeat)->Repetitions(3);
186 ADD_CASES(TC_ConsoleOut, {{"^BM_Repeat/repeats:3 %console_report$"},
187 {"^BM_Repeat/repeats:3 %console_report$"},
188 {"^BM_Repeat/repeats:3 %console_report$"},
189 {"^BM_Repeat/repeats:3_mean %console_report$"},
190 {"^BM_Repeat/repeats:3_stddev %console_report$"}});
191 ADD_CASES(TC_JSONOut, {{"\"name\": \"BM_Repeat/repeats:3\",$"},
192 {"\"name\": \"BM_Repeat/repeats:3\",$"},
193 {"\"name\": \"BM_Repeat/repeats:3\",$"},
194 {"\"name\": \"BM_Repeat/repeats:3_mean\",$"},
195 {"\"name\": \"BM_Repeat/repeats:3_stddev\",$"}});
196 ADD_CASES(TC_CSVOut, {{"^\"BM_Repeat/repeats:3\",%csv_report$"},
197 {"^\"BM_Repeat/repeats:3\",%csv_report$"},
198 {"^\"BM_Repeat/repeats:3\",%csv_report$"},
199 {"^\"BM_Repeat/repeats:3_mean\",%csv_report$"},
200 {"^\"BM_Repeat/repeats:3_stddev\",%csv_report$"}});
201
202 // Test that a non-repeated test still prints non-aggregate results even when
203 // only-aggregate reports have been requested
BM_RepeatOnce(benchmark::State & state)204 void BM_RepeatOnce(benchmark::State& state) {
205 while (state.KeepRunning()) {
206 }
207 }
208 BENCHMARK(BM_RepeatOnce)->Repetitions(1)->ReportAggregatesOnly();
209 ADD_CASES(TC_ConsoleOut, {{"^BM_RepeatOnce/repeats:1 %console_report$"}});
210 ADD_CASES(TC_JSONOut, {{"\"name\": \"BM_RepeatOnce/repeats:1\",$"}});
211 ADD_CASES(TC_CSVOut, {{"^\"BM_RepeatOnce/repeats:1\",%csv_report$"}});
212
213 // Test that non-aggregate data is not reported
BM_SummaryRepeat(benchmark::State & state)214 void BM_SummaryRepeat(benchmark::State& state) {
215 while (state.KeepRunning()) {
216 }
217 }
218 BENCHMARK(BM_SummaryRepeat)->Repetitions(3)->ReportAggregatesOnly();
219 ADD_CASES(TC_ConsoleOut,
220 {{".*BM_SummaryRepeat/repeats:3 ", MR_Not},
221 {"^BM_SummaryRepeat/repeats:3_mean %console_report$"},
222 {"^BM_SummaryRepeat/repeats:3_stddev %console_report$"}});
223 ADD_CASES(TC_JSONOut, {{".*BM_SummaryRepeat/repeats:3 ", MR_Not},
224 {"\"name\": \"BM_SummaryRepeat/repeats:3_mean\",$"},
225 {"\"name\": \"BM_SummaryRepeat/repeats:3_stddev\",$"}});
226 ADD_CASES(TC_CSVOut, {{".*BM_SummaryRepeat/repeats:3 ", MR_Not},
227 {"^\"BM_SummaryRepeat/repeats:3_mean\",%csv_report$"},
228 {"^\"BM_SummaryRepeat/repeats:3_stddev\",%csv_report$"}});
229
BM_RepeatTimeUnit(benchmark::State & state)230 void BM_RepeatTimeUnit(benchmark::State& state) {
231 while (state.KeepRunning()) {
232 }
233 }
234 BENCHMARK(BM_RepeatTimeUnit)
235 ->Repetitions(3)
236 ->ReportAggregatesOnly()
237 ->Unit(benchmark::kMicrosecond);
238 ADD_CASES(TC_ConsoleOut,
239 {{".*BM_RepeatTimeUnit/repeats:3 ", MR_Not},
240 {"^BM_RepeatTimeUnit/repeats:3_mean %console_us_report$"},
241 {"^BM_RepeatTimeUnit/repeats:3_stddev %console_us_report$"}});
242 ADD_CASES(TC_JSONOut, {{".*BM_RepeatTimeUnit/repeats:3 ", MR_Not},
243 {"\"name\": \"BM_RepeatTimeUnit/repeats:3_mean\",$"},
244 {"\"time_unit\": \"us\",?$"},
245 {"\"name\": \"BM_RepeatTimeUnit/repeats:3_stddev\",$"},
246 {"\"time_unit\": \"us\",?$"}});
247 ADD_CASES(TC_CSVOut,
248 {{".*BM_RepeatTimeUnit/repeats:3 ", MR_Not},
249 {"^\"BM_RepeatTimeUnit/repeats:3_mean\",%csv_us_report$"},
250 {"^\"BM_RepeatTimeUnit/repeats:3_stddev\",%csv_us_report$"}});
251
252 // ========================================================================= //
253 // --------------------------- TEST CASES END ------------------------------ //
254 // ========================================================================= //
255
main(int argc,char * argv[])256 int main(int argc, char* argv[]) { RunOutputTests(argc, argv); }
257