memgraph/tests/benchmark/query/strip/stripper.cpp

48 lines
1.4 KiB
C++
Raw Normal View History

#include "logging/default.hpp"
#include "logging/streams/stdout.hpp"
#include "query/preprocessor.hpp"
2016-12-22 22:51:16 +08:00
#include "utils/time/timer.hpp"
#include "benchmark/benchmark_api.h"
#include "yaml-cpp/yaml.h"
2016-12-22 22:51:16 +08:00
auto BM_Strip = [](benchmark::State &state, auto &function, std::string query) {
while (state.KeepRunning())
{
for (int start = 0; start < state.range(0); start++)
{
function(query);
}
}
2016-12-22 22:51:16 +08:00
state.SetComplexityN(state.range(0));
};
2016-12-22 22:51:16 +08:00
int main(int argc, char **argv)
{
logging::init_async();
logging::log->pipe(std::make_unique<Stdout>());
YAML::Node dataset = YAML::LoadFile(
"../../tests/data/cypher_queries/stripper/query_dict.yaml");
QueryPreprocessor processor;
using std::placeholders::_1;
std::function<StrippedQuery(const std::string &query)> preprocess =
2016-12-22 22:51:16 +08:00
std::bind(&QueryPreprocessor::preprocess, &processor, _1);
auto tests = dataset["benchmark_queries"].as<std::vector<std::string>>();
for (auto &test : tests)
{
auto *benchmark = benchmark::RegisterBenchmark(test.c_str(), BM_Strip,
preprocess, test)
->RangeMultiplier(2)
->Range(1, 8 << 10)
->Complexity(benchmark::oN);
}
2016-12-22 22:51:16 +08:00
benchmark::Initialize(&argc, argv);
benchmark::RunSpecifiedBenchmarks();
2016-12-22 22:51:16 +08:00
return 0;
}