1*dbb99499SAndroid Build Coastguard Worker #include <memory>
2*dbb99499SAndroid Build Coastguard Worker
3*dbb99499SAndroid Build Coastguard Worker #include "../src/check.h"
4*dbb99499SAndroid Build Coastguard Worker #include "benchmark/benchmark.h"
5*dbb99499SAndroid Build Coastguard Worker #include "output_test.h"
6*dbb99499SAndroid Build Coastguard Worker
7*dbb99499SAndroid Build Coastguard Worker class TestMemoryManager : public benchmark::MemoryManager {
Start()8*dbb99499SAndroid Build Coastguard Worker void Start() override {}
Stop(Result & result)9*dbb99499SAndroid Build Coastguard Worker void Stop(Result& result) override {
10*dbb99499SAndroid Build Coastguard Worker result.num_allocs = 42;
11*dbb99499SAndroid Build Coastguard Worker result.max_bytes_used = 42000;
12*dbb99499SAndroid Build Coastguard Worker }
13*dbb99499SAndroid Build Coastguard Worker };
14*dbb99499SAndroid Build Coastguard Worker
BM_empty(benchmark::State & state)15*dbb99499SAndroid Build Coastguard Worker void BM_empty(benchmark::State& state) {
16*dbb99499SAndroid Build Coastguard Worker for (auto _ : state) {
17*dbb99499SAndroid Build Coastguard Worker auto iterations = double(state.iterations()) * double(state.iterations());
18*dbb99499SAndroid Build Coastguard Worker benchmark::DoNotOptimize(iterations);
19*dbb99499SAndroid Build Coastguard Worker }
20*dbb99499SAndroid Build Coastguard Worker }
21*dbb99499SAndroid Build Coastguard Worker BENCHMARK(BM_empty);
22*dbb99499SAndroid Build Coastguard Worker
23*dbb99499SAndroid Build Coastguard Worker ADD_CASES(TC_ConsoleOut, {{"^BM_empty %console_report$"}});
24*dbb99499SAndroid Build Coastguard Worker ADD_CASES(TC_JSONOut, {{"\"name\": \"BM_empty\",$"},
25*dbb99499SAndroid Build Coastguard Worker {"\"family_index\": 0,$", MR_Next},
26*dbb99499SAndroid Build Coastguard Worker {"\"per_family_instance_index\": 0,$", MR_Next},
27*dbb99499SAndroid Build Coastguard Worker {"\"run_name\": \"BM_empty\",$", MR_Next},
28*dbb99499SAndroid Build Coastguard Worker {"\"run_type\": \"iteration\",$", MR_Next},
29*dbb99499SAndroid Build Coastguard Worker {"\"repetitions\": 1,$", MR_Next},
30*dbb99499SAndroid Build Coastguard Worker {"\"repetition_index\": 0,$", MR_Next},
31*dbb99499SAndroid Build Coastguard Worker {"\"threads\": 1,$", MR_Next},
32*dbb99499SAndroid Build Coastguard Worker {"\"iterations\": %int,$", MR_Next},
33*dbb99499SAndroid Build Coastguard Worker {"\"real_time\": %float,$", MR_Next},
34*dbb99499SAndroid Build Coastguard Worker {"\"cpu_time\": %float,$", MR_Next},
35*dbb99499SAndroid Build Coastguard Worker {"\"time_unit\": \"ns\",$", MR_Next},
36*dbb99499SAndroid Build Coastguard Worker {"\"allocs_per_iter\": %float,$", MR_Next},
37*dbb99499SAndroid Build Coastguard Worker {"\"max_bytes_used\": 42000$", MR_Next},
38*dbb99499SAndroid Build Coastguard Worker {"}", MR_Next}});
39*dbb99499SAndroid Build Coastguard Worker ADD_CASES(TC_CSVOut, {{"^\"BM_empty\",%csv_report$"}});
40*dbb99499SAndroid Build Coastguard Worker
main(int argc,char * argv[])41*dbb99499SAndroid Build Coastguard Worker int main(int argc, char* argv[]) {
42*dbb99499SAndroid Build Coastguard Worker std::unique_ptr<benchmark::MemoryManager> mm(new TestMemoryManager());
43*dbb99499SAndroid Build Coastguard Worker
44*dbb99499SAndroid Build Coastguard Worker benchmark::RegisterMemoryManager(mm.get());
45*dbb99499SAndroid Build Coastguard Worker RunOutputTests(argc, argv);
46*dbb99499SAndroid Build Coastguard Worker benchmark::RegisterMemoryManager(nullptr);
47*dbb99499SAndroid Build Coastguard Worker }
48