#include "bfs_common.hpp" using namespace query; using namespace query::plan; class SingleNodeDb : public Database { public: SingleNodeDb() : db_() {} std::unique_ptr Access() override { std::unique_ptr dba = std::make_unique(db_.Access()); return dba; } void AdvanceCommand(tx::TransactionId tx_id) override { auto dba = db_.Access(tx_id); dba.AdvanceCommand(); } std::unique_ptr MakeBfsOperator( Symbol source_sym, Symbol sink_sym, Symbol edge_sym, EdgeAtom::Direction direction, const std::vector &edge_types, const std::shared_ptr &input, bool existing_node, Expression *lower_bound, Expression *upper_bound, const ExpansionLambda &filter_lambda) override { return std::make_unique( input, source_sym, sink_sym, edge_sym, EdgeAtom::Type::BREADTH_FIRST, direction, edge_types, false, lower_bound, upper_bound, existing_node, filter_lambda, std::nullopt, std::nullopt); } std::pair, std::vector> BuildGraph( database::GraphDbAccessor *dba, const std::vector &vertex_locations, const std::vector> &edges) override { std::vector vertex_addr; std::vector edge_addr; for (size_t id = 0; id < vertex_locations.size(); ++id) { auto vertex = dba->InsertVertex(); vertex.PropsSet(dba->Property("id"), (int64_t)id); vertex_addr.push_back(vertex.address()); } for (auto e : edges) { int u, v; std::string type; std::tie(u, v, type) = e; VertexAccessor from(vertex_addr[u], *dba); VertexAccessor to(vertex_addr[v], *dba); auto edge = dba->InsertEdge(from, to, dba->EdgeType(type)); edge.PropsSet(dba->Property("from"), u); edge.PropsSet(dba->Property("to"), v); edge_addr.push_back(edge.address()); } return std::make_pair(vertex_addr, edge_addr); } protected: database::GraphDb db_; }; class SingleNodeBfsTest : public ::testing::TestWithParam< std::tuple, bool, FilterLambdaType>> { public: static void SetUpTestCase() { db_ = std::make_unique(); } static void TearDownTestCase() { db_ = nullptr; } protected: static std::unique_ptr db_; }; TEST_P(SingleNodeBfsTest, All) { int lower_bound; int upper_bound; EdgeAtom::Direction direction; std::vector edge_types; bool known_sink; FilterLambdaType filter_lambda_type; std::tie(lower_bound, upper_bound, direction, edge_types, known_sink, filter_lambda_type) = GetParam(); BfsTest(db_.get(), lower_bound, upper_bound, direction, edge_types, known_sink, filter_lambda_type); } std::unique_ptr SingleNodeBfsTest::db_{nullptr}; INSTANTIATE_TEST_CASE_P( DirectionAndExpansionDepth, SingleNodeBfsTest, testing::Combine(testing::Range(-1, kVertexCount), testing::Range(-1, kVertexCount), testing::Values(EdgeAtom::Direction::OUT, EdgeAtom::Direction::IN, EdgeAtom::Direction::BOTH), testing::Values(std::vector{}), testing::Bool(), testing::Values(FilterLambdaType::NONE))); INSTANTIATE_TEST_CASE_P( EdgeType, SingleNodeBfsTest, testing::Combine(testing::Values(-1), testing::Values(-1), testing::Values(EdgeAtom::Direction::OUT, EdgeAtom::Direction::IN, EdgeAtom::Direction::BOTH), testing::Values(std::vector{}, std::vector{"a"}, std::vector{"b"}, std::vector{"a", "b"}), testing::Bool(), testing::Values(FilterLambdaType::NONE))); INSTANTIATE_TEST_CASE_P( FilterLambda, SingleNodeBfsTest, testing::Combine( testing::Values(-1), testing::Values(-1), testing::Values(EdgeAtom::Direction::OUT, EdgeAtom::Direction::IN, EdgeAtom::Direction::BOTH), testing::Values(std::vector{}), testing::Bool(), testing::Values(FilterLambdaType::NONE, FilterLambdaType::USE_FRAME, FilterLambdaType::USE_FRAME_NULL, FilterLambdaType::USE_CTX, FilterLambdaType::ERROR)));