2016-07-07 08:58:26 +08:00
|
|
|
#include "query_engine/hardcode/queries.hpp"
|
2016-08-28 22:47:13 +08:00
|
|
|
|
|
|
|
#include "barrier/barrier.cpp"
|
|
|
|
|
2016-08-31 01:13:23 +08:00
|
|
|
#include "communication/bolt/v1/serialization/bolt_serializer.hpp"
|
2016-08-28 22:47:13 +08:00
|
|
|
#include "database/db.hpp"
|
|
|
|
#include "query_engine/query_stripper.hpp"
|
2016-08-29 02:36:52 +08:00
|
|
|
// #include "storage/edges.cpp"
|
|
|
|
// #include "storage/edges.hpp"
|
|
|
|
// #include "storage/vertices.cpp"
|
|
|
|
// #include "storage/vertices.hpp"
|
|
|
|
// #include "utils/assert.hpp"
|
2016-07-07 08:58:26 +08:00
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
Db db;
|
|
|
|
|
2016-08-28 22:47:13 +08:00
|
|
|
auto query_functions = load_queries(barrier::trans(db));
|
2016-07-07 08:58:26 +08:00
|
|
|
|
2016-07-24 10:47:48 +08:00
|
|
|
auto stripper = make_query_stripper(TK_LONG, TK_FLOAT, TK_STR, TK_BOOL);
|
2016-07-07 08:58:26 +08:00
|
|
|
|
|
|
|
// TODO: put all queries into a file
|
|
|
|
std::vector<std::string> queries = {
|
|
|
|
"CREATE (n:LABEL {name: \"TEST1\"}) RETURN n",
|
|
|
|
"CREATE (n:LABEL {name: \"TEST2\"}) RETURN n",
|
|
|
|
"CREATE (n:LABEL {name: \"TEST3\"}) RETURN n",
|
2016-08-31 06:07:42 +08:00
|
|
|
"CREATE (n:OTHER {name: \"TEST4\"}) RETURN n"
|
2016-08-18 22:34:36 +08:00
|
|
|
"CREATE (n:ACCOUNT {id: 2322, name: \"TEST\", country: \"Croatia\", "
|
|
|
|
"created_at: 2352352}) RETURN n",
|
|
|
|
"MATCH (n {id: 0}) RETURN n", "MATCH (n {id: 1}) RETURN n",
|
|
|
|
"MATCH (n {id: 2}) RETURN n", "MATCH (n {id: 3}) RETURN n",
|
2016-07-07 08:58:26 +08:00
|
|
|
"MATCH (a {id:0}), (p {id: 1}) CREATE (a)-[r:IS]->(p) RETURN r",
|
|
|
|
"MATCH (a {id:1}), (p {id: 2}) CREATE (a)-[r:IS]->(p) RETURN r",
|
|
|
|
"MATCH ()-[r]-() WHERE ID(r)=0 RETURN r",
|
|
|
|
"MATCH ()-[r]-() WHERE ID(r)=1 RETURN r",
|
|
|
|
"MATCH (n: {id: 0}) SET n.name = \"TEST100\" RETURN n",
|
|
|
|
"MATCH (n: {id: 1}) SET n.name = \"TEST101\" RETURN n",
|
|
|
|
"MATCH (n: {id: 0}) SET n.name = \"TEST102\" RETURN n",
|
2016-08-31 01:13:23 +08:00
|
|
|
"MATCH (n:LABEL) RETURN n", "MATCH (n1), (n2) WHERE ID(n1)=0 AND "
|
|
|
|
"ID(n2)=1 CREATE (n1)<-[r:IS {age: "
|
|
|
|
"25,weight: 70}]-(n2) RETURN r",
|
|
|
|
"MATCH (n) RETURN n", "MATCH (n:LABEL) RETURN n", "MATCH (n) DELETE n ",
|
|
|
|
"MATCH (n:LABEL) DELETE n", "MATCH (n) WHERE ID(n) = 0 DELETE n",
|
|
|
|
"MATCH ()-[r]-() WHERE ID(r) = 0 DELETE r", "MATCH ()-[r]-() DELETE r",
|
|
|
|
"MATCH ()-[r:TYPE]-() DELETE r",
|
|
|
|
"MATCH (n)-[:TYPE]->(m) WHERE ID(n) = 0 RETURN m",
|
|
|
|
"MATCH (n)-[:TYPE]->(m) WHERE n.name = \"kruno\" RETURN m",
|
|
|
|
"MATCH (n)-[:TYPE]->(m) WHERE n.name = \"kruno\" RETURN n,m",
|
|
|
|
"MATCH (n:LABEL)-[:TYPE]->(m) RETURN n"};
|
2016-07-07 08:58:26 +08:00
|
|
|
|
|
|
|
for (auto &query : queries) {
|
|
|
|
auto stripped = stripper.strip(query);
|
2016-08-31 01:13:23 +08:00
|
|
|
std::cout << "Query hash: " << stripped.hash << std::endl;
|
2016-07-07 08:58:26 +08:00
|
|
|
auto result = query_functions[stripped.hash](stripped.arguments);
|
|
|
|
permanent_assert(result == true,
|
|
|
|
"Result retured from query function is not true");
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|