2017-02-28 19:14:49 +08:00
|
|
|
#define HARDCODED_OUTPUT_STREAM
|
2017-07-06 19:53:39 +08:00
|
|
|
#include <gflags/gflags.h>
|
2017-02-14 16:37:32 +08:00
|
|
|
#include "../integration/query_engine_common.hpp"
|
2017-02-15 21:10:16 +08:00
|
|
|
#include "dbms/dbms.hpp"
|
2016-07-11 09:39:33 +08:00
|
|
|
|
2017-02-14 16:37:32 +08:00
|
|
|
#include "utils/fswatcher.hpp"
|
2016-07-11 09:39:33 +08:00
|
|
|
|
2017-07-06 19:53:39 +08:00
|
|
|
// Needed by query_engine_common.hpp.
|
|
|
|
DEFINE_string(q, "../data/queries/core/mg_basic_002.txt",
|
|
|
|
"Path to warm up queries");
|
|
|
|
DEFINE_string(i, "../integration/hardcoded_query",
|
|
|
|
"Path to folder with query implementations");
|
|
|
|
|
2017-02-14 16:37:32 +08:00
|
|
|
using namespace std::chrono_literals;
|
|
|
|
using namespace tests::integration;
|
2016-07-11 09:39:33 +08:00
|
|
|
|
2017-06-21 17:29:13 +08:00
|
|
|
int main(int argc, char *argv[]) {
|
2017-07-06 19:53:39 +08:00
|
|
|
gflags::ParseCommandLineFlags(&argc, &argv, true);
|
2016-07-18 01:32:35 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
// forlder with query implementations
|
2017-07-06 19:53:39 +08:00
|
|
|
auto implementations_folder = fs::path(FLAGS_i);
|
2016-08-29 01:50:54 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
// init engine
|
2017-06-21 17:29:13 +08:00
|
|
|
init_logging("ManualQueryEngine");
|
2017-02-18 18:54:37 +08:00
|
|
|
Dbms dbms;
|
2017-02-21 22:37:32 +08:00
|
|
|
StreamT stream(std::cout); // inject path to data queries
|
2017-02-18 18:54:37 +08:00
|
|
|
QueryEngineT query_engine;
|
|
|
|
// IMPORTANT: PrintRecordStream can be replaces with a smarter
|
|
|
|
// object that can test the results
|
2017-02-14 16:37:32 +08:00
|
|
|
|
2017-06-21 17:29:13 +08:00
|
|
|
WarmUpEngine(query_engine, dbms, stream);
|
2017-02-14 16:37:32 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
// init watcher
|
|
|
|
FSWatcher watcher;
|
2017-02-14 16:37:32 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
int i = 0;
|
|
|
|
watcher.watch(
|
2017-02-21 22:37:32 +08:00
|
|
|
WatchDescriptor(implementations_folder, FSEventType::All),
|
2017-02-18 18:54:37 +08:00
|
|
|
[&](FSEvent event) {
|
|
|
|
i++; // bacause only close_no_write could be detected and this
|
|
|
|
// call will cause close no write again
|
|
|
|
if (i % 2 == 1) {
|
|
|
|
// take only cpp files
|
|
|
|
if (event.path.extension() != ".cpp") return;
|
2017-02-14 16:37:32 +08:00
|
|
|
|
2017-02-28 19:14:49 +08:00
|
|
|
auto comment = std::string("// ");
|
|
|
|
auto query_mark = comment + std::string("Query: ");
|
2017-04-18 18:11:25 +08:00
|
|
|
auto lines = utils::ReadLines(event.path);
|
2017-02-28 19:14:49 +08:00
|
|
|
for (int i = 0; i < (int)lines.size(); ++i) {
|
|
|
|
// find query in the line
|
2017-06-21 17:29:13 +08:00
|
|
|
auto &line = lines[i];
|
2017-02-18 18:54:37 +08:00
|
|
|
auto pos = line.find(query_mark);
|
2017-02-28 19:14:49 +08:00
|
|
|
// if query doesn't exist pass
|
2017-02-18 18:54:37 +08:00
|
|
|
if (pos == std::string::npos) continue;
|
2017-04-18 18:11:25 +08:00
|
|
|
auto query = utils::Trim(line.substr(pos + query_mark.size()));
|
2017-02-28 19:14:49 +08:00
|
|
|
while (i + 1 < (int)lines.size() &&
|
|
|
|
lines[i + 1].find(comment) != std::string::npos) {
|
|
|
|
query += lines[i + 1].substr(lines[i + 1].find(comment) +
|
|
|
|
comment.length());
|
|
|
|
++i;
|
|
|
|
}
|
|
|
|
|
2017-06-21 17:29:13 +08:00
|
|
|
DLOG(INFO) << fmt::format("Reload: {}", query);
|
2017-02-18 18:54:37 +08:00
|
|
|
query_engine.Unload(query);
|
|
|
|
try {
|
|
|
|
query_engine.ReloadCustom(query, event.path);
|
2017-03-07 21:14:56 +08:00
|
|
|
auto db_accessor = dbms.active();
|
2017-03-14 20:26:48 +08:00
|
|
|
query_engine.Run(query, *db_accessor, stream);
|
2017-06-21 17:29:13 +08:00
|
|
|
} catch (query::PlanCompilationException &e) {
|
|
|
|
DLOG(ERROR) << fmt::format("Query compilation failed: {}",
|
|
|
|
e.what());
|
|
|
|
} catch (std::exception &e) {
|
|
|
|
DLOG(WARNING) << "Query execution failed: unknown reason";
|
2017-02-14 16:37:32 +08:00
|
|
|
}
|
2017-06-21 17:29:13 +08:00
|
|
|
DLOG(INFO) << fmt::format("Number of available query plans: {}",
|
|
|
|
query_engine.Size());
|
2017-02-18 18:54:37 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
2017-02-14 16:37:32 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
// TODO: watcher for injected query
|
2017-02-14 16:37:32 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
std::this_thread::sleep_for(1000s);
|
2017-02-14 16:37:32 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
watcher.stop();
|
2016-11-02 23:05:02 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
return 0;
|
2016-07-11 09:39:33 +08:00
|
|
|
}
|