2017-12-15 17:48:21 +08:00
|
|
|
#include <experimental/optional>
|
|
|
|
|
2018-10-04 21:23:07 +08:00
|
|
|
#include <gtest/gtest.h>
|
2017-12-15 17:48:21 +08:00
|
|
|
|
2018-01-24 19:16:14 +08:00
|
|
|
#include "communication/rpc/server.hpp"
|
2018-11-07 01:15:55 +08:00
|
|
|
#include "storage/common/types/types.hpp"
|
2018-10-04 21:23:07 +08:00
|
|
|
#include "storage/distributed/concurrent_id_mapper_master.hpp"
|
|
|
|
#include "storage/distributed/concurrent_id_mapper_worker.hpp"
|
2017-12-15 17:48:21 +08:00
|
|
|
|
2018-10-16 15:12:19 +08:00
|
|
|
#include "test_coordination.hpp"
|
|
|
|
|
2017-12-15 17:48:21 +08:00
|
|
|
template <typename TId>
|
|
|
|
class DistributedConcurrentIdMapperTest : public ::testing::Test {
|
|
|
|
const std::string kLocal{"127.0.0.1"};
|
|
|
|
|
|
|
|
protected:
|
2018-10-16 15:12:19 +08:00
|
|
|
TestMasterCoordination coordination_;
|
2018-02-28 23:02:45 +08:00
|
|
|
std::experimental::optional<communication::rpc::ClientPool>
|
|
|
|
master_client_pool_;
|
2018-01-16 17:09:15 +08:00
|
|
|
std::experimental::optional<storage::MasterConcurrentIdMapper<TId>>
|
|
|
|
master_mapper_;
|
|
|
|
std::experimental::optional<storage::WorkerConcurrentIdMapper<TId>>
|
|
|
|
worker_mapper_;
|
2017-12-15 17:48:21 +08:00
|
|
|
|
|
|
|
void SetUp() override {
|
2018-10-16 18:14:48 +08:00
|
|
|
master_mapper_.emplace(&coordination_);
|
2018-10-16 16:58:41 +08:00
|
|
|
coordination_.Start();
|
2018-10-16 15:12:19 +08:00
|
|
|
master_client_pool_.emplace(coordination_.GetServerEndpoint());
|
|
|
|
worker_mapper_.emplace(&master_client_pool_.value());
|
2017-12-15 17:48:21 +08:00
|
|
|
}
|
|
|
|
void TearDown() override {
|
|
|
|
worker_mapper_ = std::experimental::nullopt;
|
2018-02-28 23:02:45 +08:00
|
|
|
master_client_pool_ = std::experimental::nullopt;
|
2018-10-16 15:12:19 +08:00
|
|
|
coordination_.Stop();
|
2018-10-16 18:14:48 +08:00
|
|
|
master_mapper_ = std::experimental::nullopt;
|
2017-12-15 17:48:21 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2018-01-16 17:09:15 +08:00
|
|
|
typedef ::testing::Types<storage::Label, storage::EdgeType, storage::Property>
|
|
|
|
GraphDbTestTypes;
|
2017-12-15 17:48:21 +08:00
|
|
|
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");
|
2018-01-10 20:56:12 +08:00
|
|
|
EXPECT_EQ(master.value_to_id("v2"), id2);
|
2017-12-15 17:48:21 +08:00
|
|
|
|
|
|
|
EXPECT_NE(id1, id2);
|
|
|
|
}
|