2017-06-30 20:25:25 +08:00
|
|
|
#include <unordered_map>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
/**
|
|
|
|
* gtest/gtest.h must be included before rapidcheck/gtest.h!
|
|
|
|
*/
|
2017-10-30 17:43:25 +08:00
|
|
|
#include <gtest/gtest.h>
|
|
|
|
#include <rapidcheck.h>
|
2017-06-30 20:25:25 +08:00
|
|
|
#include <rapidcheck/gtest.h>
|
|
|
|
|
2018-10-05 18:37:23 +08:00
|
|
|
#include "database/single_node/graph_db.hpp"
|
|
|
|
#include "database/single_node/graph_db_accessor.hpp"
|
2017-10-30 17:43:25 +08:00
|
|
|
#include "storage/vertex_accessor.hpp"
|
|
|
|
|
2017-06-30 20:25:25 +08:00
|
|
|
/**
|
|
|
|
* It is possible to run test with custom seed with:
|
|
|
|
* RC_PARAMS="seed=1" ./random_graph
|
|
|
|
*/
|
2017-12-08 19:50:46 +08:00
|
|
|
RC_GTEST_PROP(RandomGraph, RandomGraph, (std::vector<std::string> vertex_labels,
|
|
|
|
std::vector<std::string> edge_types)) {
|
2017-06-30 20:25:25 +08:00
|
|
|
RC_PRE(!vertex_labels.empty());
|
|
|
|
RC_PRE(!edge_types.empty());
|
|
|
|
|
|
|
|
int vertices_num = vertex_labels.size();
|
|
|
|
int edges_num = edge_types.size();
|
|
|
|
|
2018-10-09 17:09:10 +08:00
|
|
|
database::GraphDb db;
|
2017-06-30 20:25:25 +08:00
|
|
|
std::vector<VertexAccessor> vertices;
|
2017-12-08 19:50:46 +08:00
|
|
|
std::unordered_map<VertexAccessor, std::string> vertex_label_map;
|
|
|
|
std::unordered_map<EdgeAccessor, std::string> edge_type_map;
|
2017-06-30 20:25:25 +08:00
|
|
|
|
2018-07-26 15:08:21 +08:00
|
|
|
auto dba = db.Access();
|
2017-06-30 20:25:25 +08:00
|
|
|
|
|
|
|
for (auto label : vertex_labels) {
|
2018-07-26 15:08:21 +08:00
|
|
|
auto vertex_accessor = dba->InsertVertex();
|
|
|
|
vertex_accessor.add_label(dba->Label(label));
|
2017-06-30 20:25:25 +08:00
|
|
|
vertex_label_map.insert({vertex_accessor, label});
|
|
|
|
vertices.push_back(vertex_accessor);
|
|
|
|
}
|
|
|
|
|
|
|
|
for (auto type : edge_types) {
|
|
|
|
auto from = vertices[*rc::gen::inRange(0, vertices_num)];
|
|
|
|
auto to = vertices[*rc::gen::inRange(0, vertices_num)];
|
2018-07-26 15:08:21 +08:00
|
|
|
auto edge_accessor = dba->InsertEdge(from, to, dba->EdgeType(type));
|
2017-06-30 20:25:25 +08:00
|
|
|
edge_type_map.insert({edge_accessor, type});
|
|
|
|
}
|
|
|
|
|
2018-07-26 15:08:21 +08:00
|
|
|
dba->AdvanceCommand();
|
2017-06-30 20:25:25 +08:00
|
|
|
|
|
|
|
int edges_num_check = 0;
|
|
|
|
int vertices_num_check = 0;
|
2018-07-26 15:08:21 +08:00
|
|
|
for (const auto &vertex : dba->Vertices(false)) {
|
2017-06-30 20:25:25 +08:00
|
|
|
auto label = vertex_label_map.at(vertex);
|
|
|
|
RC_ASSERT(vertex.labels().size() == 1);
|
2018-07-26 15:08:21 +08:00
|
|
|
RC_ASSERT(dba->LabelName(vertex.labels()[0]) == label);
|
2017-06-30 20:25:25 +08:00
|
|
|
vertices_num_check++;
|
|
|
|
}
|
2018-07-26 15:08:21 +08:00
|
|
|
for (const auto &edge : dba->Edges(false)) {
|
2017-06-30 20:25:25 +08:00
|
|
|
auto type = edge_type_map.at(edge);
|
2018-07-26 15:08:21 +08:00
|
|
|
RC_ASSERT(dba->EdgeTypeName(edge.EdgeType()) == type);
|
2017-06-30 20:25:25 +08:00
|
|
|
edges_num_check++;
|
|
|
|
}
|
|
|
|
RC_ASSERT(vertices_num_check == vertices_num);
|
|
|
|
RC_ASSERT(edges_num_check == edges_num);
|
|
|
|
}
|