2017-02-18 21:36:50 +08:00
|
|
|
#define LOG_NO_INFO 1
|
|
|
|
|
2017-06-13 22:25:08 +08:00
|
|
|
#include <fstream>
|
|
|
|
#include <iostream>
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
2017-06-21 17:29:13 +08:00
|
|
|
#include <benchmark/benchmark_api.h>
|
|
|
|
#include <glog/logging.h>
|
|
|
|
|
2017-06-13 22:25:08 +08:00
|
|
|
#include "query/frontend/stripped.hpp"
|
2016-11-23 00:42:24 +08:00
|
|
|
|
2016-12-22 22:51:16 +08:00
|
|
|
auto BM_Strip = [](benchmark::State &state, auto &function, std::string query) {
|
2017-02-18 18:54:37 +08:00
|
|
|
while (state.KeepRunning()) {
|
|
|
|
for (int start = 0; start < state.range(0); start++) {
|
|
|
|
function(query);
|
2016-11-23 00:42:24 +08:00
|
|
|
}
|
2017-02-18 18:54:37 +08:00
|
|
|
}
|
|
|
|
state.SetComplexityN(state.range(0));
|
2016-11-23 00:42:24 +08:00
|
|
|
};
|
|
|
|
|
2017-06-13 22:25:08 +08:00
|
|
|
int main(int argc, char *argv[]) {
|
2017-06-21 17:29:13 +08:00
|
|
|
google::InitGoogleLogging(argv[0]);
|
2017-02-18 18:54:37 +08:00
|
|
|
|
2017-06-08 00:28:31 +08:00
|
|
|
auto preprocess = [](const std::string &query) {
|
|
|
|
return query::StrippedQuery(query);
|
|
|
|
};
|
2017-02-18 18:54:37 +08:00
|
|
|
|
2017-06-13 22:25:08 +08:00
|
|
|
std::string path = "../../tests/data/cypher_queries/stripper/query_dict.yaml";
|
|
|
|
std::fstream queries_file(path);
|
|
|
|
|
|
|
|
std::string test;
|
|
|
|
while (std::getline(queries_file, test)) {
|
2017-03-21 20:48:35 +08:00
|
|
|
benchmark::RegisterBenchmark(test.c_str(), BM_Strip, preprocess, test)
|
|
|
|
->Range(1, 1)
|
|
|
|
->Complexity(benchmark::oN);
|
2017-02-18 18:54:37 +08:00
|
|
|
}
|
2016-11-23 00:42:24 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
benchmark::Initialize(&argc, argv);
|
|
|
|
benchmark::RunSpecifiedBenchmarks();
|
2016-11-23 00:42:24 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
return 0;
|
2016-11-23 00:42:24 +08:00
|
|
|
}
|