Skip to content

Commit

Permalink
Only candidates read requestvote responses
Browse files Browse the repository at this point in the history
  • Loading branch information
willemt committed Nov 18, 2015
1 parent 763799c commit 72e8f24
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 2 deletions.
3 changes: 2 additions & 1 deletion src/raft_server.c
Original file line number Diff line number Diff line change
Expand Up @@ -116,6 +116,7 @@ void raft_become_candidate(raft_server_t* me_)
raft_set_state(me_, RAFT_STATE_CANDIDATE);

/* we need a random factor here to prevent simultaneous candidates */
/* TODO: this should probably be lower */
me->timeout_elapsed = rand() % me->election_timeout;

for (i = 0; i < me->num_nodes; i++)
Expand Down Expand Up @@ -454,7 +455,7 @@ int raft_recv_requestvote_response(raft_server_t* me_,
__log(me_, "node responded to requestvote: %d status: %s",
node, r->vote_granted == 1 ? "granted" : "not granted");

if (raft_is_leader(me_))
if (!raft_is_candidate(me_))
return 0;

assert(node < me->num_nodes);
Expand Down
24 changes: 23 additions & 1 deletion tests/test_server.c
Original file line number Diff line number Diff line change
Expand Up @@ -444,6 +444,8 @@ void TestRaft_server_recv_requestvote_response_increase_votes_for_me(
raft_set_current_term(r, 1);
CuAssertTrue(tc, 0 == raft_get_nvotes_for_me(r));

raft_become_candidate(r);

msg_requestvote_response_t rvr;
memset(&rvr, 0, sizeof(msg_requestvote_response_t));
rvr.term = 1;
Expand All @@ -452,6 +454,26 @@ void TestRaft_server_recv_requestvote_response_increase_votes_for_me(
CuAssertTrue(tc, 1 == raft_get_nvotes_for_me(r));
}

void TestRaft_server_recv_requestvote_response_must_be_candidate_to_receive(
CuTest * tc
)
{
void *r = raft_new();
raft_add_node(r, (void*)1, 1);
raft_add_node(r, (void*)2, 0);
raft_set_current_term(r, 1);
CuAssertTrue(tc, 0 == raft_get_nvotes_for_me(r));

raft_become_leader(r);

msg_requestvote_response_t rvr;
memset(&rvr, 0, sizeof(msg_requestvote_response_t));
rvr.term = 1;
rvr.vote_granted = 1;
raft_recv_requestvote_response(r, 1, &rvr);
CuAssertTrue(tc, 0 == raft_get_nvotes_for_me(r));
}

/* Reply false if term < currentTerm (§5.1) */
void TestRaft_server_recv_requestvote_reply_false_if_term_less_than_current_term(
CuTest * tc
Expand Down Expand Up @@ -1168,7 +1190,7 @@ void TestRaft_follower_becoming_candidate_resets_election_timeout(CuTest * tc)

raft_become_candidate(r);
/* time is selected randomly */
CuAssertTrue(tc, raft_get_timeout_elapsed(r) < 900);
CuAssertTrue(tc, raft_get_timeout_elapsed(r) < 1000);
}

void TestRaft_follower_recv_appendentries_resets_election_timeout(
Expand Down

0 comments on commit 72e8f24

Please sign in to comment.