| #include <cassert> |
| #include <cstdlib> |
| #include <memory> |
| #include <vector> |
| |
| #include "benchmark/benchmark.h" |
| |
| // Tests that we can specify the number of profiler iterations with |
| // --benchmark_min_time=<NUM>x. |
| namespace { |
| |
| int iteration_count = 0; |
| int end_profiler_iteration_count = 0; |
| |
| class TestProfilerManager : public benchmark::ProfilerManager { |
| void AfterSetupStart() override { iteration_count = 0; } |
| void BeforeTeardownStop() override { |
| end_profiler_iteration_count = iteration_count; |
| } |
| }; |
| |
| class NullReporter : public benchmark::BenchmarkReporter { |
| public: |
| bool ReportContext(const Context& /*context*/) override { return true; } |
| void ReportRuns(const std::vector<Run>& /* report */) override {} |
| }; |
| |
| } // end namespace |
| |
| static void BM_MyBench(benchmark::State& state) { |
| for (auto s : state) { |
| ++iteration_count; |
| } |
| } |
| BENCHMARK(BM_MyBench); |
| |
| int main(int argc, char** argv) { |
| benchmark::MaybeReenterWithoutASLR(argc, argv); |
| // Make a fake argv and append the new --benchmark_profiler_iterations=<foo> |
| // to it. |
| int fake_argc = argc + 1; |
| std::vector<const char*> fake_argv(static_cast<size_t>(fake_argc)); |
| for (size_t i = 0; i < static_cast<size_t>(argc); ++i) { |
| fake_argv[i] = argv[i]; |
| } |
| fake_argv[static_cast<size_t>(argc)] = "--benchmark_min_time=4x"; |
| |
| std::unique_ptr<benchmark::ProfilerManager> pm(new TestProfilerManager()); |
| benchmark::RegisterProfilerManager(pm.get()); |
| |
| benchmark::Initialize(&fake_argc, const_cast<char**>(fake_argv.data())); |
| |
| NullReporter null_reporter; |
| const size_t returned_count = |
| benchmark::RunSpecifiedBenchmarks(&null_reporter, "BM_MyBench"); |
| assert(returned_count == 1); |
| |
| // Check the executed iters. |
| assert(end_profiler_iteration_count == 4); |
| |
| benchmark::RegisterProfilerManager(nullptr); |
| return 0; |
| } |