diff options
Diffstat (limited to 'libcxx/utils/google-benchmark/test/fixture_test.cc')
| -rw-r--r-- | libcxx/utils/google-benchmark/test/fixture_test.cc | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/libcxx/utils/google-benchmark/test/fixture_test.cc b/libcxx/utils/google-benchmark/test/fixture_test.cc new file mode 100644 index 00000000000..bf800fda20d --- /dev/null +++ b/libcxx/utils/google-benchmark/test/fixture_test.cc @@ -0,0 +1,52 @@ + +#include "benchmark/benchmark.h" + +#include <cassert> +#include <memory> + +class MyFixture : public ::benchmark::Fixture { + public: + void SetUp(const ::benchmark::State& state) { + if (state.thread_index == 0) { + assert(data.get() == nullptr); + data.reset(new int(42)); + } + } + + void TearDown(const ::benchmark::State& state) { + if (state.thread_index == 0) { + assert(data.get() != nullptr); + data.reset(); + } + } + + ~MyFixture() { + assert(data == nullptr); + } + + std::unique_ptr<int> data; +}; + + +BENCHMARK_F(MyFixture, Foo)(benchmark::State& st) { + assert(data.get() != nullptr); + assert(*data == 42); + while (st.KeepRunning()) { + } +} + +BENCHMARK_DEFINE_F(MyFixture, Bar)(benchmark::State& st) { + if (st.thread_index == 0) { + assert(data.get() != nullptr); + assert(*data == 42); + } + while (st.KeepRunning()) { + assert(data.get() != nullptr); + assert(*data == 42); + } + st.SetItemsProcessed(st.range_x()); +} +BENCHMARK_REGISTER_F(MyFixture, Bar)->Arg(42); +BENCHMARK_REGISTER_F(MyFixture, Bar)->Arg(42)->ThreadPerCpu(); + +BENCHMARK_MAIN() |

