mirror of
https://github.com/scylladb/scylladb.git
synced 2026-05-31 20:16:43 +00:00
raft: add some precondition checks
Check that fsm does not process messages from itself and that it does not tries to become its own follower.
This commit is contained in:
@@ -160,6 +160,9 @@ void fsm::become_leader() {
|
||||
}
|
||||
|
||||
void fsm::become_follower(server_id leader) {
|
||||
if (leader == _my_id) {
|
||||
on_internal_error(logger, "fsm cannot become a follower of itself");
|
||||
}
|
||||
_current_leader = leader;
|
||||
_state = follower{};
|
||||
if (_current_leader) {
|
||||
|
||||
@@ -457,6 +457,9 @@ void fsm::step(server_id from, const follower& c, Message&& msg) {
|
||||
|
||||
template <typename Message>
|
||||
void fsm::step(server_id from, Message&& msg) {
|
||||
if (from == _my_id) {
|
||||
on_internal_error(logger, "fsm cannot process messages from itself");
|
||||
}
|
||||
static_assert(std::is_rvalue_reference<decltype(msg)>::value, "must be rvalue");
|
||||
// 4.1. Safety
|
||||
// Servers process incoming RPC requests without consulting
|
||||
|
||||
Reference in New Issue
Block a user