From 53068f974c0d69849b6437ffe0d545aec2932309 Mon Sep 17 00:00:00 2001 From: Dominic Hamon Date: Mon, 15 Feb 2016 03:04:19 -0800 Subject: [PATCH] Pass const state to Fixture::SetUp. Add map_test. --- include/benchmark/benchmark_api.h | 4 +-- test/CMakeLists.txt | 3 ++ test/fixture_test.cc | 39 +++++++++++---------- test/map_test.cc | 57 +++++++++++++++++++++++++++++++ 4 files changed, 81 insertions(+), 22 deletions(-) create mode 100644 test/map_test.cc diff --git a/include/benchmark/benchmark_api.h b/include/benchmark/benchmark_api.h index 55235878..532c4c6d 100644 --- a/include/benchmark/benchmark_api.h +++ b/include/benchmark/benchmark_api.h @@ -486,12 +486,12 @@ public: Fixture() : internal::Benchmark("") {} virtual void Run(State& st) { - this->SetUp(); + this->SetUp(st); this->BenchmarkCase(st); this->TearDown(); } - virtual void SetUp() {} + virtual void SetUp(const State&) {} virtual void TearDown() {} protected: diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt index 7e4f4854..a10a53a9 100644 --- a/test/CMakeLists.txt +++ b/test/CMakeLists.txt @@ -39,6 +39,9 @@ add_test(basic_benchmark basic_test --benchmark_min_time=0.01) compile_benchmark_test(fixture_test) add_test(fixture_test fixture_test --benchmark_min_time=0.01) +compile_benchmark_test(map_test) +add_test(map_test map_test --benchmark_min_time=0.01) + compile_benchmark_test(cxx03_test) set_target_properties(cxx03_test PROPERTIES COMPILE_FLAGS "${CXX03_FLAGS}") diff --git a/test/fixture_test.cc b/test/fixture_test.cc index 8aea6ef0..92fbc4cb 100644 --- a/test/fixture_test.cc +++ b/test/fixture_test.cc @@ -2,33 +2,33 @@ #include "benchmark/benchmark.h" #include +#include -class MyFixture : public ::benchmark::Fixture -{ -public: - void SetUp() { - data = new int(42); - } +class MyFixture : public ::benchmark::Fixture { + public: + void SetUp(const ::benchmark::State&) { + assert(data.get() == nullptr); + data.reset(new int(42)); + } - void TearDown() { - assert(data != nullptr); - delete data; - data = nullptr; - } + void TearDown() { + assert(data.get() != nullptr); + data.release(); + } - ~MyFixture() { - assert(data == nullptr); - } + ~MyFixture() { + assert(data == nullptr); + } - int* data; + std::unique_ptr data; }; BENCHMARK_F(MyFixture, Foo)(benchmark::State& st) { - assert(data != nullptr); - assert(*data == 42); - while (st.KeepRunning()) { - } + assert(data.get() != nullptr); + assert(*data == 42); + while (st.KeepRunning()) { + } } BENCHMARK_DEFINE_F(MyFixture, Bar)(benchmark::State& st) { @@ -38,5 +38,4 @@ BENCHMARK_DEFINE_F(MyFixture, Bar)(benchmark::State& st) { } BENCHMARK_REGISTER_F(MyFixture, Bar)->Arg(42); - BENCHMARK_MAIN() diff --git a/test/map_test.cc b/test/map_test.cc new file mode 100644 index 00000000..8d5f6ecd --- /dev/null +++ b/test/map_test.cc @@ -0,0 +1,57 @@ +#include "benchmark/benchmark.h" + +#include + +namespace { + +std::map ConstructRandomMap(int size) { + std::map m; + for (int i = 0; i < size; ++i) { + m.insert(std::make_pair(rand() % size, rand() % size)); + } + return m; +} + +} // namespace + +// Basic version. +static void BM_MapLookup(benchmark::State& state) { + const int size = state.range_x(); + while (state.KeepRunning()) { + state.PauseTiming(); + std::map m = ConstructRandomMap(size); + state.ResumeTiming(); + for (int i = 0; i < size; ++i) { + benchmark::DoNotOptimize(m.find(rand() % size)); + } + } + state.SetItemsProcessed(state.iterations() * size); +} +BENCHMARK(BM_MapLookup)->Range(1 << 3, 1 << 12); + +// Using fixtures. +class MapFixture : public ::benchmark::Fixture { + public: + void SetUp(const ::benchmark::State& st) { + m = ConstructRandomMap(st.range_x()); + } + + void TearDown() { + m.clear(); + } + + std::map m; +}; + +BENCHMARK_DEFINE_F(MapFixture, Lookup)(benchmark::State& state) { + const int size = state.range_x(); + while (state.KeepRunning()) { + for (int i = 0; i < size; ++i) { + benchmark::DoNotOptimize(m.find(rand() % size)); + } + } + state.SetItemsProcessed(state.iterations() * size); +} +BENCHMARK_REGISTER_F(MapFixture, Lookup)->Range(1<<3, 1<<12); + +BENCHMARK_MAIN()