03db948d7e
Summary: Operations are moved and renamed from WAL to a separate file in preparation for HA and distributed storage. Reviewers: florijan, mtomic, mislav.bradac Reviewed By: florijan Subscribers: mislav.bradac, pullbot Differential Revision: https://phabricator.memgraph.io/D1034
195 lines
4.5 KiB
C++
195 lines
4.5 KiB
C++
#include "gtest/gtest.h"
|
|
|
|
#include "database/graph_db.hpp"
|
|
#include "database/graph_db_accessor.hpp"
|
|
#include "database/state_delta.hpp"
|
|
|
|
TEST(StateDelta, CreateVertex) {
|
|
GraphDb db;
|
|
auto gid0 = gid::Create(0, 0);
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto delta = database::StateDelta::CreateVertex(dba.transaction_id(), gid0);
|
|
delta.Apply(dba);
|
|
dba.Commit();
|
|
}
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto vertex = dba.FindVertex(gid0, false);
|
|
EXPECT_TRUE(vertex);
|
|
}
|
|
}
|
|
|
|
TEST(StateDelta, RemoveVertex) {
|
|
GraphDb db;
|
|
auto gid0 = gid::Create(0, 0);
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
dba.InsertVertex(gid0);
|
|
dba.Commit();
|
|
}
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto delta = database::StateDelta::RemoveVertex(dba.transaction_id(), gid0);
|
|
delta.Apply(dba);
|
|
dba.Commit();
|
|
}
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto vertex = dba.FindVertex(gid0, false);
|
|
EXPECT_FALSE(vertex);
|
|
}
|
|
}
|
|
|
|
TEST(StateDelta, CreateEdge) {
|
|
GraphDb db;
|
|
auto gid0 = gid::Create(0, 0);
|
|
auto gid1 = gid::Create(0, 1);
|
|
auto gid2 = gid::Create(0, 2);
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
dba.InsertVertex(gid0);
|
|
dba.InsertVertex(gid1);
|
|
dba.Commit();
|
|
}
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto delta = database::StateDelta::CreateEdge(dba.transaction_id(), gid2,
|
|
gid0, gid1, "edge");
|
|
delta.Apply(dba);
|
|
dba.Commit();
|
|
}
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto edge = dba.FindEdge(gid2, false);
|
|
EXPECT_TRUE(edge);
|
|
}
|
|
}
|
|
|
|
TEST(StateDelta, RemoveEdge) {
|
|
GraphDb db;
|
|
auto gid0 = gid::Create(0, 0);
|
|
auto gid1 = gid::Create(0, 1);
|
|
auto gid2 = gid::Create(0, 2);
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto v0 = dba.InsertVertex(gid0);
|
|
auto v1 = dba.InsertVertex(gid1);
|
|
dba.InsertEdge(v0, v1, dba.EdgeType("edge"), gid2);
|
|
dba.Commit();
|
|
}
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto delta = database::StateDelta::RemoveEdge(dba.transaction_id(), gid2);
|
|
delta.Apply(dba);
|
|
dba.Commit();
|
|
}
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto edge = dba.FindEdge(gid2, false);
|
|
EXPECT_FALSE(edge);
|
|
}
|
|
}
|
|
|
|
TEST(StateDelta, AddLabel) {
|
|
GraphDb db;
|
|
auto gid0 = gid::Create(0, 0);
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
dba.InsertVertex(gid0);
|
|
dba.Commit();
|
|
}
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto delta =
|
|
database::StateDelta::AddLabel(dba.transaction_id(), gid0, "label");
|
|
delta.Apply(dba);
|
|
dba.Commit();
|
|
}
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto vertex = dba.FindVertex(gid0, false);
|
|
EXPECT_TRUE(vertex);
|
|
auto labels = vertex->labels();
|
|
EXPECT_EQ(labels.size(), 1);
|
|
EXPECT_EQ(labels[0], dba.Label("label"));
|
|
}
|
|
}
|
|
|
|
TEST(StateDelta, RemoveLabel) {
|
|
GraphDb db;
|
|
auto gid0 = gid::Create(0, 0);
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto vertex = dba.InsertVertex(gid0);
|
|
vertex.add_label(dba.Label("label"));
|
|
dba.Commit();
|
|
}
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto delta =
|
|
database::StateDelta::RemoveLabel(dba.transaction_id(), gid0, "label");
|
|
delta.Apply(dba);
|
|
dba.Commit();
|
|
}
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto vertex = dba.FindVertex(gid0, false);
|
|
EXPECT_TRUE(vertex);
|
|
auto labels = vertex->labels();
|
|
EXPECT_EQ(labels.size(), 0);
|
|
}
|
|
}
|
|
|
|
TEST(StateDelta, SetPropertyVertex) {
|
|
GraphDb db;
|
|
auto gid0 = gid::Create(0, 0);
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
dba.InsertVertex(gid0);
|
|
dba.Commit();
|
|
}
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto delta = database::StateDelta::PropsSetVertex(
|
|
dba.transaction_id(), gid0, "property", PropertyValue(2212));
|
|
delta.Apply(dba);
|
|
dba.Commit();
|
|
}
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto vertex = dba.FindVertex(gid0, false);
|
|
EXPECT_TRUE(vertex);
|
|
auto prop = vertex->PropsAt(dba.Property("property"));
|
|
EXPECT_EQ(prop.Value<int64_t>(), 2212);
|
|
}
|
|
}
|
|
|
|
TEST(StateDelta, SetPropertyEdge) {
|
|
GraphDb db;
|
|
auto gid0 = gid::Create(0, 0);
|
|
auto gid1 = gid::Create(0, 1);
|
|
auto gid2 = gid::Create(0, 2);
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto v0 = dba.InsertVertex(gid0);
|
|
auto v1 = dba.InsertVertex(gid1);
|
|
dba.InsertEdge(v0, v1, dba.EdgeType("edge"), gid2);
|
|
dba.Commit();
|
|
}
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto delta = database::StateDelta::PropsSetEdge(
|
|
dba.transaction_id(), gid2, "property", PropertyValue(2212));
|
|
delta.Apply(dba);
|
|
dba.Commit();
|
|
}
|
|
{
|
|
GraphDbAccessor dba(db);
|
|
auto edge = dba.FindEdge(gid2, false);
|
|
EXPECT_TRUE(edge);
|
|
auto prop = edge->PropsAt(dba.Property("property"));
|
|
EXPECT_EQ(prop.Value<int64_t>(), 2212);
|
|
}
|
|
}
|