#include #include #include "storage/single_node/edge.hpp" #include "storage/single_node/vertex.hpp" #include "transactions/single_node/engine.hpp" #include "utils/algorithm.hpp" #include "storage/single_node/edges.hpp" TEST(Edges, Filtering) { Edges edges; tx::Engine tx_engine; auto tx = tx_engine.Begin(); int64_t vertex_gid = 0; mvcc::VersionList v0(*tx, storage::Gid::FromInt(vertex_gid++)); mvcc::VersionList v1(*tx, storage::Gid::FromInt(vertex_gid++)); mvcc::VersionList v2(*tx, storage::Gid::FromInt(vertex_gid++)); mvcc::VersionList v3(*tx, storage::Gid::FromInt(vertex_gid++)); storage::EdgeType t1{1}; storage::EdgeType t2{2}; int64_t edge_gid = 0; mvcc::VersionList e1(*tx, storage::Gid::FromInt(edge_gid++), &v0, &v1, t1); edges.emplace(&v1, &e1, t1); mvcc::VersionList e2(*tx, storage::Gid::FromInt(edge_gid++), &v0, &v2, t2); edges.emplace(&v2, &e2, t2); mvcc::VersionList e3(*tx, storage::Gid::FromInt(edge_gid++), &v0, &v3, t1); edges.emplace(&v3, &e3, t1); mvcc::VersionList e4(*tx, storage::Gid::FromInt(edge_gid++), &v0, &v1, t2); edges.emplace(&v1, &e4, t2); mvcc::VersionList e5(*tx, storage::Gid::FromInt(edge_gid++), &v0, &v2, t1); edges.emplace(&v2, &e5, t1); mvcc::VersionList e6(*tx, storage::Gid::FromInt(edge_gid++), &v0, &v3, t2); edges.emplace(&v3, &e6, t2); auto edge_addresses = [edges](mvcc::VersionList *dest, std::vector *edge_types) { std::vector *> ret; for (auto it = edges.begin(dest, edge_types); it != edges.end(); ++it) ret.push_back(it->edge); return ret; }; { // no filtering EXPECT_THAT(edge_addresses(nullptr, nullptr), ::testing::UnorderedElementsAre(&e1, &e2, &e3, &e4, &e5, &e6)); } { // filter by node EXPECT_THAT(edge_addresses(&v1, nullptr), ::testing::UnorderedElementsAre(&e1, &e4)); EXPECT_THAT(edge_addresses(&v2, nullptr), ::testing::UnorderedElementsAre(&e2, &e5)); EXPECT_THAT(edge_addresses(&v3, nullptr), ::testing::UnorderedElementsAre(&e3, &e6)); } { // filter by edge type std::vector f1{t1}; std::vector f2{t2}; std::vector f3{t1, t2}; EXPECT_THAT(edge_addresses(nullptr, &f1), ::testing::UnorderedElementsAre(&e1, &e3, &e5)); EXPECT_THAT(edge_addresses(nullptr, &f2), ::testing::UnorderedElementsAre(&e2, &e4, &e6)); EXPECT_THAT(edge_addresses(nullptr, &f3), ::testing::UnorderedElementsAre(&e1, &e2, &e3, &e4, &e5, &e6)); } { // filter by both node and edge type std::vector f1{t1}; std::vector f2{t2}; EXPECT_THAT(edge_addresses(&v1, &f1), ::testing::UnorderedElementsAre(&e1)); EXPECT_THAT(edge_addresses(&v1, &f2), ::testing::UnorderedElementsAre(&e4)); EXPECT_THAT(edge_addresses(&v2, &f1), ::testing::UnorderedElementsAre(&e5)); EXPECT_THAT(edge_addresses(&v2, &f2), ::testing::UnorderedElementsAre(&e2)); EXPECT_THAT(edge_addresses(&v3, &f1), ::testing::UnorderedElementsAre(&e3)); EXPECT_THAT(edge_addresses(&v3, &f2), ::testing::UnorderedElementsAre(&e6)); } tx_engine.Abort(*tx); }