RATIS-2008. Follower should recognize candidate if the candidate is the same peer as the current valid leader (#1024)
diff --git a/ratis-server/src/main/java/org/apache/ratis/server/impl/VoteContext.java b/ratis-server/src/main/java/org/apache/ratis/server/impl/VoteContext.java
index 6375d65..3ba0c0e 100644
--- a/ratis-server/src/main/java/org/apache/ratis/server/impl/VoteContext.java
+++ b/ratis-server/src/main/java/org/apache/ratis/server/impl/VoteContext.java
@@ -102,8 +102,10 @@
if (info.isFollower()) {
final RaftPeerId leader = impl.getState().getLeaderId();
if (leader != null
+ && !leader.equals(candidateId)
&& impl.getRole().getFollowerState().map(FollowerState::isCurrentLeaderValid).orElse(false)) {
- return reject("this server is a follower and still has a valid leader " + leader);
+ return reject("this server is a follower and still has a valid leader " + leader
+ + " different than the candidate " + candidateId);
}
}
return true;