2024-01-06 00:42:54 +08:00
|
|
|
// Copyright 2024 Memgraph Ltd.
|
2021-10-26 14:53:56 +08:00
|
|
|
//
|
|
|
|
// Use of this software is governed by the Business Source License
|
|
|
|
// included in the file licenses/BSL.txt; by using this file, you agree to be bound by the terms of the Business Source
|
|
|
|
// License, and you may not use this file except in compliance with the Business Source License.
|
|
|
|
//
|
|
|
|
// As of the Change Date specified in that file, in accordance with
|
|
|
|
// the Business Source License, use of this software will be governed
|
|
|
|
// by the Apache License, Version 2.0, included in the file
|
|
|
|
// licenses/APL.txt.
|
|
|
|
|
2023-06-29 17:44:55 +08:00
|
|
|
#include <memory>
|
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>
|
|
|
|
|
2023-06-29 17:44:55 +08:00
|
|
|
#include "storage/v2/inmemory/storage.hpp"
|
2020-01-13 17:34:55 +08:00
|
|
|
#include "storage/v2/storage.hpp"
|
2023-06-29 17:44:55 +08:00
|
|
|
#include "storage/v2/vertex_accessor.hpp"
|
2024-01-06 00:42:54 +08:00
|
|
|
using memgraph::replication::ReplicationRole;
|
2017-06-30 20:25:25 +08:00
|
|
|
/**
|
|
|
|
* It is possible to run test with custom seed with:
|
|
|
|
* RC_PARAMS="seed=1" ./random_graph
|
|
|
|
*/
|
2021-02-18 22:32:43 +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();
|
|
|
|
|
2023-06-29 17:44:55 +08:00
|
|
|
std::unique_ptr<memgraph::storage::Storage> db{new memgraph::storage::InMemoryStorage()};
|
2022-02-22 20:33:45 +08:00
|
|
|
std::vector<memgraph::storage::VertexAccessor> vertices;
|
|
|
|
std::unordered_map<memgraph::storage::VertexAccessor, std::string> vertex_label_map;
|
|
|
|
std::unordered_map<memgraph::storage::EdgeAccessor, std::string> edge_type_map;
|
2017-06-30 20:25:25 +08:00
|
|
|
|
2024-01-06 00:42:54 +08:00
|
|
|
auto dba = db->Access(ReplicationRole::MAIN);
|
2017-06-30 20:25:25 +08:00
|
|
|
|
|
|
|
for (auto label : vertex_labels) {
|
2023-06-29 17:44:55 +08:00
|
|
|
auto vertex_accessor = dba->CreateVertex();
|
|
|
|
RC_ASSERT(vertex_accessor.AddLabel(dba->NameToLabel(label)).HasValue());
|
|
|
|
vertex_label_map.emplace(vertex_accessor, label);
|
2017-06-30 20:25:25 +08:00
|
|
|
vertices.push_back(vertex_accessor);
|
|
|
|
}
|
|
|
|
|
|
|
|
for (auto type : edge_types) {
|
2020-01-13 17:34:55 +08:00
|
|
|
auto &from = vertices[*rc::gen::inRange(0, vertices_num)];
|
|
|
|
auto &to = vertices[*rc::gen::inRange(0, vertices_num)];
|
2023-06-29 17:44:55 +08:00
|
|
|
auto maybe_edge_accessor = dba->CreateEdge(&from, &to, dba->NameToEdgeType(type));
|
2020-01-13 17:34:55 +08:00
|
|
|
RC_ASSERT(maybe_edge_accessor.HasValue());
|
|
|
|
edge_type_map.insert({*maybe_edge_accessor, type});
|
2017-06-30 20:25:25 +08:00
|
|
|
}
|
|
|
|
|
2023-06-29 17:44:55 +08:00
|
|
|
dba->AdvanceCommand();
|
2017-06-30 20:25:25 +08:00
|
|
|
|
|
|
|
int edges_num_check = 0;
|
|
|
|
int vertices_num_check = 0;
|
2023-06-29 17:44:55 +08:00
|
|
|
for (auto vertex : dba->Vertices(memgraph::storage::View::OLD)) {
|
2017-06-30 20:25:25 +08:00
|
|
|
auto label = vertex_label_map.at(vertex);
|
2022-02-22 20:33:45 +08:00
|
|
|
auto maybe_labels = vertex.Labels(memgraph::storage::View::OLD);
|
2020-01-13 17:34:55 +08:00
|
|
|
RC_ASSERT(maybe_labels.HasValue());
|
|
|
|
const auto &labels = *maybe_labels;
|
|
|
|
RC_ASSERT(labels.size() == 1);
|
2023-06-29 17:44:55 +08:00
|
|
|
RC_ASSERT(dba->LabelToName(labels[0]) == label);
|
2017-06-30 20:25:25 +08:00
|
|
|
vertices_num_check++;
|
2022-02-22 20:33:45 +08:00
|
|
|
auto maybe_edges = vertex.OutEdges(memgraph::storage::View::OLD);
|
2020-01-13 17:34:55 +08:00
|
|
|
RC_ASSERT(maybe_edges.HasValue());
|
2023-09-08 23:12:25 +08:00
|
|
|
for (auto &edge : maybe_edges->edges) {
|
2020-01-13 17:34:55 +08:00
|
|
|
const auto &type = edge_type_map.at(edge);
|
2023-06-29 17:44:55 +08:00
|
|
|
RC_ASSERT(dba->EdgeTypeToName(edge.EdgeType()) == type);
|
2020-01-13 17:34:55 +08:00
|
|
|
edges_num_check++;
|
|
|
|
}
|
2017-06-30 20:25:25 +08:00
|
|
|
}
|
|
|
|
RC_ASSERT(vertices_num_check == vertices_num);
|
|
|
|
RC_ASSERT(edges_num_check == edges_num);
|
|
|
|
}
|