#include #include #include "communication/rpc/server.hpp" #include "storage/common/types/types.hpp" #include "storage/distributed/concurrent_id_mapper_master.hpp" #include "storage/distributed/concurrent_id_mapper_worker.hpp" #include "test_coordination.hpp" template class DistributedConcurrentIdMapperTest : public ::testing::Test { const std::string kLocal{"127.0.0.1"}; protected: TestMasterCoordination coordination_; communication::ClientContext client_context_; std::optional master_client_pool_; std::optional> master_mapper_; std::optional> worker_mapper_; void SetUp() override { master_mapper_.emplace(&coordination_); coordination_.Start(); master_client_pool_.emplace(coordination_.GetServerEndpoint(), &client_context_); worker_mapper_.emplace(&master_client_pool_.value()); } void TearDown() override { worker_mapper_ = std::nullopt; master_client_pool_ = std::nullopt; coordination_.Stop(); master_mapper_ = std::nullopt; } }; typedef ::testing::Types GraphDbTestTypes; TYPED_TEST_CASE(DistributedConcurrentIdMapperTest, GraphDbTestTypes); TYPED_TEST(DistributedConcurrentIdMapperTest, Basic) { auto &master = this->master_mapper_.value(); auto &worker = this->worker_mapper_.value(); auto id1 = master.value_to_id("v1"); EXPECT_EQ(worker.id_to_value(id1), "v1"); EXPECT_EQ(worker.value_to_id("v1"), id1); auto id2 = worker.value_to_id("v2"); EXPECT_EQ(master.id_to_value(id2), "v2"); EXPECT_EQ(master.value_to_id("v2"), id2); EXPECT_NE(id1, id2); }