2024-03-05 15:33:13 +08:00
|
|
|
// Copyright 2024 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.
|
|
|
|
|
2024-03-21 14:41:26 +08:00
|
|
|
#include "coordination/coordinator_communication_config.hpp"
|
|
|
|
#include "io/network/endpoint.hpp"
|
2024-03-05 15:33:13 +08:00
|
|
|
#include "nuraft/coordinator_state_machine.hpp"
|
|
|
|
#include "nuraft/raft_log_action.hpp"
|
|
|
|
#include "utils/file.hpp"
|
|
|
|
#include "utils/uuid.hpp"
|
|
|
|
|
|
|
|
#include <gflags/gflags.h>
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
#include "json/json.hpp"
|
|
|
|
|
|
|
|
using memgraph::coordination::CoordinatorStateMachine;
|
2024-03-21 14:41:26 +08:00
|
|
|
using memgraph::coordination::CoordinatorToReplicaConfig;
|
2024-03-05 15:33:13 +08:00
|
|
|
using memgraph::coordination::RaftLogAction;
|
2024-03-21 14:41:26 +08:00
|
|
|
using memgraph::coordination::ReplicationClientInfo;
|
|
|
|
using memgraph::io::network::Endpoint;
|
2024-03-05 15:33:13 +08:00
|
|
|
using memgraph::replication_coordination_glue::ReplicationMode;
|
|
|
|
using memgraph::utils::UUID;
|
|
|
|
|
|
|
|
class RaftLogSerialization : public ::testing::Test {
|
|
|
|
protected:
|
|
|
|
void SetUp() override {}
|
|
|
|
|
|
|
|
void TearDown() override {}
|
|
|
|
|
|
|
|
std::filesystem::path test_folder_{std::filesystem::temp_directory_path() / "MG_tests_unit_raft_log_serialization"};
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(RaftLogSerialization, ReplClientInfo) {
|
2024-03-21 14:41:26 +08:00
|
|
|
ReplicationClientInfo info{.instance_name = "instance_name",
|
|
|
|
.replication_mode = ReplicationMode::SYNC,
|
|
|
|
.replication_server = Endpoint{"127.0.0.1", 10111}};
|
2024-03-05 15:33:13 +08:00
|
|
|
|
|
|
|
nlohmann::json j = info;
|
2024-03-21 14:41:26 +08:00
|
|
|
ReplicationClientInfo info2 = j.get<memgraph::coordination::ReplicationClientInfo>();
|
2024-03-05 15:33:13 +08:00
|
|
|
|
|
|
|
ASSERT_EQ(info, info2);
|
|
|
|
}
|
|
|
|
|
2024-03-21 14:41:26 +08:00
|
|
|
TEST_F(RaftLogSerialization, CoordinatorToReplicaConfig) {
|
|
|
|
CoordinatorToReplicaConfig config{.instance_name = "instance3",
|
|
|
|
.mgt_server = Endpoint{"127.0.0.1", 10112},
|
|
|
|
.replication_client_info = {.instance_name = "instance_name",
|
|
|
|
.replication_mode = ReplicationMode::ASYNC,
|
|
|
|
.replication_server = Endpoint{"127.0.0.1", 10001}},
|
|
|
|
.instance_health_check_frequency_sec = std::chrono::seconds{1},
|
|
|
|
.instance_down_timeout_sec = std::chrono::seconds{5},
|
|
|
|
.instance_get_uuid_frequency_sec = std::chrono::seconds{10},
|
|
|
|
.ssl = std::nullopt};
|
2024-03-05 15:33:13 +08:00
|
|
|
|
|
|
|
nlohmann::json j = config;
|
2024-03-21 14:41:26 +08:00
|
|
|
CoordinatorToReplicaConfig config2 = j.get<memgraph::coordination::CoordinatorToReplicaConfig>();
|
2024-03-05 15:33:13 +08:00
|
|
|
|
|
|
|
ASSERT_EQ(config, config2);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(RaftLogSerialization, RaftLogActionRegister) {
|
|
|
|
auto action = RaftLogAction::REGISTER_REPLICATION_INSTANCE;
|
|
|
|
|
|
|
|
nlohmann::json j = action;
|
|
|
|
RaftLogAction action2 = j.get<memgraph::coordination::RaftLogAction>();
|
|
|
|
|
|
|
|
ASSERT_EQ(action, action2);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(RaftLogSerialization, RaftLogActionUnregister) {
|
|
|
|
auto action = RaftLogAction::UNREGISTER_REPLICATION_INSTANCE;
|
|
|
|
|
|
|
|
nlohmann::json j = action;
|
|
|
|
RaftLogAction action2 = j.get<memgraph::coordination::RaftLogAction>();
|
|
|
|
|
|
|
|
ASSERT_EQ(action, action2);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(RaftLogSerialization, RaftLogActionPromote) {
|
|
|
|
auto action = RaftLogAction::SET_INSTANCE_AS_MAIN;
|
|
|
|
|
|
|
|
nlohmann::json j = action;
|
|
|
|
RaftLogAction action2 = j.get<memgraph::coordination::RaftLogAction>();
|
|
|
|
|
|
|
|
ASSERT_EQ(action, action2);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(RaftLogSerialization, RaftLogActionDemote) {
|
|
|
|
auto action = RaftLogAction::SET_INSTANCE_AS_REPLICA;
|
|
|
|
|
|
|
|
nlohmann::json j = action;
|
|
|
|
RaftLogAction action2 = j.get<memgraph::coordination::RaftLogAction>();
|
|
|
|
|
|
|
|
ASSERT_EQ(action, action2);
|
|
|
|
}
|
|
|
|
|
2024-03-22 19:34:33 +08:00
|
|
|
TEST_F(RaftLogSerialization, RaftLogActionUpdateUUIDForInstance) {
|
|
|
|
auto action = RaftLogAction::UPDATE_UUID_FOR_INSTANCE;
|
2024-03-05 15:33:13 +08:00
|
|
|
|
|
|
|
nlohmann::json j = action;
|
|
|
|
RaftLogAction action2 = j.get<memgraph::coordination::RaftLogAction>();
|
|
|
|
|
|
|
|
ASSERT_EQ(action, action2);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(RaftLogSerialization, RegisterInstance) {
|
2024-03-21 14:41:26 +08:00
|
|
|
CoordinatorToReplicaConfig config{.instance_name = "instance3",
|
|
|
|
.mgt_server = Endpoint{"127.0.0.1", 10112},
|
|
|
|
.replication_client_info = {.instance_name = "instance_name",
|
|
|
|
.replication_mode = ReplicationMode::ASYNC,
|
|
|
|
.replication_server = Endpoint{"127.0.0.1", 10001}},
|
|
|
|
.instance_health_check_frequency_sec = std::chrono::seconds{1},
|
|
|
|
.instance_down_timeout_sec = std::chrono::seconds{5},
|
|
|
|
.instance_get_uuid_frequency_sec = std::chrono::seconds{10},
|
|
|
|
.ssl = std::nullopt};
|
2024-03-05 15:33:13 +08:00
|
|
|
|
|
|
|
auto buffer = CoordinatorStateMachine::SerializeRegisterInstance(config);
|
|
|
|
auto [payload, action] = CoordinatorStateMachine::DecodeLog(*buffer);
|
|
|
|
ASSERT_EQ(action, RaftLogAction::REGISTER_REPLICATION_INSTANCE);
|
2024-03-21 14:41:26 +08:00
|
|
|
ASSERT_EQ(config, std::get<CoordinatorToReplicaConfig>(payload));
|
2024-03-05 15:33:13 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(RaftLogSerialization, UnregisterInstance) {
|
|
|
|
auto buffer = CoordinatorStateMachine::SerializeUnregisterInstance("instance3");
|
|
|
|
auto [payload, action] = CoordinatorStateMachine::DecodeLog(*buffer);
|
|
|
|
ASSERT_EQ(action, RaftLogAction::UNREGISTER_REPLICATION_INSTANCE);
|
|
|
|
ASSERT_EQ("instance3", std::get<std::string>(payload));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(RaftLogSerialization, SetInstanceAsMain) {
|
2024-03-22 19:34:33 +08:00
|
|
|
auto instance_uuid_update =
|
|
|
|
memgraph::coordination::InstanceUUIDUpdate{.instance_name = "instance3", .uuid = memgraph::utils::UUID{}};
|
|
|
|
auto buffer = CoordinatorStateMachine::SerializeSetInstanceAsMain(instance_uuid_update);
|
2024-03-05 15:33:13 +08:00
|
|
|
auto [payload, action] = CoordinatorStateMachine::DecodeLog(*buffer);
|
|
|
|
ASSERT_EQ(action, RaftLogAction::SET_INSTANCE_AS_MAIN);
|
2024-03-22 19:34:33 +08:00
|
|
|
ASSERT_EQ(instance_uuid_update.instance_name,
|
|
|
|
std::get<memgraph::coordination::InstanceUUIDUpdate>(payload).instance_name);
|
|
|
|
ASSERT_EQ(instance_uuid_update.uuid, std::get<memgraph::coordination::InstanceUUIDUpdate>(payload).uuid);
|
2024-03-05 15:33:13 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(RaftLogSerialization, SetInstanceAsReplica) {
|
|
|
|
auto buffer = CoordinatorStateMachine::SerializeSetInstanceAsReplica("instance3");
|
|
|
|
auto [payload, action] = CoordinatorStateMachine::DecodeLog(*buffer);
|
|
|
|
ASSERT_EQ(action, RaftLogAction::SET_INSTANCE_AS_REPLICA);
|
|
|
|
ASSERT_EQ("instance3", std::get<std::string>(payload));
|
|
|
|
}
|
|
|
|
|
2024-03-22 19:34:33 +08:00
|
|
|
TEST_F(RaftLogSerialization, UpdateUUIDForNewMain) {
|
2024-03-05 15:33:13 +08:00
|
|
|
UUID uuid;
|
2024-03-22 19:34:33 +08:00
|
|
|
auto buffer = CoordinatorStateMachine::SerializeUpdateUUIDForNewMain(uuid);
|
2024-03-05 15:33:13 +08:00
|
|
|
auto [payload, action] = CoordinatorStateMachine::DecodeLog(*buffer);
|
2024-03-22 19:34:33 +08:00
|
|
|
ASSERT_EQ(action, RaftLogAction::UPDATE_UUID_OF_NEW_MAIN);
|
2024-03-05 15:33:13 +08:00
|
|
|
ASSERT_EQ(uuid, std::get<UUID>(payload));
|
|
|
|
}
|