2022-12-08 00:33:47 +08:00
|
|
|
// Copyright 2022 Memgraph Ltd.
|
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
|
2022-12-13 01:15:49 +08:00
|
|
|
#include <memory>
|
2022-12-08 00:33:47 +08:00
|
|
|
#include "mock_helpers.hpp"
|
|
|
|
|
|
|
|
#include "query/v2/bindings/frame.hpp"
|
|
|
|
#include "query/v2/bindings/symbol_table.hpp"
|
|
|
|
#include "query/v2/common.hpp"
|
|
|
|
#include "query/v2/context.hpp"
|
|
|
|
#include "query/v2/plan/operator.hpp"
|
|
|
|
#include "query/v2/requests.hpp"
|
|
|
|
#include "storage/v3/property_value.hpp"
|
|
|
|
#include "storage/v3/shard.hpp"
|
|
|
|
#include "utils/logging.hpp"
|
|
|
|
#include "utils/memory.hpp"
|
|
|
|
|
2022-12-13 01:15:49 +08:00
|
|
|
namespace memgraph::query::v2 {
|
2022-12-08 00:33:47 +08:00
|
|
|
|
|
|
|
MultiFrame CreateMultiFrame(const size_t max_pos, const Symbol &src, const Symbol &dst, MockedRequestRouter *router) {
|
2022-12-19 22:44:01 +08:00
|
|
|
static constexpr size_t number_of_frames = 100;
|
|
|
|
MultiFrame multi_frame(max_pos, number_of_frames, utils::NewDeleteResource());
|
2022-12-08 00:33:47 +08:00
|
|
|
auto frames_populator = multi_frame.GetInvalidFramesPopulator();
|
|
|
|
size_t i = 0;
|
|
|
|
for (auto &frame : frames_populator) {
|
|
|
|
auto &src_acc = frame.at(src);
|
|
|
|
auto &dst_acc = frame.at(dst);
|
|
|
|
auto v1 = msgs::Vertex{.id = {{msgs::LabelId::FromUint(1)}, {msgs::Value(static_cast<int64_t>(i++))}}};
|
|
|
|
auto v2 = msgs::Vertex{.id = {{msgs::LabelId::FromUint(1)}, {msgs::Value(static_cast<int64_t>(i++))}}};
|
|
|
|
std::map<msgs::PropertyId, msgs::Value> mp;
|
|
|
|
src_acc = TypedValue(query::v2::accessors::VertexAccessor(v1, mp, router));
|
|
|
|
dst_acc = TypedValue(query::v2::accessors::VertexAccessor(v2, mp, router));
|
|
|
|
}
|
|
|
|
|
2022-12-19 22:44:01 +08:00
|
|
|
multi_frame.MakeAllFramesInvalid();
|
|
|
|
|
2022-12-08 00:33:47 +08:00
|
|
|
return multi_frame;
|
|
|
|
}
|
|
|
|
|
2022-12-13 01:15:49 +08:00
|
|
|
TEST(CreateExpandTest, Cursor) {
|
|
|
|
using testing::_;
|
|
|
|
using testing::Return;
|
2022-12-08 00:33:47 +08:00
|
|
|
|
|
|
|
AstStorage ast;
|
|
|
|
SymbolTable symbol_table;
|
|
|
|
|
2022-12-13 01:15:49 +08:00
|
|
|
plan::NodeCreationInfo node;
|
|
|
|
plan::EdgeCreationInfo edge;
|
2022-12-08 00:33:47 +08:00
|
|
|
edge.edge_type = msgs::EdgeTypeId::FromUint(1);
|
|
|
|
edge.direction = EdgeAtom::Direction::IN;
|
2022-12-15 00:26:40 +08:00
|
|
|
edge.symbol = symbol_table.CreateSymbol("e", true);
|
2022-12-08 00:33:47 +08:00
|
|
|
auto id_alloc = IdAllocator(0, 100);
|
|
|
|
|
|
|
|
const auto &src = symbol_table.CreateSymbol("n", true);
|
|
|
|
node.symbol = symbol_table.CreateSymbol("u", true);
|
|
|
|
|
2022-12-19 22:44:01 +08:00
|
|
|
auto once_op = std::make_shared<plan::Once>();
|
|
|
|
auto once_cur = once_op->MakeCursor(utils::NewDeleteResource());
|
2022-12-13 01:15:49 +08:00
|
|
|
|
|
|
|
auto create_expand = plan::CreateExpand(node, edge, once_op, src, true);
|
2022-12-08 00:33:47 +08:00
|
|
|
auto cursor = create_expand.MakeCursor(utils::NewDeleteResource());
|
|
|
|
|
2022-12-13 01:15:49 +08:00
|
|
|
MockedRequestRouter router;
|
2022-12-15 00:26:40 +08:00
|
|
|
EXPECT_CALL(router, CreateExpand(_))
|
|
|
|
.Times(1)
|
|
|
|
.WillOnce(Return(std::vector<msgs::CreateExpandResponse>{msgs::CreateExpandResponse{}}));
|
2022-12-08 00:33:47 +08:00
|
|
|
auto context = MakeContext(ast, symbol_table, &router, &id_alloc);
|
|
|
|
auto multi_frame = CreateMultiFrame(context.symbol_table.max_position(), src, node.symbol, &router);
|
|
|
|
cursor->PullMultiple(multi_frame, context);
|
2022-12-15 00:26:40 +08:00
|
|
|
|
|
|
|
auto frames = multi_frame.GetValidFramesReader();
|
2022-12-19 22:44:01 +08:00
|
|
|
auto number_of_valid_frames = 0;
|
2022-12-15 00:26:40 +08:00
|
|
|
for (auto &frame : frames) {
|
2022-12-19 22:44:01 +08:00
|
|
|
++number_of_valid_frames;
|
2022-12-15 00:26:40 +08:00
|
|
|
EXPECT_EQ(frame[edge.symbol].IsEdge(), true);
|
|
|
|
const auto &e = frame[edge.symbol].ValueEdge();
|
|
|
|
EXPECT_EQ(e.EdgeType(), edge.edge_type);
|
|
|
|
}
|
2022-12-19 22:44:01 +08:00
|
|
|
EXPECT_EQ(number_of_valid_frames, 1);
|
|
|
|
|
|
|
|
auto invalid_frames = multi_frame.GetInvalidFramesPopulator();
|
|
|
|
auto number_of_invalid_frames = std::distance(invalid_frames.begin(), invalid_frames.end());
|
|
|
|
EXPECT_EQ(number_of_invalid_frames, 99);
|
2022-12-08 00:33:47 +08:00
|
|
|
}
|
2022-12-13 01:15:49 +08:00
|
|
|
|
|
|
|
} // namespace memgraph::query::v2
|