[DEBUG] [02/15/2025 10:27:34.521] [main] [EventStream(pekko://test)] logger log1-TestEventListener started 10:27:34,522 AM [test-pekko.actor.default-dispatcher-5] [INFO] Slf4jLogger - Slf4jLogger started [DEBUG] [02/15/2025 10:27:34.522] [main] [EventStream(pekko://test)] logger log2-Slf4jLogger started [DEBUG] [02/15/2025 10:27:34.522] [main] [EventStream(pekko://test)] Default Loggers started [INFO] [02/15/2025 10:27:34.533] [main] [ArteryTransport(pekko://test)] Remoting started with transport [Artery tcp]; listening on address [pekko://test@10.30.170.64:17355] with UID [-8972197948173532008] 10:27:34,534 AM [test-pekko.actor.default-dispatcher-6] [INFO] ArteryTransport - Remoting started with transport [Artery tcp]; listening on address [pekko://test@10.30.170.64:17355] with UID [-8972197948173532008] [INFO] [02/15/2025 10:27:34.534] [main] [Cluster(pekko://test)] Cluster Node [pekko://test@10.30.170.64:17355] - Starting up, Pekko version [1.0.3] ... 10:27:34,534 AM [test-pekko.actor.default-dispatcher-5] [INFO] Cluster - Cluster Node [pekko://test@10.30.170.64:17355] - Starting up, Pekko version [1.0.3] ... [INFO] [02/15/2025 10:27:34.537] [main] [Cluster(pekko://test)] Cluster Node [pekko://test@10.30.170.64:17355] - Registered cluster JMX MBean [pekko:type=Cluster] [INFO] [02/15/2025 10:27:34.537] [main] [Cluster(pekko://test)] Cluster Node [pekko://test@10.30.170.64:17355] - Started up successfully 10:27:34,537 AM [test-pekko.actor.default-dispatcher-6] [INFO] Cluster - Cluster Node [pekko://test@10.30.170.64:17355] - Registered cluster JMX MBean [pekko:type=Cluster] 10:27:34,537 AM [test-pekko.actor.default-dispatcher-6] [INFO] Cluster - Cluster Node [pekko://test@10.30.170.64:17355] - Started up successfully [INFO] [02/15/2025 10:27:34.538] [test-pekko.actor.internal-dispatcher-2] [Cluster(pekko://test)] Cluster Node [pekko://test@10.30.170.64:17355] - No downing-provider-class configured, manual cluster downing required, see https://pekko.apache.org/docs/pekko/current/typed/cluster.html#downing [INFO] [02/15/2025 10:27:34.538] [test-pekko.actor.internal-dispatcher-2] [Cluster(pekko://test)] Cluster Node [pekko://test@10.30.170.64:17355] - No seed-nodes configured, manual cluster join required, see https://pekko.apache.org/docs/pekko/current/typed/cluster.html#joining 10:27:34,538 AM [test-pekko.actor.default-dispatcher-5] [INFO] Cluster - Cluster Node [pekko://test@10.30.170.64:17355] - No downing-provider-class configured, manual cluster downing required, see https://pekko.apache.org/docs/pekko/current/typed/cluster.html#downing 10:27:34,538 AM [test-pekko.actor.default-dispatcher-5] [INFO] Cluster - Cluster Node [pekko://test@10.30.170.64:17355] - No seed-nodes configured, manual cluster join required, see https://pekko.apache.org/docs/pekko/current/typed/cluster.html#joining 10:27:34,550 AM [main] [INFO] NonVotingFollowerIntegrationTest - testFollowerLeaderStateChanges [WARN] [02/15/2025 10:27:34.552] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/follower85]: org.opendaylight.controller.cluster.common.actor.Monitor@ebe774d 10:27:34,555 AM [test-pekko.actor.default-dispatcher-6] [INFO] RaftActor - follower85: Starting recovery with journal batch size 1000 [INFO] [pekkoDeadLetter][02/15/2025 10:27:34.555] [test-pekko.actor.default-dispatcher-6] [pekko://test/user/termination-monitor] Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/follower85] to Actor[pekko://test/user/termination-monitor] was not delivered. [1] dead letters encountered. If this is not an expected behavior then Actor[pekko://test/user/termination-monitor] may have terminated unexpectedly. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 10:27:34,555 AM [test-pekko.actor.default-dispatcher-6] [INFO] EmptyLocalActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/follower85] to Actor[pekko://test/user/termination-monitor] was not delivered. [1] dead letters encountered. If this is not an expected behavior then Actor[pekko://test/user/termination-monitor] may have terminated unexpectedly. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 10:27:34,557 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest13303268626842841898/follower85/TermInfo.properties does not exist java.nio.file.NoSuchFileException: /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest13303268626842841898/follower85/TermInfo.properties at java.base/sun.nio.fs.UnixException.translateToIOException(UnixException.java:92) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:106) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:111) at java.base/sun.nio.fs.UnixFileSystemProvider.newByteChannel(UnixFileSystemProvider.java:261) at java.base/java.nio.file.Files.newByteChannel(Files.java:379) at java.base/java.nio.file.Files.newByteChannel(Files.java:431) at java.base/java.nio.file.spi.FileSystemProvider.newInputStream(FileSystemProvider.java:420) at java.base/java.nio.file.Files.newInputStream(Files.java:159) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadFile(PropertiesTermInfoStore.java:108) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadAndSetTerm(PropertiesTermInfoStore.java:78) at org.opendaylight.controller.cluster.raft.RaftActorRecoverySupport.(RaftActorRecoverySupport.java:62) at org.opendaylight.controller.cluster.raft.RaftActor.newRaftActorRecoverySupport(RaftActor.java:181) at org.opendaylight.controller.cluster.raft.MockRaftActor.newRaftActorRecoverySupport(MockRaftActor.java:85) at org.opendaylight.controller.cluster.raft.RaftActor.handleRecover(RaftActor.java:166) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:33) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:29) at scala.PartialFunction.applyOrElse(PartialFunction.scala:214) at scala.PartialFunction.applyOrElse$(PartialFunction.scala:213) at org.apache.pekko.japi.pf.UnitCaseStatement.applyOrElse(CaseStatements.scala:29) at scala.PartialFunction$OrElse.apply(PartialFunction.scala:266) at org.apache.pekko.persistence.Eventsourced$$anon$2$$anonfun$1.applyOrElse(Eventsourced.scala:651) at org.apache.pekko.actor.Actor.aroundReceive(Actor.scala:547) at org.apache.pekko.actor.Actor.aroundReceive$(Actor.scala:545) at org.apache.pekko.persistence.AbstractPersistentActor.org$apache$pekko$persistence$Eventsourced$$super$aroundReceive(PersistentActor.scala:305) at org.apache.pekko.persistence.Eventsourced$$anon$3.stateReceive(Eventsourced.scala:769) at org.apache.pekko.persistence.Eventsourced.aroundReceive(Eventsourced.scala:256) at org.apache.pekko.persistence.Eventsourced.aroundReceive$(Eventsourced.scala:255) at org.apache.pekko.persistence.AbstractPersistentActor.aroundReceive(PersistentActor.scala:305) at org.apache.pekko.actor.ActorCell.receiveMessage(ActorCell.scala:590) at org.apache.pekko.actor.ActorCell.invoke(ActorCell.scala:557) at org.apache.pekko.dispatch.Mailbox.processMailbox(Mailbox.scala:280) at org.apache.pekko.dispatch.Mailbox.run(Mailbox.scala:241) at org.apache.pekko.dispatch.Mailbox.exec(Mailbox.scala:253) at java.base/java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:387) at java.base/java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1312) at java.base/java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1843) at java.base/java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1808) at java.base/java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:188) 10:27:34,558 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower85: Set currentTerm=1, votedFor=leader84 10:27:34,558 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorRecoverySupport - follower85: Received ReplicatedLogEntry for recovery: index: 0, size: 141 10:27:34,558 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorContextImpl - follower85: Updated server config: isVoting: false, peers: [PeerInfo [id=leader84, address=pekko://test/user/leader84, votingState=VOTING]] 10:27:34,558 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActorRecoverySupport - follower85: Recovery completed - Switching actor to Follower - last log index = -1, last log term = -1, snapshot index = -1, snapshot term = -1, journal size = 0 10:27:34,561 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower85: Set currentTerm=1, votedFor=leader84 10:27:34,561 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActorRecoverySupport - follower85: Local TermInfo store seeded with TermInfo{term=1, votedFor=leader84} [WARN] [02/15/2025 10:27:34.654] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader84]: org.opendaylight.controller.cluster.common.actor.Monitor@4361edfd [INFO] [pekkoDeadLetter][02/15/2025 10:27:34.654] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/leader84] to Actor[pekko://test/user/termination-monitor] was not delivered. [2] dead letters encountered. If this is not an expected behavior then Actor[pekko://test/user/termination-monitor] may have terminated unexpectedly. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 10:27:34,654 AM [test-pekko.actor.default-dispatcher-5] [INFO] EmptyLocalActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/leader84] to Actor[pekko://test/user/termination-monitor] was not delivered. [2] dead letters encountered. If this is not an expected behavior then Actor[pekko://test/user/termination-monitor] may have terminated unexpectedly. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 10:27:34,655 AM [test-pekko.actor.default-dispatcher-11] [INFO] RaftActor - leader84: Starting recovery with journal batch size 1000 10:27:34,657 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] PropertiesTermInfoStore - /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest13303268626842841898/leader84/TermInfo.properties does not exist java.nio.file.NoSuchFileException: /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest13303268626842841898/leader84/TermInfo.properties at java.base/sun.nio.fs.UnixException.translateToIOException(UnixException.java:92) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:106) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:111) at java.base/sun.nio.fs.UnixFileSystemProvider.newByteChannel(UnixFileSystemProvider.java:261) at java.base/java.nio.file.Files.newByteChannel(Files.java:379) at java.base/java.nio.file.Files.newByteChannel(Files.java:431) at java.base/java.nio.file.spi.FileSystemProvider.newInputStream(FileSystemProvider.java:420) at java.base/java.nio.file.Files.newInputStream(Files.java:159) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadFile(PropertiesTermInfoStore.java:108) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadAndSetTerm(PropertiesTermInfoStore.java:78) at org.opendaylight.controller.cluster.raft.RaftActorRecoverySupport.(RaftActorRecoverySupport.java:62) at org.opendaylight.controller.cluster.raft.RaftActor.newRaftActorRecoverySupport(RaftActor.java:181) at org.opendaylight.controller.cluster.raft.MockRaftActor.newRaftActorRecoverySupport(MockRaftActor.java:85) at org.opendaylight.controller.cluster.raft.RaftActor.handleRecover(RaftActor.java:166) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:33) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:29) at scala.PartialFunction.applyOrElse(PartialFunction.scala:214) at scala.PartialFunction.applyOrElse$(PartialFunction.scala:213) at org.apache.pekko.japi.pf.UnitCaseStatement.applyOrElse(CaseStatements.scala:29) at scala.PartialFunction$OrElse.apply(PartialFunction.scala:266) at org.apache.pekko.persistence.Eventsourced$$anon$2$$anonfun$1.applyOrElse(Eventsourced.scala:651) at org.apache.pekko.actor.Actor.aroundReceive(Actor.scala:547) at org.apache.pekko.actor.Actor.aroundReceive$(Actor.scala:545) at org.apache.pekko.persistence.AbstractPersistentActor.org$apache$pekko$persistence$Eventsourced$$super$aroundReceive(PersistentActor.scala:305) at org.apache.pekko.persistence.Eventsourced$$anon$3.stateReceive(Eventsourced.scala:769) at org.apache.pekko.persistence.Eventsourced.aroundReceive(Eventsourced.scala:256) at org.apache.pekko.persistence.Eventsourced.aroundReceive$(Eventsourced.scala:255) at org.apache.pekko.persistence.AbstractPersistentActor.aroundReceive(PersistentActor.scala:305) at org.apache.pekko.actor.ActorCell.receiveMessage(ActorCell.scala:590) at org.apache.pekko.actor.ActorCell.invoke(ActorCell.scala:557) at org.apache.pekko.dispatch.Mailbox.processMailbox(Mailbox.scala:280) at org.apache.pekko.dispatch.Mailbox.run(Mailbox.scala:241) at org.apache.pekko.dispatch.Mailbox.exec(Mailbox.scala:253) at java.base/java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:387) at java.base/java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1312) at java.base/java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1843) at java.base/java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1808) at java.base/java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:188) 10:27:34,657 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] PropertiesTermInfoStore - leader84: Set currentTerm=1, votedFor=leader84 10:27:34,657 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActorRecoverySupport - leader84: Received ReplicatedLogEntry for recovery: index: 0, size: 141 10:27:34,657 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActorContextImpl - leader84: Updated server config: isVoting: true, peers: [PeerInfo [id=follower85, address=pekko://test/user/follower85, votingState=NON_VOTING]] 10:27:34,657 AM [test-pekko.actor.default-dispatcher-11] [INFO] RaftActorRecoverySupport - leader84: Recovery completed - Switching actor to Follower - last log index = -1, last log term = -1, snapshot index = -1, snapshot term = -1, journal size = 0 10:27:34,662 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] PropertiesTermInfoStore - leader84: Set currentTerm=1, votedFor=leader84 10:27:34,662 AM [test-pekko.actor.default-dispatcher-11] [INFO] RaftActorRecoverySupport - leader84: Local TermInfo store seeded with TermInfo{term=1, votedFor=leader84} 10:27:35,124 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] DefaultConfigParamsImpl - No custom RaftPolicy specified. Using DefaultRaftPolicy 10:27:35,124 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - leader84 (Follower): Checking if this node is isolated in the cluster unreachable set [],all members [] self member: Member(pekko://test@10.30.170.64:17355, Removed) 10:27:35,124 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - leader84 (Follower): Received ElectionTimeout - switching to Candidate 10:27:35,124 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Candidate - leader84 (Candidate): Election: Candidate has following voting peers: [] 10:27:35,128 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] PropertiesTermInfoStore - leader84: Set currentTerm=2, votedFor=leader84 10:27:35,128 AM [test-pekko.actor.default-dispatcher-11] [INFO] Candidate - leader84 (Candidate): Starting new election term 2 10:27:35,128 AM [test-pekko.actor.default-dispatcher-11] [INFO] RaftActorBehavior - leader84 (Follower) :- Switching from behavior Follower to Candidate, election term: 2 10:27:35,128 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Candidate - leader84 (Candidate): Received ElectionTimeout 10:27:35,128 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader84 (Leader): Election: Leader has following peers: [follower85] 10:27:35,129 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader84 (Leader): Checking sendAppendEntries for follower follower85: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 10:27:35,129 AM [test-pekko.actor.default-dispatcher-11] [INFO] RaftActorBehavior - leader84 (Candidate) :- Switching from behavior Candidate to Leader, election term: 2 10:27:35,129 AM [test-pekko.actor.default-dispatcher-11] [INFO] Follower - follower85 (Follower): Term 2 in "AppendEntries{term=2, leaderId=leader84, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 1 - updating term 10:27:35,132 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] PropertiesTermInfoStore - follower85: Set currentTerm=2, votedFor=null 10:27:35,133 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] SyncStatusTracker - follower85: Last sync leader does not match current leader leader84, need to catch up to -1 10:27:35,133 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader84 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower85 updated: matchIndex: -1, nextIndex: 0 10:27:35,133 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader84 (Leader): Checking sendAppendEntries for follower follower85: active: true, followerNextIndex: 0, leaderLastIndex: -1, leaderSnapShotIndex: -1 [WARN] [02/15/2025 10:27:35.133] [test-pekko.actor.default-dispatcher-11] [pekko://test/user/follower85] unhandled message from Actor[pekko://test/deadLetters]: org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus@74bd0587 [INFO] [pekkoDeadLetter][02/15/2025 10:27:35.133] [test-pekko.actor.default-dispatcher-11] [pekko://test/user/follower85] Message [org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus] to TestActor[pekko://test/user/follower85] was unhandled. [3] dead letters encountered. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 10:27:35,134 AM [test-pekko.actor.default-dispatcher-11] [INFO] TestActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus] to TestActor[pekko://test/user/follower85] was unhandled. [3] dead letters encountered. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 10:27:35,172 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] DefaultConfigParamsImpl - No custom RaftPolicy specified. Using DefaultRaftPolicy 10:27:35,484 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SyncStatusTracker - follower85: Lagging 0 entries behind leader leader84 and reached -1 (of expected -1) 10:27:35,485 AM [test-pekko.actor.default-dispatcher-11] [INFO] TestActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus] to TestActor[pekko://test/user/follower85] was unhandled. [4] dead letters encountered. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. [WARN] [02/15/2025 10:27:35.485] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/follower85] unhandled message from Actor[pekko://test/deadLetters]: org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus@754b4460 [INFO] [pekkoDeadLetter][02/15/2025 10:27:35.484] [test-pekko.actor.default-dispatcher-11] [pekko://test/user/follower85] Message [org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus] to TestActor[pekko://test/user/follower85] was unhandled. [4] dead letters encountered. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 10:27:35,525 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/roleChangeNotifier87#-739440310] 10:27:35,537 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/follower85-collector88#1310867733] 10:27:35,538 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower85] 10:27:35,538 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/leader84-collector89#829653386] 10:27:35,539 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader84] 10:27:35,541 AM [main] [INFO] NonVotingFollowerIntegrationTest - testFollowerResyncWithLessLeaderLogEntriesAfterNonPersistentLeaderRestart starting 10:27:35,544 AM [test-pekko.actor.default-dispatcher-5] [INFO] EmptyLocalActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/follower91] to Actor[pekko://test/user/termination-monitor] was not delivered. [5] dead letters encountered. If this is not an expected behavior then Actor[pekko://test/user/termination-monitor] may have terminated unexpectedly. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. [WARN] [02/15/2025 10:27:35.544] [test-pekko.actor.default-dispatcher-11] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/follower91]: org.opendaylight.controller.cluster.common.actor.Monitor@6cc5cc85 [INFO] [pekkoDeadLetter][02/15/2025 10:27:35.544] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/follower91] to Actor[pekko://test/user/termination-monitor] was not delivered. [5] dead letters encountered. If this is not an expected behavior then Actor[pekko://test/user/termination-monitor] may have terminated unexpectedly. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 10:27:35,545 AM [test-pekko.actor.default-dispatcher-15] [INFO] RaftActor - follower91: Starting recovery with journal batch size 1000 [WARN] [02/15/2025 10:27:35.547] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader90]: org.opendaylight.controller.cluster.common.actor.Monitor@56b70295 10:27:35,547 AM [test-pekko.actor.default-dispatcher-11] [INFO] RaftActor - leader90: Starting recovery with journal batch size 1000 [INFO] [pekkoDeadLetter][02/15/2025 10:27:35.547] [test-pekko.actor.default-dispatcher-14] [pekko://test/user/termination-monitor] Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/leader90] to Actor[pekko://test/user/termination-monitor] was not delivered. [6] dead letters encountered. If this is not an expected behavior then Actor[pekko://test/user/termination-monitor] may have terminated unexpectedly. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 10:27:35,547 AM [test-pekko.actor.default-dispatcher-5] [INFO] EmptyLocalActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/leader90] to Actor[pekko://test/user/termination-monitor] was not delivered. [6] dead letters encountered. If this is not an expected behavior then Actor[pekko://test/user/termination-monitor] may have terminated unexpectedly. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 10:27:35,548 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest4704488771400024289/follower91/TermInfo.properties does not exist java.nio.file.NoSuchFileException: /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest4704488771400024289/follower91/TermInfo.properties at java.base/sun.nio.fs.UnixException.translateToIOException(UnixException.java:92) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:106) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:111) at java.base/sun.nio.fs.UnixFileSystemProvider.newByteChannel(UnixFileSystemProvider.java:261) at java.base/java.nio.file.Files.newByteChannel(Files.java:379) at java.base/java.nio.file.Files.newByteChannel(Files.java:431) at java.base/java.nio.file.spi.FileSystemProvider.newInputStream(FileSystemProvider.java:420) at java.base/java.nio.file.Files.newInputStream(Files.java:159) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadFile(PropertiesTermInfoStore.java:108) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadAndSetTerm(PropertiesTermInfoStore.java:78) at org.opendaylight.controller.cluster.raft.RaftActorRecoverySupport.(RaftActorRecoverySupport.java:62) at org.opendaylight.controller.cluster.raft.RaftActor.newRaftActorRecoverySupport(RaftActor.java:181) at org.opendaylight.controller.cluster.raft.MockRaftActor.newRaftActorRecoverySupport(MockRaftActor.java:85) at org.opendaylight.controller.cluster.raft.RaftActor.handleRecover(RaftActor.java:166) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:33) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:29) at scala.PartialFunction.applyOrElse(PartialFunction.scala:214) at scala.PartialFunction.applyOrElse$(PartialFunction.scala:213) at org.apache.pekko.japi.pf.UnitCaseStatement.applyOrElse(CaseStatements.scala:29) at scala.PartialFunction$OrElse.apply(PartialFunction.scala:266) at org.apache.pekko.persistence.Eventsourced$$anon$2$$anonfun$1.applyOrElse(Eventsourced.scala:651) at org.apache.pekko.actor.Actor.aroundReceive(Actor.scala:547) at org.apache.pekko.actor.Actor.aroundReceive$(Actor.scala:545) at org.apache.pekko.persistence.AbstractPersistentActor.org$apache$pekko$persistence$Eventsourced$$super$aroundReceive(PersistentActor.scala:305) at org.apache.pekko.persistence.Eventsourced$$anon$3.stateReceive(Eventsourced.scala:769) at org.apache.pekko.persistence.Eventsourced.aroundReceive(Eventsourced.scala:256) at org.apache.pekko.persistence.Eventsourced.aroundReceive$(Eventsourced.scala:255) at org.apache.pekko.persistence.AbstractPersistentActor.aroundReceive(PersistentActor.scala:305) at org.apache.pekko.actor.ActorCell.receiveMessage(ActorCell.scala:590) at org.apache.pekko.actor.ActorCell.invoke(ActorCell.scala:557) at org.apache.pekko.dispatch.Mailbox.processMailbox(Mailbox.scala:280) at org.apache.pekko.dispatch.Mailbox.run(Mailbox.scala:241) at org.apache.pekko.dispatch.Mailbox.exec(Mailbox.scala:253) at java.base/java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:387) at java.base/java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1312) at java.base/java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1843) at java.base/java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1808) at java.base/java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:188) 10:27:35,548 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - follower91: Set currentTerm=1, votedFor=leader90 10:27:35,548 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorRecoverySupport - follower91: Received ReplicatedLogEntry for recovery: index: 0, size: 141 10:27:35,548 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorContextImpl - follower91: Updated server config: isVoting: false, peers: [PeerInfo [id=leader90, address=pekko://test/user/leader90, votingState=VOTING]] 10:27:35,548 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActorRecoverySupport - follower91: Recovery completed - Switching actor to Follower - last log index = -1, last log term = -1, snapshot index = -1, snapshot term = -1, journal size = 0 10:27:35,549 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest4704488771400024289/leader90/TermInfo.properties does not exist java.nio.file.NoSuchFileException: /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest4704488771400024289/leader90/TermInfo.properties at java.base/sun.nio.fs.UnixException.translateToIOException(UnixException.java:92) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:106) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:111) at java.base/sun.nio.fs.UnixFileSystemProvider.newByteChannel(UnixFileSystemProvider.java:261) at java.base/java.nio.file.Files.newByteChannel(Files.java:379) at java.base/java.nio.file.Files.newByteChannel(Files.java:431) at java.base/java.nio.file.spi.FileSystemProvider.newInputStream(FileSystemProvider.java:420) at java.base/java.nio.file.Files.newInputStream(Files.java:159) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadFile(PropertiesTermInfoStore.java:108) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadAndSetTerm(PropertiesTermInfoStore.java:78) at org.opendaylight.controller.cluster.raft.RaftActorRecoverySupport.(RaftActorRecoverySupport.java:62) at org.opendaylight.controller.cluster.raft.RaftActor.newRaftActorRecoverySupport(RaftActor.java:181) at org.opendaylight.controller.cluster.raft.MockRaftActor.newRaftActorRecoverySupport(MockRaftActor.java:85) at org.opendaylight.controller.cluster.raft.RaftActor.handleRecover(RaftActor.java:166) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:33) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:29) at scala.PartialFunction.applyOrElse(PartialFunction.scala:214) at scala.PartialFunction.applyOrElse$(PartialFunction.scala:213) at org.apache.pekko.japi.pf.UnitCaseStatement.applyOrElse(CaseStatements.scala:29) at scala.PartialFunction$OrElse.apply(PartialFunction.scala:266) at org.apache.pekko.persistence.Eventsourced$$anon$2$$anonfun$1.applyOrElse(Eventsourced.scala:651) at org.apache.pekko.actor.Actor.aroundReceive(Actor.scala:547) at org.apache.pekko.actor.Actor.aroundReceive$(Actor.scala:545) at org.apache.pekko.persistence.AbstractPersistentActor.org$apache$pekko$persistence$Eventsourced$$super$aroundReceive(PersistentActor.scala:305) at org.apache.pekko.persistence.Eventsourced$$anon$3.stateReceive(Eventsourced.scala:769) at org.apache.pekko.persistence.Eventsourced.aroundReceive(Eventsourced.scala:256) at org.apache.pekko.persistence.Eventsourced.aroundReceive$(Eventsourced.scala:255) at org.apache.pekko.persistence.AbstractPersistentActor.aroundReceive(PersistentActor.scala:305) at org.apache.pekko.actor.ActorCell.receiveMessage(ActorCell.scala:590) at org.apache.pekko.actor.ActorCell.invoke(ActorCell.scala:557) at org.apache.pekko.dispatch.Mailbox.processMailbox(Mailbox.scala:280) at org.apache.pekko.dispatch.Mailbox.run(Mailbox.scala:241) at org.apache.pekko.dispatch.Mailbox.exec(Mailbox.scala:253) at java.base/java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:387) at java.base/java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1312) at java.base/java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1843) at java.base/java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1808) at java.base/java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:188) 10:27:35,550 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - leader90: Set currentTerm=1, votedFor=leader90 10:27:35,550 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorRecoverySupport - leader90: Received ReplicatedLogEntry for recovery: index: 0, size: 141 10:27:35,550 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorContextImpl - leader90: Updated server config: isVoting: true, peers: [PeerInfo [id=follower91, address=pekko://test/user/follower91, votingState=NON_VOTING]] 10:27:35,550 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActorRecoverySupport - leader90: Recovery completed - Switching actor to Follower - last log index = -1, last log term = -1, snapshot index = -1, snapshot term = -1, journal size = 0 10:27:35,551 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - follower91: Set currentTerm=1, votedFor=leader90 10:27:35,551 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActorRecoverySupport - follower91: Local TermInfo store seeded with TermInfo{term=1, votedFor=leader90} 10:27:35,553 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - leader90: Set currentTerm=1, votedFor=leader90 10:27:35,553 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActorRecoverySupport - leader90: Local TermInfo store seeded with TermInfo{term=1, votedFor=leader90} 10:27:36,54 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] DefaultConfigParamsImpl - No custom RaftPolicy specified. Using DefaultRaftPolicy 10:27:36,54 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - leader90 (Follower): Checking if this node is isolated in the cluster unreachable set [],all members [] self member: Member(pekko://test@10.30.170.64:17355, Removed) 10:27:36,54 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - leader90 (Follower): Received ElectionTimeout - switching to Candidate 10:27:36,55 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Candidate - leader90 (Candidate): Election: Candidate has following voting peers: [] 10:27:36,59 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - leader90: Set currentTerm=2, votedFor=leader90 10:27:36,59 AM [test-pekko.actor.default-dispatcher-16] [INFO] Candidate - leader90 (Candidate): Starting new election term 2 10:27:36,59 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActorBehavior - leader90 (Follower) :- Switching from behavior Follower to Candidate, election term: 2 10:27:36,59 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Candidate - leader90 (Candidate): Received ElectionTimeout 10:27:36,59 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader90 (Leader): Election: Leader has following peers: [follower91] 10:27:36,59 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader90 (Leader): Checking sendAppendEntries for follower follower91: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 10:27:36,59 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActorBehavior - leader90 (Candidate) :- Switching from behavior Candidate to Leader, election term: 2 10:27:36,59 AM [test-pekko.actor.default-dispatcher-17] [INFO] Follower - follower91 (Follower): Term 2 in "AppendEntries{term=2, leaderId=leader90, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 1 - updating term 10:27:36,63 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - follower91: Set currentTerm=2, votedFor=null 10:27:36,64 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SyncStatusTracker - follower91: Last sync leader does not match current leader leader90, need to catch up to -1 10:27:36,64 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower91 updated: matchIndex: -1, nextIndex: 0 10:27:36,64 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): Checking sendAppendEntries for follower follower91: active: true, followerNextIndex: 0, leaderLastIndex: -1, leaderSnapShotIndex: -1 [WARN] [02/15/2025 10:27:36.064] [test-pekko.actor.default-dispatcher-17] [pekko://test/user/follower91] unhandled message from Actor[pekko://test/deadLetters]: org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus@1c7bcfa2 [INFO] [pekkoDeadLetter][02/15/2025 10:27:36.064] [test-pekko.actor.default-dispatcher-17] [pekko://test/user/follower91] Message [org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus] to TestActor[pekko://test/user/follower91] was unhandled. [7] dead letters encountered. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 10:27:36,65 AM [test-pekko.actor.default-dispatcher-17] [INFO] TestActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus] to TestActor[pekko://test/user/follower91] was unhandled. [7] dead letters encountered. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 10:27:36,111 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActor - leader90: Persist data SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:36,111 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] ReplicatedLogImpl - leader90: Append log entry and persist SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:36,111 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): Replicate message: identifier: MockIdentifier{value=zero}, logIndex: 0, isSendImmediate: true 10:27:36,111 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorBehavior - leader90 (Leader): Setting last applied to 0 10:27:36,111 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorContextImpl - leader90: Moving last applied index from -1 to 0 10:27:36,111 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActor - leader90: Applying state for log index 0 data zero 10:27:36,112 AM [test-pekko.actor.default-dispatcher-17] [INFO] MockRaftActor - leader90: applyState called: zero 10:27:36,112 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): Checking sendAppendEntries for follower follower91: active: true, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 10:27:36,112 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): sendAppendEntries: 0 is present for follower follower91 10:27:36,112 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): Sending AppendEntries to follower follower91: AppendEntries{term=2, leaderId=leader90, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=2, payload=zero]]} 10:27:36,112 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActor - leader90: Persisting ApplyJournalEntries with index=0 10:27:36,112 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] ReplicatedLogImpl - leader90: persist complete SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:36,112 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=leader90, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=2, payload=zero]]} 10:27:36,112 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): Number of entries to be appended = 1 10:27:36,112 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): After cleanup, lastIndex: -1, entries to be added from: 0 10:27:36,112 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActor - leader90: Persist data SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:36,112 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): Append entry to log zero 10:27:36,112 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] ReplicatedLogImpl - leader90: Append log entry and persist SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:36,112 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower91: Append log entry and persist SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:36,113 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower91: persist complete SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:36,113 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): Replicate message: identifier: MockIdentifier{value=one}, logIndex: 1, isSendImmediate: true 10:27:36,113 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorBehavior - leader90 (Leader): Setting last applied to 1 10:27:36,113 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): Log size is now 1 10:27:36,113 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorContextImpl - leader90: Moving last applied index from 0 to 1 10:27:36,113 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): Commit index set to 0 10:27:36,113 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActor - leader90: Applying state for log index 1 data one 10:27:36,113 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=follower91, logLastIndex=0, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:36,113 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower91: Lagging 0 entries behind leader leader90 and reached 0 (of expected -1) 10:27:36,113 AM [test-pekko.actor.default-dispatcher-17] [INFO] MockRaftActor - leader90: applyState called: one 10:27:36,113 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 0, context.getLastApplied(): -1, lastIndex(): 0 10:27:36,113 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - follower91 (Follower): Setting last applied to 0 10:27:36,113 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorContextImpl - follower91: Moving last applied index from -1 to 0 10:27:36,113 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower91: Applying state for log index 0 data zero 10:27:36,113 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): Checking sendAppendEntries for follower follower91: active: true, followerNextIndex: 0, leaderLastIndex: 1, leaderSnapShotIndex: -1 10:27:36,113 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): sendAppendEntries: 0 is present for follower follower91 10:27:36,113 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): Sending AppendEntries to follower follower91: AppendEntries{term=2, leaderId=leader90, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=2, payload=zero], SimpleReplicatedLogEntry [index=1, term=2, payload=one]]} 10:27:36,113 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - follower91: applyState called: zero 10:27:36,113 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower91 updated: matchIndex: 0, nextIndex: 1 10:27:36,113 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SnapshotManager - leader90: fakeSnapshot purging log to 0 for term 2 10:27:36,113 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): Checking sendAppendEntries for follower follower91: active: true, followerNextIndex: 1, leaderLastIndex: 1, leaderSnapShotIndex: 0 10:27:36,113 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): sendAppendEntries: 1 is present for follower follower91 10:27:36,113 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=leader90, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=2, payload=zero], SimpleReplicatedLogEntry [index=1, term=2, payload=one]]} 10:27:36,113 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): Number of entries to be appended = 2 10:27:36,113 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): Sending AppendEntries to follower follower91: AppendEntries{term=2, leaderId=leader90, prevLogIndex=0, prevLogTerm=2, leaderCommit=1, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=1, term=2, payload=one]]} 10:27:36,113 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): matchEntry SimpleReplicatedLogEntry [index=0, term=2, payload=zero] is present: existingEntryTerm: 2 10:27:36,113 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): After cleanup, lastIndex: 0, entries to be added from: 1 10:27:36,113 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): Append entry to log one 10:27:36,113 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower91: Append log entry and persist SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:36,113 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader90: Persisting ApplyJournalEntries with index=1 10:27:36,114 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - leader90: persist complete SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:36,114 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader90: Persist data SimpleReplicatedLogEntry [index=2, term=2, payload=two] 10:27:36,114 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - leader90: Append log entry and persist SimpleReplicatedLogEntry [index=2, term=2, payload=two] 10:27:36,114 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader90 (Leader): Replicate message: identifier: MockIdentifier{value=two}, logIndex: 2, isSendImmediate: true 10:27:36,114 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorBehavior - leader90 (Leader): Setting last applied to 2 10:27:36,114 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorContextImpl - leader90: Moving last applied index from 1 to 2 10:27:36,114 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader90: Applying state for log index 2 data two 10:27:36,114 AM [test-pekko.actor.default-dispatcher-14] [INFO] MockRaftActor - leader90: applyState called: two 10:27:36,114 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader90 (Leader): Checking sendAppendEntries for follower follower91: active: true, followerNextIndex: 1, leaderLastIndex: 2, leaderSnapShotIndex: 0 10:27:36,114 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader90 (Leader): sendAppendEntries: 1 is present for follower follower91 10:27:36,114 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader90 (Leader): Sending AppendEntries to follower follower91: AppendEntries{term=2, leaderId=leader90, prevLogIndex=0, prevLogTerm=2, leaderCommit=2, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=1, term=2, payload=one], SimpleReplicatedLogEntry [index=2, term=2, payload=two]]} 10:27:36,114 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader90: Persisting ApplyJournalEntries with index=2 10:27:36,114 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower91: persist complete SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:36,114 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - leader90: persist complete SimpleReplicatedLogEntry [index=2, term=2, payload=two] 10:27:36,114 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): Log size is now 2 10:27:36,114 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): Commit index set to 1 10:27:36,114 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=follower91, logLastIndex=1, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower91: Lagging 0 entries behind leader leader90 and reached 1 (of expected -1) 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 1, context.getLastApplied(): 0, lastIndex(): 1 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - follower91 (Follower): Setting last applied to 1 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorContextImpl - follower91: Moving last applied index from 0 to 1 10:27:36,115 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader90 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower91 updated: matchIndex: 1, nextIndex: 2 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower91: Applying state for log index 1 data one 10:27:36,115 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SnapshotManager - leader90: fakeSnapshot purging log to 1 for term 2 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - follower91: applyState called: one 10:27:36,115 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader90 (Leader): Checking sendAppendEntries for follower follower91: active: true, followerNextIndex: 2, leaderLastIndex: 2, leaderSnapShotIndex: 1 10:27:36,115 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader90 (Leader): sendAppendEntries: 2 is present for follower follower91 10:27:36,115 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader90 (Leader): Sending AppendEntries to follower follower91: AppendEntries{term=2, leaderId=leader90, prevLogIndex=1, prevLogTerm=2, leaderCommit=2, replicatedToAllIndex=1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=2, term=2, payload=two]]} 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower91: Persisting ApplyJournalEntries with index=0 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=leader90, prevLogIndex=0, prevLogTerm=2, leaderCommit=1, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=1, term=2, payload=one]]} 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): Number of entries to be appended = 1 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): matchEntry SimpleReplicatedLogEntry [index=1, term=2, payload=one] is present: existingEntryTerm: 2 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): After cleanup, lastIndex: 1, entries to be added from: 1 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): Log size is now 2 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=follower91, logLastIndex=1, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower91: Lagging 0 entries behind leader leader90 and reached 1 (of expected -1) 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - follower91: fakeSnapshot purging log to 0 for term 2 10:27:36,115 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): sendAppendEntries: 2 is present for follower follower91 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=leader90, prevLogIndex=0, prevLogTerm=2, leaderCommit=2, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=1, term=2, payload=one], SimpleReplicatedLogEntry [index=2, term=2, payload=two]]} 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): Number of entries to be appended = 2 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): matchEntry SimpleReplicatedLogEntry [index=1, term=2, payload=one] is present: existingEntryTerm: 2 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): After cleanup, lastIndex: 1, entries to be added from: 1 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): Append entry to log two 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower91: Append log entry and persist SimpleReplicatedLogEntry [index=2, term=2, payload=two] 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower91: persist complete SimpleReplicatedLogEntry [index=2, term=2, payload=two] 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): Log size is now 2 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): Commit index set to 2 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=follower91, logLastIndex=2, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower91: Lagging 0 entries behind leader leader90 and reached 2 (of expected -1) 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 2, context.getLastApplied(): 1, lastIndex(): 2 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - follower91 (Follower): Setting last applied to 2 10:27:36,115 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorContextImpl - follower91: Moving last applied index from 1 to 2 10:27:36,116 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower91: Applying state for log index 2 data two 10:27:36,116 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - follower91: applyState called: two 10:27:36,116 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader90 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower91 updated: matchIndex: 2, nextIndex: 3 10:27:36,116 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower91: Persisting ApplyJournalEntries with index=1 10:27:36,116 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=leader90, prevLogIndex=1, prevLogTerm=2, leaderCommit=2, replicatedToAllIndex=1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=2, term=2, payload=two]]} 10:27:36,116 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader90 (Leader): Checking sendAppendEntries for follower follower91: active: true, followerNextIndex: 3, leaderLastIndex: 2, leaderSnapShotIndex: 1 10:27:36,116 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): Number of entries to be appended = 1 10:27:36,116 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): matchEntry SimpleReplicatedLogEntry [index=2, term=2, payload=two] is present: existingEntryTerm: 2 10:27:36,116 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): After cleanup, lastIndex: 2, entries to be added from: 1 10:27:36,116 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): Log size is now 2 10:27:36,116 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower91 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=follower91, logLastIndex=2, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:36,116 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower91: Lagging 0 entries behind leader leader90 and reached 2 (of expected -1) 10:27:36,116 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - follower91: fakeSnapshot purging log to 1 for term 2 10:27:36,116 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower91: Persisting ApplyJournalEntries with index=2 [WARN] [02/15/2025 10:27:36.116] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/follower91] unhandled message from Actor[pekko://test/deadLetters]: org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus@697dce67 [INFO] [pekkoDeadLetter][02/15/2025 10:27:36.117] [test-pekko.actor.default-dispatcher-18] [pekko://test/user/follower91] Message [org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus] to TestActor[pekko://test/user/follower91] was unhandled. [8] dead letters encountered. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 10:27:36,117 AM [test-pekko.actor.default-dispatcher-11] [INFO] TestActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus] to TestActor[pekko://test/user/follower91] was unhandled. [8] dead letters encountered. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. [WARN] [02/15/2025 10:27:36.176] [test-pekko.actor.default-dispatcher-18] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader90]: org.opendaylight.controller.cluster.common.actor.Monitor@3eb2df7e [INFO] [pekkoDeadLetter][02/15/2025 10:27:36.176] [test-pekko.actor.default-dispatcher-11] [pekko://test/user/termination-monitor] Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/leader90] to Actor[pekko://test/user/termination-monitor] was not delivered. [9] dead letters encountered. If this is not an expected behavior then Actor[pekko://test/user/termination-monitor] may have terminated unexpectedly. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 10:27:36,176 AM [test-pekko.actor.default-dispatcher-11] [INFO] EmptyLocalActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/leader90] to Actor[pekko://test/user/termination-monitor] was not delivered. [9] dead letters encountered. If this is not an expected behavior then Actor[pekko://test/user/termination-monitor] may have terminated unexpectedly. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 10:27:36,177 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActor - leader90: Starting recovery with journal batch size 1000 10:27:36,179 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - leader90: Set currentTerm=2, votedFor=leader90 10:27:36,179 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - leader90: Set currentTerm=1, votedFor=leader90 10:27:36,179 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorRecoverySupport - leader90: Received ReplicatedLogEntry for recovery: index: 0, size: 141 10:27:36,179 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorContextImpl - leader90: Updated server config: isVoting: true, peers: [PeerInfo [id=follower91, address=pekko://test/user/follower91, votingState=NON_VOTING]] 10:27:36,179 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorRecoverySupport - leader90: Recovery completed - Switching actor to Follower - last log index = -1, last log term = -1, snapshot index = -1, snapshot term = -1, journal size = 0 10:27:36,179 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorRecoverySupport - leader90: restoring local TermInfo{term=2, votedFor=leader90} 10:27:36,179 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - leader90: Set currentTerm=2, votedFor=leader90 10:27:36,673 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - leader90 (Follower): Checking if this node is isolated in the cluster unreachable set [],all members [] self member: Member(pekko://test@10.30.170.64:17355, Removed) 10:27:36,673 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - leader90 (Follower): Received ElectionTimeout - switching to Candidate 10:27:36,674 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Candidate - leader90 (Candidate): Election: Candidate has following voting peers: [] 10:27:36,677 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] PropertiesTermInfoStore - leader90: Set currentTerm=3, votedFor=leader90 10:27:36,677 AM [test-pekko.actor.default-dispatcher-11] [INFO] Candidate - leader90 (Candidate): Starting new election term 3 10:27:36,677 AM [test-pekko.actor.default-dispatcher-11] [INFO] RaftActorBehavior - leader90 (Follower) :- Switching from behavior Follower to Candidate, election term: 3 10:27:36,677 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Candidate - leader90 (Candidate): Received ElectionTimeout 10:27:36,678 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader90 (Leader): Election: Leader has following peers: [follower91] 10:27:36,678 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader90 (Leader): Checking sendAppendEntries for follower follower91: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 10:27:36,678 AM [test-pekko.actor.default-dispatcher-11] [INFO] RaftActorBehavior - leader90 (Candidate) :- Switching from behavior Candidate to Leader, election term: 3 10:27:36,684 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActor - leader90: Persist data SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] 10:27:36,684 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] ReplicatedLogImpl - leader90: Append log entry and persist SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] 10:27:36,684 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): Replicate message: identifier: MockIdentifier{value=zero-1}, logIndex: 0, isSendImmediate: true 10:27:36,684 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorBehavior - leader90 (Leader): Setting last applied to 0 10:27:36,684 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorContextImpl - leader90: Moving last applied index from -1 to 0 10:27:36,684 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActor - leader90: Applying state for log index 0 data zero-1 10:27:36,685 AM [test-pekko.actor.default-dispatcher-17] [INFO] MockRaftActor - leader90: applyState called: zero-1 10:27:36,685 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): Checking sendAppendEntries for follower follower91: active: false, followerNextIndex: -1, leaderLastIndex: 0, leaderSnapShotIndex: -1 10:27:36,685 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActor - leader90: Persisting ApplyJournalEntries with index=0 10:27:36,685 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] ReplicatedLogImpl - leader90: persist complete SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] 10:27:36,685 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActor - leader90: Persist data SimpleReplicatedLogEntry [index=1, term=3, payload=one-1] 10:27:36,685 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] ReplicatedLogImpl - leader90: Append log entry and persist SimpleReplicatedLogEntry [index=1, term=3, payload=one-1] 10:27:36,685 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): Replicate message: identifier: MockIdentifier{value=one-1}, logIndex: 1, isSendImmediate: true 10:27:36,685 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorBehavior - leader90 (Leader): Setting last applied to 1 10:27:36,685 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorContextImpl - leader90: Moving last applied index from 0 to 1 10:27:36,685 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActor - leader90: Applying state for log index 1 data one-1 10:27:36,685 AM [test-pekko.actor.default-dispatcher-17] [INFO] MockRaftActor - leader90: applyState called: one-1 10:27:36,685 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader90 (Leader): Checking sendAppendEntries for follower follower91: active: false, followerNextIndex: -1, leaderLastIndex: 1, leaderSnapShotIndex: -1 10:27:36,685 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActor - leader90: Persisting ApplyJournalEntries with index=1 10:27:36,686 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - leader90: persist complete SimpleReplicatedLogEntry [index=1, term=3, payload=one-1] 10:27:36,794 AM [test-pekko.actor.default-dispatcher-17] [INFO] Follower - follower91 (Follower): Term 3 in "AppendEntries{term=3, leaderId=leader90, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 2 - updating term 10:27:36,797 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - follower91: Set currentTerm=3, votedFor=null 10:27:36,797 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SyncStatusTracker - follower91: Lagging -3 entries behind leader leader90 and reached 2 (of expected -1) 10:27:36,797 AM [test-pekko.actor.default-dispatcher-16] [INFO] AbstractLeader - leader90 (Leader): handleAppendEntriesReply: follower follower91 lastIndex 2 is ahead of our lastIndex 1 (snapshotIndex -1, snapshotTerm -1) - forcing install snaphot 10:27:36,797 AM [test-pekko.actor.default-dispatcher-16] [INFO] SnapshotManager - leader90: Initiating snapshot capture CaptureSnapshot [lastAppliedIndex=1, lastAppliedTerm=3, lastIndex=1, lastTerm=3, installSnapshotInitiated=, replicatedToAllIndex=-1, replicatedToAllTerm=-1, unAppliedEntries size=0, mandatoryTrim=false] to install on follower91 10:27:36,797 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - leader90: lastSequenceNumber prior to capture: -1 10:27:36,800 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorSnapshotMessageSupport - leader90: CaptureSnapshotReply received by actor 10:27:36,800 AM [test-pekko.actor.default-dispatcher-16] [INFO] SnapshotManager - leader90: Persisting of snapshot done: Snapshot [lastIndex=1, lastTerm=3, lastAppliedIndex=1, lastAppliedTerm=3, unAppliedEntries size=0, state=MockSnapshotState [state=[zero-1, one-1]], electionTerm=3, electionVotedFor=leader90, ServerConfigPayload=ClusterConfig{serverInfo=[ServerInfo[peerId=follower91, isVoting=false], ServerInfo[peerId=leader90, isVoting=true]]}] 10:27:36,801 AM [test-pekko.actor.default-dispatcher-16] [INFO] SnapshotManager - leader90: Removed in-memory snapshotted entries, adjusted snaphsotIndex: -1 and term: -1 10:27:36,803 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader90 (Leader): sendInstallSnapshot 10:27:36,803 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] LeaderInstallSnapshotState - leader90 (Leader): Snapshot 333 bytes, total chunks to send: 1 10:27:36,803 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] LeaderInstallSnapshotState - leader90 (Leader): Next chunk: total length=333, offset=0, size=333, hashCode=878051978 10:27:36,803 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader90 (Leader): next snapshot chunk size for follower follower91: 333 10:27:36,803 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader90 (Leader): InstallSnapshot sent to follower Vector(user, follower91), Chunk: 1/1 10:27:36,803 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - leader90: Snapshot success - sequence number: -1 10:27:36,803 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorSnapshotMessageSupport - leader90: SnapshotComplete received 10:27:36,803 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower91 (Follower): handleInstallSnapshot: InstallSnapshot{term=3, leaderId=leader90, lastIncludedIndex=1, lastIncludedTerm=3, datasize=333, chunk=1/1, lastChunkHashCode=OptionalInt[-1], serverConfig=ClusterConfig{serverInfo=[ServerInfo[peerId=follower91, isVoting=false], ServerInfo[peerId=leader90, isVoting=true]]}} 10:27:36,804 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SyncStatusTracker - follower91: Lagging -1 entries behind leader leader90 and reached 2 (of expected -1) 10:27:36,804 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SnapshotTracker - follower91 (Follower): addChunk: chunkIndex=1, lastChunkIndex=0, collectedChunks.size=0, lastChunkHashCode=-1 10:27:36,804 AM [test-pekko.actor.default-dispatcher-17] [INFO] Follower - follower91 (Follower): Snapshot received from leader: leader90 10:27:36,806 AM [test-pekko.actor.default-dispatcher-17] [INFO] SnapshotManager - follower91: Applying snapshot on follower: org.opendaylight.controller.cluster.io.FileBackedOutputStream$1@5c6e0b7 10:27:36,807 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SnapshotManager - follower91: Converted InstallSnapshot from leader: leader90 to state 10:27:36,807 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SnapshotManager - follower91: lastSequenceNumber prior to persisting applied snapshot: -1 10:27:36,808 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SnapshotManager - follower91: Snapshot success - sequence number: -1 10:27:36,808 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorContextImpl - follower91: Moving last applied index from 2 to 1 10:27:36,808 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - follower91: Set currentTerm=3, votedFor=null 10:27:36,808 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorContextImpl - follower91: Updated server config: isVoting: false, peers: [PeerInfo [id=leader90, address=pekko://test/user/leader90, votingState=VOTING]] 10:27:36,808 AM [test-pekko.actor.default-dispatcher-17] [INFO] MockRaftActor - follower91: applySnapshot called 10:27:36,808 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower91 (Follower): handleInstallSnapshot returning: InstallSnapshotReply{term=3, followerId=follower91, chunkIndex=1, success=true} 10:27:36,808 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader90 (Leader): handleInstallSnapshotReply: InstallSnapshotReply{term=3, followerId=follower91, chunkIndex=1, success=true} 10:27:36,808 AM [test-pekko.actor.default-dispatcher-11] [INFO] AbstractLeader - leader90 (Leader): Snapshot successfully installed on follower follower91 (last chunk 1) - matchIndex set to 1, nextIndex set to 2 10:27:36,808 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] SnapshotManager - leader90: fakeSnapshot purging log to 0 for term 3 10:27:36,808 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorSnapshotMessageSupport - follower91: SnapshotComplete received 10:27:36,836 AM [main] [INFO] NonVotingFollowerIntegrationTest - testFollowerResyncWithLessLeaderLogEntriesAfterNonPersistentLeaderRestart ending 10:27:36,836 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/follower91-collector93#-2007776946] 10:27:36,847 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower91] 10:27:36,848 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/leader90-collector94#-419938707] 10:27:36,848 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader90] 10:27:36,849 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/leader90-collector95#-98781286] 10:27:36,849 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader90] 10:27:36,851 AM [main] [INFO] NonVotingFollowerIntegrationTest - testFollowerResyncWithEmptyLeaderLogAfterNonPersistentLeaderRestart starting [WARN] [02/15/2025 10:27:36.854] [test-pekko.actor.default-dispatcher-11] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/follower97]: org.opendaylight.controller.cluster.common.actor.Monitor@a70df84 [INFO] [pekkoDeadLetter][02/15/2025 10:27:36.854] [test-pekko.actor.default-dispatcher-11] [pekko://test/user/termination-monitor] Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/follower97] to Actor[pekko://test/user/termination-monitor] was not delivered. [10] dead letters encountered, no more dead letters will be logged in next [5.000 min]. If this is not an expected behavior then Actor[pekko://test/user/termination-monitor] may have terminated unexpectedly. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 10:27:36,854 AM [test-pekko.actor.default-dispatcher-11] [INFO] EmptyLocalActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/follower97] to Actor[pekko://test/user/termination-monitor] was not delivered. [10] dead letters encountered, no more dead letters will be logged in next [5.000 min]. If this is not an expected behavior then Actor[pekko://test/user/termination-monitor] may have terminated unexpectedly. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 10:27:36,855 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActor - follower97: Starting recovery with journal batch size 1000 [WARN] [02/15/2025 10:27:36.857] [test-pekko.actor.default-dispatcher-18] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader96]: org.opendaylight.controller.cluster.common.actor.Monitor@1abb7770 10:27:36,857 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest12335241181424045998/follower97/TermInfo.properties does not exist java.nio.file.NoSuchFileException: /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest12335241181424045998/follower97/TermInfo.properties at java.base/sun.nio.fs.UnixException.translateToIOException(UnixException.java:92) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:106) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:111) at java.base/sun.nio.fs.UnixFileSystemProvider.newByteChannel(UnixFileSystemProvider.java:261) at java.base/java.nio.file.Files.newByteChannel(Files.java:379) at java.base/java.nio.file.Files.newByteChannel(Files.java:431) at java.base/java.nio.file.spi.FileSystemProvider.newInputStream(FileSystemProvider.java:420) at java.base/java.nio.file.Files.newInputStream(Files.java:159) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadFile(PropertiesTermInfoStore.java:108) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadAndSetTerm(PropertiesTermInfoStore.java:78) at org.opendaylight.controller.cluster.raft.RaftActorRecoverySupport.(RaftActorRecoverySupport.java:62) at org.opendaylight.controller.cluster.raft.RaftActor.newRaftActorRecoverySupport(RaftActor.java:181) at org.opendaylight.controller.cluster.raft.MockRaftActor.newRaftActorRecoverySupport(MockRaftActor.java:85) at org.opendaylight.controller.cluster.raft.RaftActor.handleRecover(RaftActor.java:166) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:33) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:29) at scala.PartialFunction.applyOrElse(PartialFunction.scala:214) at scala.PartialFunction.applyOrElse$(PartialFunction.scala:213) at org.apache.pekko.japi.pf.UnitCaseStatement.applyOrElse(CaseStatements.scala:29) at scala.PartialFunction$OrElse.apply(PartialFunction.scala:266) at org.apache.pekko.persistence.Eventsourced$$anon$2$$anonfun$1.applyOrElse(Eventsourced.scala:651) at org.apache.pekko.actor.Actor.aroundReceive(Actor.scala:547) at org.apache.pekko.actor.Actor.aroundReceive$(Actor.scala:545) at org.apache.pekko.persistence.AbstractPersistentActor.org$apache$pekko$persistence$Eventsourced$$super$aroundReceive(PersistentActor.scala:305) at org.apache.pekko.persistence.Eventsourced$$anon$3.stateReceive(Eventsourced.scala:769) at org.apache.pekko.persistence.Eventsourced.aroundReceive(Eventsourced.scala:256) at org.apache.pekko.persistence.Eventsourced.aroundReceive$(Eventsourced.scala:255) at org.apache.pekko.persistence.AbstractPersistentActor.aroundReceive(PersistentActor.scala:305) at org.apache.pekko.actor.ActorCell.receiveMessage(ActorCell.scala:590) at org.apache.pekko.actor.ActorCell.invoke(ActorCell.scala:557) at org.apache.pekko.dispatch.Mailbox.processMailbox(Mailbox.scala:280) at org.apache.pekko.dispatch.Mailbox.run(Mailbox.scala:241) at org.apache.pekko.dispatch.Mailbox.exec(Mailbox.scala:253) at java.base/java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:387) at java.base/java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1312) at java.base/java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1843) at java.base/java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1808) at java.base/java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:188) 10:27:36,858 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - follower97: Set currentTerm=1, votedFor=leader96 10:27:36,858 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActor - leader96: Starting recovery with journal batch size 1000 10:27:36,858 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorRecoverySupport - follower97: Received ReplicatedLogEntry for recovery: index: 0, size: 141 10:27:36,858 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorContextImpl - follower97: Updated server config: isVoting: false, peers: [PeerInfo [id=leader96, address=pekko://test/user/leader96, votingState=VOTING]] 10:27:36,859 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorRecoverySupport - follower97: Recovery completed - Switching actor to Follower - last log index = -1, last log term = -1, snapshot index = -1, snapshot term = -1, journal size = 0 10:27:36,859 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest12335241181424045998/leader96/TermInfo.properties does not exist java.nio.file.NoSuchFileException: /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest12335241181424045998/leader96/TermInfo.properties at java.base/sun.nio.fs.UnixException.translateToIOException(UnixException.java:92) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:106) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:111) at java.base/sun.nio.fs.UnixFileSystemProvider.newByteChannel(UnixFileSystemProvider.java:261) at java.base/java.nio.file.Files.newByteChannel(Files.java:379) at java.base/java.nio.file.Files.newByteChannel(Files.java:431) at java.base/java.nio.file.spi.FileSystemProvider.newInputStream(FileSystemProvider.java:420) at java.base/java.nio.file.Files.newInputStream(Files.java:159) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadFile(PropertiesTermInfoStore.java:108) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadAndSetTerm(PropertiesTermInfoStore.java:78) at org.opendaylight.controller.cluster.raft.RaftActorRecoverySupport.(RaftActorRecoverySupport.java:62) at org.opendaylight.controller.cluster.raft.RaftActor.newRaftActorRecoverySupport(RaftActor.java:181) at org.opendaylight.controller.cluster.raft.MockRaftActor.newRaftActorRecoverySupport(MockRaftActor.java:85) at org.opendaylight.controller.cluster.raft.RaftActor.handleRecover(RaftActor.java:166) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:33) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:29) at scala.PartialFunction.applyOrElse(PartialFunction.scala:214) at scala.PartialFunction.applyOrElse$(PartialFunction.scala:213) at org.apache.pekko.japi.pf.UnitCaseStatement.applyOrElse(CaseStatements.scala:29) at scala.PartialFunction$OrElse.apply(PartialFunction.scala:266) at org.apache.pekko.persistence.Eventsourced$$anon$2$$anonfun$1.applyOrElse(Eventsourced.scala:651) at org.apache.pekko.actor.Actor.aroundReceive(Actor.scala:547) at org.apache.pekko.actor.Actor.aroundReceive$(Actor.scala:545) at org.apache.pekko.persistence.AbstractPersistentActor.org$apache$pekko$persistence$Eventsourced$$super$aroundReceive(PersistentActor.scala:305) at org.apache.pekko.persistence.Eventsourced$$anon$3.stateReceive(Eventsourced.scala:769) at org.apache.pekko.persistence.Eventsourced.aroundReceive(Eventsourced.scala:256) at org.apache.pekko.persistence.Eventsourced.aroundReceive$(Eventsourced.scala:255) at org.apache.pekko.persistence.AbstractPersistentActor.aroundReceive(PersistentActor.scala:305) at org.apache.pekko.actor.ActorCell.receiveMessage(ActorCell.scala:590) at org.apache.pekko.actor.ActorCell.invoke(ActorCell.scala:557) at org.apache.pekko.dispatch.Mailbox.processMailbox(Mailbox.scala:280) at org.apache.pekko.dispatch.Mailbox.run(Mailbox.scala:241) at org.apache.pekko.dispatch.Mailbox.exec(Mailbox.scala:253) at java.base/java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:387) at java.base/java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1312) at java.base/java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1843) at java.base/java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1808) at java.base/java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:188) 10:27:36,859 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - leader96: Set currentTerm=1, votedFor=leader96 10:27:36,860 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorRecoverySupport - leader96: Received ReplicatedLogEntry for recovery: index: 0, size: 141 10:27:36,860 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorContextImpl - leader96: Updated server config: isVoting: true, peers: [PeerInfo [id=follower97, address=pekko://test/user/follower97, votingState=NON_VOTING]] 10:27:36,860 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActorRecoverySupport - leader96: Recovery completed - Switching actor to Follower - last log index = -1, last log term = -1, snapshot index = -1, snapshot term = -1, journal size = 0 10:27:36,862 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - follower97: Set currentTerm=1, votedFor=leader96 10:27:36,862 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorRecoverySupport - follower97: Local TermInfo store seeded with TermInfo{term=1, votedFor=leader96} 10:27:36,863 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - leader96: Set currentTerm=1, votedFor=leader96 10:27:36,864 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActorRecoverySupport - leader96: Local TermInfo store seeded with TermInfo{term=1, votedFor=leader96} 10:27:37,284 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] DefaultConfigParamsImpl - No custom RaftPolicy specified. Using DefaultRaftPolicy 10:27:37,284 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - leader96 (Follower): Checking if this node is isolated in the cluster unreachable set [],all members [] self member: Member(pekko://test@10.30.170.64:17355, Removed) 10:27:37,285 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - leader96 (Follower): Received ElectionTimeout - switching to Candidate 10:27:37,285 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Candidate - leader96 (Candidate): Election: Candidate has following voting peers: [] 10:27:37,288 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - leader96: Set currentTerm=2, votedFor=leader96 10:27:37,288 AM [test-pekko.actor.default-dispatcher-14] [INFO] Candidate - leader96 (Candidate): Starting new election term 2 10:27:37,288 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActorBehavior - leader96 (Follower) :- Switching from behavior Follower to Candidate, election term: 2 10:27:37,288 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Candidate - leader96 (Candidate): Received ElectionTimeout 10:27:37,288 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): Election: Leader has following peers: [follower97] 10:27:37,289 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): Checking sendAppendEntries for follower follower97: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 10:27:37,289 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActorBehavior - leader96 (Candidate) :- Switching from behavior Candidate to Leader, election term: 2 10:27:37,289 AM [test-pekko.actor.default-dispatcher-14] [INFO] Follower - follower97 (Follower): Term 2 in "AppendEntries{term=2, leaderId=leader96, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 1 - updating term 10:27:37,292 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - follower97: Set currentTerm=2, votedFor=null 10:27:37,292 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SyncStatusTracker - follower97: Last sync leader does not match current leader leader96, need to catch up to -1 10:27:37,292 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower97 updated: matchIndex: -1, nextIndex: 0 10:27:37,292 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): Checking sendAppendEntries for follower follower97: active: true, followerNextIndex: 0, leaderLastIndex: -1, leaderSnapShotIndex: -1 [WARN] [02/15/2025 10:27:37.292] [test-pekko.actor.default-dispatcher-14] [pekko://test/user/follower97] unhandled message from Actor[pekko://test/deadLetters]: org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus@1e63a9dd 10:27:37,318 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader96: Persist data SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:37,318 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - leader96: Append log entry and persist SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:37,318 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): Replicate message: identifier: MockIdentifier{value=zero}, logIndex: 0, isSendImmediate: true 10:27:37,318 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorBehavior - leader96 (Leader): Setting last applied to 0 10:27:37,318 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorContextImpl - leader96: Moving last applied index from -1 to 0 10:27:37,318 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader96: Applying state for log index 0 data zero 10:27:37,318 AM [test-pekko.actor.default-dispatcher-14] [INFO] MockRaftActor - leader96: applyState called: zero 10:27:37,318 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): Checking sendAppendEntries for follower follower97: active: true, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 10:27:37,318 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): sendAppendEntries: 0 is present for follower follower97 10:27:37,319 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): Sending AppendEntries to follower follower97: AppendEntries{term=2, leaderId=leader96, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=2, payload=zero]]} 10:27:37,319 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader96: Persisting ApplyJournalEntries with index=0 10:27:37,319 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - leader96: persist complete SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:37,319 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader96: Persist data SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:37,319 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - leader96: Append log entry and persist SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:37,319 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=leader96, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=2, payload=zero]]} 10:27:37,319 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): Replicate message: identifier: MockIdentifier{value=one}, logIndex: 1, isSendImmediate: true 10:27:37,319 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): Number of entries to be appended = 1 10:27:37,319 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorBehavior - leader96 (Leader): Setting last applied to 1 10:27:37,319 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): After cleanup, lastIndex: -1, entries to be added from: 0 10:27:37,319 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorContextImpl - leader96: Moving last applied index from 0 to 1 10:27:37,319 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader96: Applying state for log index 1 data one 10:27:37,319 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): Append entry to log zero 10:27:37,319 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower97: Append log entry and persist SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:37,319 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower97: persist complete SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:37,319 AM [test-pekko.actor.default-dispatcher-14] [INFO] MockRaftActor - leader96: applyState called: one 10:27:37,319 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): Log size is now 1 10:27:37,319 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): Commit index set to 0 10:27:37,319 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=follower97, logLastIndex=0, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:37,319 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): Checking sendAppendEntries for follower follower97: active: true, followerNextIndex: 0, leaderLastIndex: 1, leaderSnapShotIndex: -1 10:27:37,319 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower97: Lagging 0 entries behind leader leader96 and reached 0 (of expected -1) 10:27:37,319 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): sendAppendEntries: 0 is present for follower follower97 10:27:37,319 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 0, context.getLastApplied(): -1, lastIndex(): 0 10:27:37,319 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - follower97 (Follower): Setting last applied to 0 10:27:37,319 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorContextImpl - follower97: Moving last applied index from -1 to 0 10:27:37,319 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): Sending AppendEntries to follower follower97: AppendEntries{term=2, leaderId=leader96, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=2, payload=zero], SimpleReplicatedLogEntry [index=1, term=2, payload=one]]} 10:27:37,319 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower97: Applying state for log index 0 data zero 10:27:37,319 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader96: Persisting ApplyJournalEntries with index=1 10:27:37,319 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - follower97: applyState called: zero 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower97 updated: matchIndex: 0, nextIndex: 1 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SnapshotManager - leader96: fakeSnapshot purging log to 0 for term 2 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): Checking sendAppendEntries for follower follower97: active: true, followerNextIndex: 1, leaderLastIndex: 1, leaderSnapShotIndex: 0 10:27:37,320 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=leader96, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=2, payload=zero], SimpleReplicatedLogEntry [index=1, term=2, payload=one]]} 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): sendAppendEntries: 1 is present for follower follower97 10:27:37,320 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): Number of entries to be appended = 2 10:27:37,320 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): matchEntry SimpleReplicatedLogEntry [index=0, term=2, payload=zero] is present: existingEntryTerm: 2 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): Sending AppendEntries to follower follower97: AppendEntries{term=2, leaderId=leader96, prevLogIndex=0, prevLogTerm=2, leaderCommit=1, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=1, term=2, payload=one]]} 10:27:37,320 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): After cleanup, lastIndex: 0, entries to be added from: 1 10:27:37,320 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): Append entry to log one 10:27:37,320 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower97: Append log entry and persist SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:37,320 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower97: persist complete SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - leader96: persist complete SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:37,320 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): Log size is now 2 10:27:37,320 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): Commit index set to 1 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader96: Persist data SimpleReplicatedLogEntry [index=2, term=2, payload=two] 10:27:37,320 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=follower97, logLastIndex=1, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - leader96: Append log entry and persist SimpleReplicatedLogEntry [index=2, term=2, payload=two] 10:27:37,320 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower97: Lagging 0 entries behind leader leader96 and reached 1 (of expected -1) 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): Replicate message: identifier: MockIdentifier{value=two}, logIndex: 2, isSendImmediate: true 10:27:37,320 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 1, context.getLastApplied(): 0, lastIndex(): 1 10:27:37,320 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - follower97 (Follower): Setting last applied to 1 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorBehavior - leader96 (Leader): Setting last applied to 2 10:27:37,320 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorContextImpl - follower97: Moving last applied index from 0 to 1 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorContextImpl - leader96: Moving last applied index from 1 to 2 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader96: Applying state for log index 2 data two 10:27:37,320 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower97: Applying state for log index 1 data one 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [INFO] MockRaftActor - leader96: applyState called: two 10:27:37,320 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - follower97: applyState called: one 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): Checking sendAppendEntries for follower follower97: active: true, followerNextIndex: 1, leaderLastIndex: 2, leaderSnapShotIndex: 0 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): sendAppendEntries: 1 is present for follower follower97 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): Sending AppendEntries to follower follower97: AppendEntries{term=2, leaderId=leader96, prevLogIndex=0, prevLogTerm=2, leaderCommit=2, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=1, term=2, payload=one], SimpleReplicatedLogEntry [index=2, term=2, payload=two]]} 10:27:37,320 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower97: Persisting ApplyJournalEntries with index=0 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower97 updated: matchIndex: 1, nextIndex: 2 10:27:37,320 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SnapshotManager - leader96: fakeSnapshot purging log to 1 for term 2 10:27:37,321 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): Checking sendAppendEntries for follower follower97: active: true, followerNextIndex: 2, leaderLastIndex: 2, leaderSnapShotIndex: 1 10:27:37,321 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): sendAppendEntries: 2 is present for follower follower97 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=leader96, prevLogIndex=0, prevLogTerm=2, leaderCommit=1, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=1, term=2, payload=one]]} 10:27:37,321 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): Sending AppendEntries to follower follower97: AppendEntries{term=2, leaderId=leader96, prevLogIndex=1, prevLogTerm=2, leaderCommit=2, replicatedToAllIndex=1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=2, term=2, payload=two]]} 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): Number of entries to be appended = 1 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): matchEntry SimpleReplicatedLogEntry [index=1, term=2, payload=one] is present: existingEntryTerm: 2 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): After cleanup, lastIndex: 1, entries to be added from: 1 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): Log size is now 2 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=follower97, logLastIndex=1, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:37,321 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader96: Persisting ApplyJournalEntries with index=2 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower97: Lagging 0 entries behind leader leader96 and reached 1 (of expected -1) 10:27:37,321 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - leader96: persist complete SimpleReplicatedLogEntry [index=2, term=2, payload=two] 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - follower97: fakeSnapshot purging log to 0 for term 2 10:27:37,321 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader96 (Leader): sendAppendEntries: 2 is present for follower follower97 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower97: Persisting ApplyJournalEntries with index=1 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=leader96, prevLogIndex=0, prevLogTerm=2, leaderCommit=2, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=1, term=2, payload=one], SimpleReplicatedLogEntry [index=2, term=2, payload=two]]} 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): Number of entries to be appended = 2 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): matchEntry SimpleReplicatedLogEntry [index=1, term=2, payload=one] is present: existingEntryTerm: 2 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): After cleanup, lastIndex: 1, entries to be added from: 1 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): Append entry to log two 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower97: Append log entry and persist SimpleReplicatedLogEntry [index=2, term=2, payload=two] 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower97: persist complete SimpleReplicatedLogEntry [index=2, term=2, payload=two] 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): Log size is now 2 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): Commit index set to 2 10:27:37,321 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=follower97, logLastIndex=2, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:37,322 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower97: Lagging 0 entries behind leader leader96 and reached 2 (of expected -1) 10:27:37,322 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 2, context.getLastApplied(): 1, lastIndex(): 2 10:27:37,322 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - follower97 (Follower): Setting last applied to 2 10:27:37,322 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader96 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower97 updated: matchIndex: 2, nextIndex: 3 10:27:37,322 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorContextImpl - follower97: Moving last applied index from 1 to 2 10:27:37,322 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower97: Applying state for log index 2 data two 10:27:37,322 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - follower97: applyState called: two 10:27:37,322 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader96 (Leader): Checking sendAppendEntries for follower follower97: active: true, followerNextIndex: 3, leaderLastIndex: 2, leaderSnapShotIndex: 1 10:27:37,322 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=leader96, prevLogIndex=1, prevLogTerm=2, leaderCommit=2, replicatedToAllIndex=1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=2, term=2, payload=two]]} 10:27:37,322 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): Number of entries to be appended = 1 10:27:37,322 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): matchEntry SimpleReplicatedLogEntry [index=2, term=2, payload=two] is present: existingEntryTerm: 2 10:27:37,322 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): After cleanup, lastIndex: 2, entries to be added from: 1 10:27:37,322 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): Log size is now 2 10:27:37,322 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower97 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=follower97, logLastIndex=2, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:37,322 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower97: Lagging 0 entries behind leader leader96 and reached 2 (of expected -1) 10:27:37,322 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - follower97: fakeSnapshot purging log to 1 for term 2 10:27:37,322 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower97: Persisting ApplyJournalEntries with index=2 [WARN] [02/15/2025 10:27:37.323] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/follower97] unhandled message from Actor[pekko://test/deadLetters]: org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus@35866305 [WARN] [02/15/2025 10:27:37.382] [test-pekko.actor.default-dispatcher-17] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader96]: org.opendaylight.controller.cluster.common.actor.Monitor@3ad36605 10:27:37,383 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActor - leader96: Starting recovery with journal batch size 1000 10:27:37,386 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - leader96: Set currentTerm=2, votedFor=leader96 10:27:37,386 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - leader96: Set currentTerm=1, votedFor=leader96 10:27:37,386 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorRecoverySupport - leader96: Received ReplicatedLogEntry for recovery: index: 0, size: 141 10:27:37,386 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorContextImpl - leader96: Updated server config: isVoting: true, peers: [PeerInfo [id=follower97, address=pekko://test/user/follower97, votingState=NON_VOTING]] 10:27:37,386 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActorRecoverySupport - leader96: Recovery completed - Switching actor to Follower - last log index = -1, last log term = -1, snapshot index = -1, snapshot term = -1, journal size = 0 10:27:37,386 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorRecoverySupport - leader96: restoring local TermInfo{term=2, votedFor=leader96} 10:27:37,386 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - leader96: Set currentTerm=2, votedFor=leader96 10:27:37,814 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - leader96 (Follower): Checking if this node is isolated in the cluster unreachable set [],all members [] self member: Member(pekko://test@10.30.170.64:17355, Removed) 10:27:37,815 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - leader96 (Follower): Received ElectionTimeout - switching to Candidate 10:27:37,815 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Candidate - leader96 (Candidate): Election: Candidate has following voting peers: [] 10:27:37,818 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - leader96: Set currentTerm=3, votedFor=leader96 10:27:37,818 AM [test-pekko.actor.default-dispatcher-17] [INFO] Candidate - leader96 (Candidate): Starting new election term 3 10:27:37,818 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorBehavior - leader96 (Follower) :- Switching from behavior Follower to Candidate, election term: 3 10:27:37,819 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Candidate - leader96 (Candidate): Received ElectionTimeout 10:27:37,819 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader96 (Leader): Election: Leader has following peers: [follower97] 10:27:37,819 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader96 (Leader): Checking sendAppendEntries for follower follower97: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 10:27:37,819 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorBehavior - leader96 (Candidate) :- Switching from behavior Candidate to Leader, election term: 3 10:27:37,819 AM [test-pekko.actor.default-dispatcher-17] [INFO] Follower - follower97 (Follower): Term 3 in "AppendEntries{term=3, leaderId=leader96, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 2 - updating term 10:27:37,823 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - follower97: Set currentTerm=3, votedFor=null 10:27:37,823 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SyncStatusTracker - follower97: Lagging -3 entries behind leader leader96 and reached 2 (of expected -1) 10:27:37,823 AM [test-pekko.actor.default-dispatcher-17] [INFO] AbstractLeader - leader96 (Leader): handleAppendEntriesReply: follower follower97 lastIndex 2 is ahead of our lastIndex -1 (snapshotIndex -1, snapshotTerm -1) - forcing install snaphot 10:27:37,823 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SnapshotManager - leader96: Capturing Snapshot : lastLogEntry is null. Using snapshot values lastAppliedIndex -1 and lastAppliedTerm -1 instead. 10:27:37,823 AM [test-pekko.actor.default-dispatcher-17] [INFO] SnapshotManager - leader96: Initiating snapshot capture CaptureSnapshot [lastAppliedIndex=-1, lastAppliedTerm=-1, lastIndex=-1, lastTerm=-1, installSnapshotInitiated=, replicatedToAllIndex=-1, replicatedToAllTerm=-1, unAppliedEntries size=0, mandatoryTrim=false] to install on follower97 10:27:37,823 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SnapshotManager - leader96: lastSequenceNumber prior to capture: -1 10:27:37,824 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorSnapshotMessageSupport - leader96: CaptureSnapshotReply received by actor 10:27:37,824 AM [test-pekko.actor.default-dispatcher-17] [INFO] SnapshotManager - leader96: Persisting of snapshot done: Snapshot [lastIndex=-1, lastTerm=-1, lastAppliedIndex=-1, lastAppliedTerm=-1, unAppliedEntries size=0, state=MockSnapshotState [state=[]], electionTerm=3, electionVotedFor=leader96, ServerConfigPayload=ClusterConfig{serverInfo=[ServerInfo[peerId=follower97, isVoting=false], ServerInfo[peerId=leader96, isVoting=true]]}] 10:27:37,824 AM [test-pekko.actor.default-dispatcher-17] [INFO] SnapshotManager - leader96: Removed in-memory snapshotted entries, adjusted snaphsotIndex: -1 and term: -1 10:27:37,824 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader96 (Leader): sendInstallSnapshot 10:27:37,824 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] LeaderInstallSnapshotState - leader96 (Leader): Snapshot 171 bytes, total chunks to send: 1 10:27:37,824 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] LeaderInstallSnapshotState - leader96 (Leader): Next chunk: total length=171, offset=0, size=171, hashCode=-2041399403 10:27:37,824 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader96 (Leader): next snapshot chunk size for follower follower97: 171 10:27:37,824 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader96 (Leader): InstallSnapshot sent to follower Vector(user, follower97), Chunk: 1/1 10:27:37,824 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SnapshotManager - leader96: Snapshot success - sequence number: -1 10:27:37,824 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorSnapshotMessageSupport - leader96: SnapshotComplete received 10:27:37,824 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower97 (Follower): handleInstallSnapshot: InstallSnapshot{term=3, leaderId=leader96, lastIncludedIndex=-1, lastIncludedTerm=-1, datasize=171, chunk=1/1, lastChunkHashCode=OptionalInt[-1], serverConfig=ClusterConfig{serverInfo=[ServerInfo[peerId=follower97, isVoting=false], ServerInfo[peerId=leader96, isVoting=true]]}} 10:27:37,824 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SyncStatusTracker - follower97: Lagging -3 entries behind leader leader96 and reached 2 (of expected -1) 10:27:37,824 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SnapshotTracker - follower97 (Follower): addChunk: chunkIndex=1, lastChunkIndex=0, collectedChunks.size=0, lastChunkHashCode=-1 10:27:37,824 AM [test-pekko.actor.default-dispatcher-17] [INFO] Follower - follower97 (Follower): Snapshot received from leader: leader96 10:27:37,825 AM [test-pekko.actor.default-dispatcher-17] [INFO] SnapshotManager - follower97: Applying snapshot on follower: org.opendaylight.controller.cluster.io.FileBackedOutputStream$1@613986f 10:27:37,825 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SnapshotManager - follower97: Converted InstallSnapshot from leader: leader96 to state 10:27:37,825 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SnapshotManager - follower97: lastSequenceNumber prior to persisting applied snapshot: -1 10:27:37,825 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SnapshotManager - follower97: Snapshot success - sequence number: -1 10:27:37,825 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorContextImpl - follower97: Moving last applied index from 2 to -1 10:27:37,825 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - follower97: Set currentTerm=3, votedFor=null 10:27:37,825 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorContextImpl - follower97: Updated server config: isVoting: false, peers: [PeerInfo [id=leader96, address=pekko://test/user/leader96, votingState=VOTING]] 10:27:37,825 AM [test-pekko.actor.default-dispatcher-17] [INFO] MockRaftActor - follower97: applySnapshot called 10:27:37,825 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower97 (Follower): handleInstallSnapshot returning: InstallSnapshotReply{term=3, followerId=follower97, chunkIndex=1, success=true} 10:27:37,825 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorSnapshotMessageSupport - follower97: SnapshotComplete received 10:27:37,825 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader96 (Leader): handleInstallSnapshotReply: InstallSnapshotReply{term=3, followerId=follower97, chunkIndex=1, success=true} 10:27:37,825 AM [test-pekko.actor.default-dispatcher-17] [INFO] AbstractLeader - leader96 (Leader): Snapshot successfully installed on follower follower97 (last chunk 1) - matchIndex set to -1, nextIndex set to 0 10:27:37,841 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader96: Persist data SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] 10:27:37,841 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - leader96: Append log entry and persist SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] 10:27:37,841 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader96 (Leader): Replicate message: identifier: MockIdentifier{value=zero-1}, logIndex: 0, isSendImmediate: true 10:27:37,841 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - leader96 (Leader): Setting last applied to 0 10:27:37,841 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorContextImpl - leader96: Moving last applied index from -1 to 0 10:27:37,841 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader96: Applying state for log index 0 data zero-1 10:27:37,841 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - leader96: applyState called: zero-1 10:27:37,841 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader96 (Leader): Checking sendAppendEntries for follower follower97: active: true, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 10:27:37,841 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader96 (Leader): sendAppendEntries: 0 is present for follower follower97 10:27:37,841 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader96 (Leader): Sending AppendEntries to follower follower97: AppendEntries{term=3, leaderId=leader96, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1]]} 10:27:37,841 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] Follower - follower97 (Follower): handleAppendEntries: AppendEntries{term=3, leaderId=leader96, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1]]} 10:27:37,841 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] Follower - follower97 (Follower): Number of entries to be appended = 1 10:27:37,841 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] Follower - follower97 (Follower): After cleanup, lastIndex: -1, entries to be added from: 0 10:27:37,842 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] Follower - follower97 (Follower): Append entry to log zero-1 10:27:37,842 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] ReplicatedLogImpl - follower97: Append log entry and persist SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] 10:27:37,842 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] ReplicatedLogImpl - follower97: persist complete SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] 10:27:37,842 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] Follower - follower97 (Follower): Log size is now 1 10:27:37,842 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] Follower - follower97 (Follower): Commit index set to 0 10:27:37,842 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] Follower - follower97 (Follower): handleAppendEntries returning : AppendEntriesReply{term=3, success=true, followerId=follower97, logLastIndex=0, logLastTerm=3, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:37,842 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] SyncStatusTracker - follower97: Lagging 0 entries behind leader leader96 and reached 0 (of expected -1) 10:27:37,842 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] Follower - follower97 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 0, context.getLastApplied(): -1, lastIndex(): 0 10:27:37,842 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] RaftActorBehavior - follower97 (Follower): Setting last applied to 0 10:27:37,842 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] RaftActorContextImpl - follower97: Moving last applied index from -1 to 0 10:27:37,842 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] RaftActor - follower97: Applying state for log index 0 data zero-1 10:27:37,842 AM [test-pekko.actor.default-dispatcher-18] [INFO] MockRaftActor - follower97: applyState called: zero-1 10:27:37,842 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] RaftActor - follower97: Persisting ApplyJournalEntries with index=0 10:27:37,842 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader96: Persisting ApplyJournalEntries with index=0 10:27:37,842 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader96 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower97 updated: matchIndex: 0, nextIndex: 1 10:27:37,843 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader96 (Leader): Checking sendAppendEntries for follower follower97: active: true, followerNextIndex: 1, leaderLastIndex: 0, leaderSnapShotIndex: -1 10:27:37,843 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - leader96: persist complete SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] 10:27:37,891 AM [main] [INFO] NonVotingFollowerIntegrationTest - testFollowerResyncWithEmptyLeaderLogAfterNonPersistentLeaderRestart ending 10:27:37,891 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/follower97-collector99#-729254188] 10:27:37,902 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower97] 10:27:37,903 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/leader96-collector100#-1767523745] 10:27:37,903 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader96] 10:27:37,903 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/leader96-collector101#1468449037] 10:27:37,904 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader96] 10:27:37,907 AM [main] [INFO] NonVotingFollowerIntegrationTest - testFollowerResyncWithOneMoreLeaderLogEntryAfterNonPersistentLeaderRestart starting [WARN] [02/15/2025 10:27:37.910] [test-pekko.actor.default-dispatcher-17] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/follower103]: org.opendaylight.controller.cluster.common.actor.Monitor@ca61dfb 10:27:37,911 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActor - follower103: Starting recovery with journal batch size 1000 [WARN] [02/15/2025 10:27:37.913] [test-pekko.actor.default-dispatcher-18] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader102]: org.opendaylight.controller.cluster.common.actor.Monitor@1b9fa983 10:27:37,913 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActor - leader102: Starting recovery with journal batch size 1000 10:27:37,914 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest13693361122769448774/follower103/TermInfo.properties does not exist java.nio.file.NoSuchFileException: /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest13693361122769448774/follower103/TermInfo.properties at java.base/sun.nio.fs.UnixException.translateToIOException(UnixException.java:92) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:106) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:111) at java.base/sun.nio.fs.UnixFileSystemProvider.newByteChannel(UnixFileSystemProvider.java:261) at java.base/java.nio.file.Files.newByteChannel(Files.java:379) at java.base/java.nio.file.Files.newByteChannel(Files.java:431) at java.base/java.nio.file.spi.FileSystemProvider.newInputStream(FileSystemProvider.java:420) at java.base/java.nio.file.Files.newInputStream(Files.java:159) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadFile(PropertiesTermInfoStore.java:108) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadAndSetTerm(PropertiesTermInfoStore.java:78) at org.opendaylight.controller.cluster.raft.RaftActorRecoverySupport.(RaftActorRecoverySupport.java:62) at org.opendaylight.controller.cluster.raft.RaftActor.newRaftActorRecoverySupport(RaftActor.java:181) at org.opendaylight.controller.cluster.raft.MockRaftActor.newRaftActorRecoverySupport(MockRaftActor.java:85) at org.opendaylight.controller.cluster.raft.RaftActor.handleRecover(RaftActor.java:166) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:33) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:29) at scala.PartialFunction.applyOrElse(PartialFunction.scala:214) at scala.PartialFunction.applyOrElse$(PartialFunction.scala:213) at org.apache.pekko.japi.pf.UnitCaseStatement.applyOrElse(CaseStatements.scala:29) at scala.PartialFunction$OrElse.apply(PartialFunction.scala:266) at org.apache.pekko.persistence.Eventsourced$$anon$2$$anonfun$1.applyOrElse(Eventsourced.scala:651) at org.apache.pekko.actor.Actor.aroundReceive(Actor.scala:547) at org.apache.pekko.actor.Actor.aroundReceive$(Actor.scala:545) at org.apache.pekko.persistence.AbstractPersistentActor.org$apache$pekko$persistence$Eventsourced$$super$aroundReceive(PersistentActor.scala:305) at org.apache.pekko.persistence.Eventsourced$$anon$3.stateReceive(Eventsourced.scala:769) at org.apache.pekko.persistence.Eventsourced.aroundReceive(Eventsourced.scala:256) at org.apache.pekko.persistence.Eventsourced.aroundReceive$(Eventsourced.scala:255) at org.apache.pekko.persistence.AbstractPersistentActor.aroundReceive(PersistentActor.scala:305) at org.apache.pekko.actor.ActorCell.receiveMessage(ActorCell.scala:590) at org.apache.pekko.actor.ActorCell.invoke(ActorCell.scala:557) at org.apache.pekko.dispatch.Mailbox.processMailbox(Mailbox.scala:280) at org.apache.pekko.dispatch.Mailbox.run(Mailbox.scala:241) at org.apache.pekko.dispatch.Mailbox.exec(Mailbox.scala:253) at java.base/java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:387) at java.base/java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1312) at java.base/java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1843) at java.base/java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1808) at java.base/java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:188) 10:27:37,914 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - follower103: Set currentTerm=1, votedFor=leader102 10:27:37,915 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorRecoverySupport - follower103: Received ReplicatedLogEntry for recovery: index: 0, size: 143 10:27:37,915 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorContextImpl - follower103: Updated server config: isVoting: false, peers: [PeerInfo [id=leader102, address=pekko://test/user/leader102, votingState=VOTING]] 10:27:37,915 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActorRecoverySupport - follower103: Recovery completed - Switching actor to Follower - last log index = -1, last log term = -1, snapshot index = -1, snapshot term = -1, journal size = 0 10:27:37,915 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest13693361122769448774/leader102/TermInfo.properties does not exist java.nio.file.NoSuchFileException: /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest13693361122769448774/leader102/TermInfo.properties at java.base/sun.nio.fs.UnixException.translateToIOException(UnixException.java:92) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:106) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:111) at java.base/sun.nio.fs.UnixFileSystemProvider.newByteChannel(UnixFileSystemProvider.java:261) at java.base/java.nio.file.Files.newByteChannel(Files.java:379) at java.base/java.nio.file.Files.newByteChannel(Files.java:431) at java.base/java.nio.file.spi.FileSystemProvider.newInputStream(FileSystemProvider.java:420) at java.base/java.nio.file.Files.newInputStream(Files.java:159) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadFile(PropertiesTermInfoStore.java:108) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadAndSetTerm(PropertiesTermInfoStore.java:78) at org.opendaylight.controller.cluster.raft.RaftActorRecoverySupport.(RaftActorRecoverySupport.java:62) at org.opendaylight.controller.cluster.raft.RaftActor.newRaftActorRecoverySupport(RaftActor.java:181) at org.opendaylight.controller.cluster.raft.MockRaftActor.newRaftActorRecoverySupport(MockRaftActor.java:85) at org.opendaylight.controller.cluster.raft.RaftActor.handleRecover(RaftActor.java:166) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:33) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:29) at scala.PartialFunction.applyOrElse(PartialFunction.scala:214) at scala.PartialFunction.applyOrElse$(PartialFunction.scala:213) at org.apache.pekko.japi.pf.UnitCaseStatement.applyOrElse(CaseStatements.scala:29) at scala.PartialFunction$OrElse.apply(PartialFunction.scala:266) at org.apache.pekko.persistence.Eventsourced$$anon$2$$anonfun$1.applyOrElse(Eventsourced.scala:651) at org.apache.pekko.actor.Actor.aroundReceive(Actor.scala:547) at org.apache.pekko.actor.Actor.aroundReceive$(Actor.scala:545) at org.apache.pekko.persistence.AbstractPersistentActor.org$apache$pekko$persistence$Eventsourced$$super$aroundReceive(PersistentActor.scala:305) at org.apache.pekko.persistence.Eventsourced$$anon$3.stateReceive(Eventsourced.scala:769) at org.apache.pekko.persistence.Eventsourced.aroundReceive(Eventsourced.scala:256) at org.apache.pekko.persistence.Eventsourced.aroundReceive$(Eventsourced.scala:255) at org.apache.pekko.persistence.AbstractPersistentActor.aroundReceive(PersistentActor.scala:305) at org.apache.pekko.actor.ActorCell.receiveMessage(ActorCell.scala:590) at org.apache.pekko.actor.ActorCell.invoke(ActorCell.scala:557) at org.apache.pekko.dispatch.Mailbox.processMailbox(Mailbox.scala:280) at org.apache.pekko.dispatch.Mailbox.run(Mailbox.scala:241) at org.apache.pekko.dispatch.Mailbox.exec(Mailbox.scala:253) at java.base/java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:387) at java.base/java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1312) at java.base/java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1843) at java.base/java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1808) at java.base/java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:188) 10:27:37,915 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - leader102: Set currentTerm=1, votedFor=leader102 10:27:37,915 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorRecoverySupport - leader102: Received ReplicatedLogEntry for recovery: index: 0, size: 143 10:27:37,915 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorContextImpl - leader102: Updated server config: isVoting: true, peers: [PeerInfo [id=follower103, address=pekko://test/user/follower103, votingState=NON_VOTING]] 10:27:37,916 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorRecoverySupport - leader102: Recovery completed - Switching actor to Follower - last log index = -1, last log term = -1, snapshot index = -1, snapshot term = -1, journal size = 0 10:27:37,918 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - follower103: Set currentTerm=1, votedFor=leader102 10:27:37,918 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActorRecoverySupport - follower103: Local TermInfo store seeded with TermInfo{term=1, votedFor=leader102} 10:27:37,918 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - leader102: Set currentTerm=1, votedFor=leader102 10:27:37,918 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorRecoverySupport - leader102: Local TermInfo store seeded with TermInfo{term=1, votedFor=leader102} 10:27:38,384 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] DefaultConfigParamsImpl - No custom RaftPolicy specified. Using DefaultRaftPolicy 10:27:38,384 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - leader102 (Follower): Checking if this node is isolated in the cluster unreachable set [],all members [] self member: Member(pekko://test@10.30.170.64:17355, Removed) 10:27:38,384 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - leader102 (Follower): Received ElectionTimeout - switching to Candidate 10:27:38,384 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Candidate - leader102 (Candidate): Election: Candidate has following voting peers: [] 10:27:38,388 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - leader102: Set currentTerm=2, votedFor=leader102 10:27:38,388 AM [test-pekko.actor.default-dispatcher-17] [INFO] Candidate - leader102 (Candidate): Starting new election term 2 10:27:38,388 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorBehavior - leader102 (Follower) :- Switching from behavior Follower to Candidate, election term: 2 10:27:38,388 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Candidate - leader102 (Candidate): Received ElectionTimeout 10:27:38,388 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader102 (Leader): Election: Leader has following peers: [follower103] 10:27:38,388 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader102 (Leader): Checking sendAppendEntries for follower follower103: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 10:27:38,388 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorBehavior - leader102 (Candidate) :- Switching from behavior Candidate to Leader, election term: 2 10:27:38,388 AM [test-pekko.actor.default-dispatcher-5] [INFO] Follower - follower103 (Follower): Term 2 in "AppendEntries{term=2, leaderId=leader102, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 1 - updating term 10:27:38,391 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower103: Set currentTerm=2, votedFor=null 10:27:38,391 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - follower103: Last sync leader does not match current leader leader102, need to catch up to -1 10:27:38,391 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader102 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower103 updated: matchIndex: -1, nextIndex: 0 10:27:38,391 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader102 (Leader): Checking sendAppendEntries for follower follower103: active: true, followerNextIndex: 0, leaderLastIndex: -1, leaderSnapShotIndex: -1 [WARN] [02/15/2025 10:27:38.391] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/follower103] unhandled message from Actor[pekko://test/deadLetters]: org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus@28ebe8cd 10:27:38,424 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader102: Persist data SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:38,424 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - leader102: Append log entry and persist SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:38,424 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader102 (Leader): Replicate message: identifier: MockIdentifier{value=zero}, logIndex: 0, isSendImmediate: true 10:27:38,424 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - leader102 (Leader): Setting last applied to 0 10:27:38,424 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorContextImpl - leader102: Moving last applied index from -1 to 0 10:27:38,424 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader102: Applying state for log index 0 data zero 10:27:38,424 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - leader102: applyState called: zero 10:27:38,424 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader102 (Leader): Checking sendAppendEntries for follower follower103: active: true, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 10:27:38,424 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader102 (Leader): sendAppendEntries: 0 is present for follower follower103 10:27:38,424 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader102 (Leader): Sending AppendEntries to follower follower103: AppendEntries{term=2, leaderId=leader102, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=2, payload=zero]]} 10:27:38,425 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader102: Persisting ApplyJournalEntries with index=0 10:27:38,425 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - leader102: persist complete SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:38,425 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader102: Persist data SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=leader102, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=2, payload=zero]]} 10:27:38,425 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - leader102: Append log entry and persist SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): Number of entries to be appended = 1 10:27:38,425 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader102 (Leader): Replicate message: identifier: MockIdentifier{value=one}, logIndex: 1, isSendImmediate: true 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): After cleanup, lastIndex: -1, entries to be added from: 0 10:27:38,425 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - leader102 (Leader): Setting last applied to 1 10:27:38,425 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorContextImpl - leader102: Moving last applied index from 0 to 1 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): Append entry to log zero 10:27:38,425 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader102: Applying state for log index 1 data one 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - follower103: Append log entry and persist SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - follower103: persist complete SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:38,425 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - leader102: applyState called: one 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): Log size is now 1 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): Commit index set to 0 10:27:38,425 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader102 (Leader): Checking sendAppendEntries for follower follower103: active: true, followerNextIndex: 0, leaderLastIndex: 1, leaderSnapShotIndex: -1 10:27:38,425 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader102 (Leader): sendAppendEntries: 0 is present for follower follower103 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=follower103, logLastIndex=0, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:38,425 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader102 (Leader): Sending AppendEntries to follower follower103: AppendEntries{term=2, leaderId=leader102, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=2, payload=zero], SimpleReplicatedLogEntry [index=1, term=2, payload=one]]} 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - follower103: Lagging 0 entries behind leader leader102 and reached 0 (of expected -1) 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 0, context.getLastApplied(): -1, lastIndex(): 0 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - follower103 (Follower): Setting last applied to 0 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorContextImpl - follower103: Moving last applied index from -1 to 0 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - follower103: Applying state for log index 0 data zero 10:27:38,425 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader102: Persisting ApplyJournalEntries with index=1 10:27:38,425 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower103 updated: matchIndex: 0, nextIndex: 1 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [INFO] MockRaftActor - follower103: applyState called: zero 10:27:38,425 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] SnapshotManager - leader102: fakeSnapshot purging log to 0 for term 2 10:27:38,425 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): Checking sendAppendEntries for follower follower103: active: true, followerNextIndex: 1, leaderLastIndex: 1, leaderSnapShotIndex: 0 10:27:38,425 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): sendAppendEntries: 1 is present for follower follower103 10:27:38,425 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): Sending AppendEntries to follower follower103: AppendEntries{term=2, leaderId=leader102, prevLogIndex=0, prevLogTerm=2, leaderCommit=1, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=1, term=2, payload=one]]} 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=leader102, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=2, payload=zero], SimpleReplicatedLogEntry [index=1, term=2, payload=one]]} 10:27:38,425 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] ReplicatedLogImpl - leader102: persist complete SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): Number of entries to be appended = 2 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): matchEntry SimpleReplicatedLogEntry [index=0, term=2, payload=zero] is present: existingEntryTerm: 2 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): After cleanup, lastIndex: 0, entries to be added from: 1 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): Append entry to log one 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - follower103: Append log entry and persist SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - follower103: persist complete SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): Log size is now 2 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): Commit index set to 1 10:27:38,425 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=follower103, logLastIndex=1, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:38,426 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - follower103: Lagging 0 entries behind leader leader102 and reached 1 (of expected -1) 10:27:38,426 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 1, context.getLastApplied(): 0, lastIndex(): 1 10:27:38,426 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - follower103 (Follower): Setting last applied to 1 10:27:38,426 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorContextImpl - follower103: Moving last applied index from 0 to 1 10:27:38,426 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - follower103: Applying state for log index 1 data one 10:27:38,426 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower103 updated: matchIndex: 1, nextIndex: 2 10:27:38,426 AM [test-pekko.actor.default-dispatcher-5] [INFO] MockRaftActor - follower103: applyState called: one 10:27:38,426 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): Checking sendAppendEntries for follower follower103: active: true, followerNextIndex: 2, leaderLastIndex: 1, leaderSnapShotIndex: 0 10:27:38,426 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - follower103: Persisting ApplyJournalEntries with index=0 10:27:38,426 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=leader102, prevLogIndex=0, prevLogTerm=2, leaderCommit=1, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=1, term=2, payload=one]]} 10:27:38,426 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): Number of entries to be appended = 1 10:27:38,426 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): matchEntry SimpleReplicatedLogEntry [index=1, term=2, payload=one] is present: existingEntryTerm: 2 10:27:38,426 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): After cleanup, lastIndex: 1, entries to be added from: 1 10:27:38,426 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): Log size is now 2 10:27:38,426 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=follower103, logLastIndex=1, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:38,426 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - follower103: Lagging 0 entries behind leader leader102 and reached 1 (of expected -1) 10:27:38,426 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - follower103: fakeSnapshot purging log to 0 for term 2 10:27:38,426 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - follower103: Persisting ApplyJournalEntries with index=1 [WARN] [02/15/2025 10:27:38.426] [test-pekko.actor.default-dispatcher-11] [pekko://test/user/follower103] unhandled message from Actor[pekko://test/deadLetters]: org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus@ae1aff6 [WARN] [02/15/2025 10:27:38.488] [test-pekko.actor.default-dispatcher-11] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader102]: org.opendaylight.controller.cluster.common.actor.Monitor@1c317bb1 10:27:38,489 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActor - leader102: Starting recovery with journal batch size 1000 10:27:38,491 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - leader102: Set currentTerm=2, votedFor=leader102 10:27:38,492 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - leader102: Set currentTerm=1, votedFor=leader102 10:27:38,492 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorRecoverySupport - leader102: Received ReplicatedLogEntry for recovery: index: 0, size: 143 10:27:38,492 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorContextImpl - leader102: Updated server config: isVoting: true, peers: [PeerInfo [id=follower103, address=pekko://test/user/follower103, votingState=NON_VOTING]] 10:27:38,492 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActorRecoverySupport - leader102: Recovery completed - Switching actor to Follower - last log index = -1, last log term = -1, snapshot index = -1, snapshot term = -1, journal size = 0 10:27:38,492 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorRecoverySupport - leader102: restoring local TermInfo{term=2, votedFor=leader102} 10:27:38,492 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - leader102: Set currentTerm=2, votedFor=leader102 10:27:38,914 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - leader102 (Follower): Checking if this node is isolated in the cluster unreachable set [],all members [] self member: Member(pekko://test@10.30.170.64:17355, Removed) 10:27:38,914 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - leader102 (Follower): Received ElectionTimeout - switching to Candidate 10:27:38,914 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Candidate - leader102 (Candidate): Election: Candidate has following voting peers: [] 10:27:38,917 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - leader102: Set currentTerm=3, votedFor=leader102 10:27:38,917 AM [test-pekko.actor.default-dispatcher-5] [INFO] Candidate - leader102 (Candidate): Starting new election term 3 10:27:38,917 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActorBehavior - leader102 (Follower) :- Switching from behavior Follower to Candidate, election term: 3 10:27:38,918 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Candidate - leader102 (Candidate): Received ElectionTimeout 10:27:38,918 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader102 (Leader): Election: Leader has following peers: [follower103] 10:27:38,918 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader102 (Leader): Checking sendAppendEntries for follower follower103: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 10:27:38,918 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActorBehavior - leader102 (Candidate) :- Switching from behavior Candidate to Leader, election term: 3 10:27:38,947 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActor - leader102: Persist data SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] 10:27:38,947 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] ReplicatedLogImpl - leader102: Append log entry and persist SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] 10:27:38,947 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): Replicate message: identifier: MockIdentifier{value=zero-1}, logIndex: 0, isSendImmediate: true 10:27:38,947 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActorBehavior - leader102 (Leader): Setting last applied to 0 10:27:38,947 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActorContextImpl - leader102: Moving last applied index from -1 to 0 10:27:38,947 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActor - leader102: Applying state for log index 0 data zero-1 10:27:38,947 AM [test-pekko.actor.default-dispatcher-11] [INFO] MockRaftActor - leader102: applyState called: zero-1 10:27:38,947 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): Checking sendAppendEntries for follower follower103: active: false, followerNextIndex: -1, leaderLastIndex: 0, leaderSnapShotIndex: -1 10:27:38,947 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActor - leader102: Persisting ApplyJournalEntries with index=0 10:27:38,947 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] ReplicatedLogImpl - leader102: persist complete SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] 10:27:38,947 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActor - leader102: Persist data SimpleReplicatedLogEntry [index=1, term=3, payload=one-1] 10:27:38,947 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] ReplicatedLogImpl - leader102: Append log entry and persist SimpleReplicatedLogEntry [index=1, term=3, payload=one-1] 10:27:38,948 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): Replicate message: identifier: MockIdentifier{value=one-1}, logIndex: 1, isSendImmediate: true 10:27:38,948 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActorBehavior - leader102 (Leader): Setting last applied to 1 10:27:38,948 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActorContextImpl - leader102: Moving last applied index from 0 to 1 10:27:38,948 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActor - leader102: Applying state for log index 1 data one-1 10:27:38,948 AM [test-pekko.actor.default-dispatcher-11] [INFO] MockRaftActor - leader102: applyState called: one-1 10:27:38,948 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): Checking sendAppendEntries for follower follower103: active: false, followerNextIndex: -1, leaderLastIndex: 1, leaderSnapShotIndex: -1 10:27:38,948 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActor - leader102: Persisting ApplyJournalEntries with index=1 10:27:38,948 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] ReplicatedLogImpl - leader102: persist complete SimpleReplicatedLogEntry [index=1, term=3, payload=one-1] 10:27:38,948 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActor - leader102: Persist data SimpleReplicatedLogEntry [index=2, term=3, payload=two-1] 10:27:38,948 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] ReplicatedLogImpl - leader102: Append log entry and persist SimpleReplicatedLogEntry [index=2, term=3, payload=two-1] 10:27:38,948 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): Replicate message: identifier: MockIdentifier{value=two-1}, logIndex: 2, isSendImmediate: true 10:27:38,948 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActorBehavior - leader102 (Leader): Setting last applied to 2 10:27:38,948 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActorContextImpl - leader102: Moving last applied index from 1 to 2 10:27:38,948 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActor - leader102: Applying state for log index 2 data two-1 10:27:38,948 AM [test-pekko.actor.default-dispatcher-11] [INFO] MockRaftActor - leader102: applyState called: two-1 10:27:38,948 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): Checking sendAppendEntries for follower follower103: active: false, followerNextIndex: -1, leaderLastIndex: 2, leaderSnapShotIndex: -1 10:27:38,948 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActor - leader102: Persisting ApplyJournalEntries with index=2 10:27:38,949 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] ReplicatedLogImpl - leader102: persist complete SimpleReplicatedLogEntry [index=2, term=3, payload=two-1] 10:27:39,34 AM [test-pekko.actor.default-dispatcher-11] [INFO] Follower - follower103 (Follower): Term 3 in "AppendEntries{term=3, leaderId=leader102, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 2 - updating term 10:27:39,37 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] PropertiesTermInfoStore - follower103: Set currentTerm=3, votedFor=null 10:27:39,38 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] SyncStatusTracker - follower103: Lagging -2 entries behind leader leader102 and reached 1 (of expected -1) 10:27:39,38 AM [test-pekko.actor.default-dispatcher-11] [INFO] AbstractLeader - leader102 (Leader): handleAppendEntriesReply: follower follower103 last log term 2 for index 1 conflicts with the leader's 3 - set the follower's next index to 0 10:27:39,38 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): Checking sendAppendEntries for follower follower103: active: true, followerNextIndex: 0, leaderLastIndex: 2, leaderSnapShotIndex: -1 10:27:39,38 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): sendAppendEntries: 0 is present for follower follower103 10:27:39,38 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): Sending AppendEntries to follower follower103: AppendEntries{term=3, leaderId=leader102, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=2, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1], SimpleReplicatedLogEntry [index=1, term=3, payload=one-1], SimpleReplicatedLogEntry [index=2, term=3, payload=two-1]]} 10:27:39,38 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower103 (Follower): handleAppendEntries: AppendEntries{term=3, leaderId=leader102, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=2, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1], SimpleReplicatedLogEntry [index=1, term=3, payload=one-1], SimpleReplicatedLogEntry [index=2, term=3, payload=two-1]]} 10:27:39,38 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower103 (Follower): Number of entries to be appended = 3 10:27:39,38 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower103 (Follower): matchEntry SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] is present: existingEntryTerm: 2 10:27:39,38 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] DefaultConfigParamsImpl - No custom RaftPolicy specified. Using DefaultRaftPolicy 10:27:39,38 AM [test-pekko.actor.default-dispatcher-11] [INFO] Follower - follower103 (Follower): Removing entries from log starting at 0, commitIndex: 1, lastApplied: 1 10:27:39,38 AM [test-pekko.actor.default-dispatcher-11] [INFO] Follower - follower103 (Follower): Could not remove entries - sending reply to force snapshot 10:27:39,38 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] SyncStatusTracker - follower103: Lagging 1 entries behind leader leader102 and reached 1 (of expected -1) 10:27:39,38 AM [test-pekko.actor.default-dispatcher-11] [INFO] AbstractLeader - leader102 (Leader): handleAppendEntriesReply - received unsuccessful reply: AppendEntriesReply{term=3, success=false, followerId=follower103, logLastIndex=1, logLastTerm=2, forceInstallSnapshot=true, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5}, leader snapshotIndex: -1, snapshotTerm: -1, replicatedToAllIndex: -1 10:27:39,39 AM [test-pekko.actor.default-dispatcher-11] [INFO] SnapshotManager - leader102: Initiating snapshot capture CaptureSnapshot [lastAppliedIndex=2, lastAppliedTerm=3, lastIndex=2, lastTerm=3, installSnapshotInitiated=, replicatedToAllIndex=-1, replicatedToAllTerm=-1, unAppliedEntries size=0, mandatoryTrim=false] to install on follower103 10:27:39,39 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] SnapshotManager - leader102: lastSequenceNumber prior to capture: -1 10:27:39,39 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActorSnapshotMessageSupport - leader102: CaptureSnapshotReply received by actor 10:27:39,39 AM [test-pekko.actor.default-dispatcher-11] [INFO] SnapshotManager - leader102: Persisting of snapshot done: Snapshot [lastIndex=2, lastTerm=3, lastAppliedIndex=2, lastAppliedTerm=3, unAppliedEntries size=0, state=MockSnapshotState [state=[zero-1, one-1, two-1]], electionTerm=3, electionVotedFor=leader102, ServerConfigPayload=ClusterConfig{serverInfo=[ServerInfo[peerId=follower103, isVoting=false], ServerInfo[peerId=leader102, isVoting=true]]}] 10:27:39,39 AM [test-pekko.actor.default-dispatcher-11] [INFO] SnapshotManager - leader102: Removed in-memory snapshotted entries, adjusted snaphsotIndex: -1 and term: -1 10:27:39,39 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): sendInstallSnapshot 10:27:39,39 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] LeaderInstallSnapshotState - leader102 (Leader): Snapshot 351 bytes, total chunks to send: 1 10:27:39,39 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] LeaderInstallSnapshotState - leader102 (Leader): Next chunk: total length=351, offset=0, size=351, hashCode=236499276 10:27:39,39 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): next snapshot chunk size for follower follower103: 351 10:27:39,39 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader102 (Leader): InstallSnapshot sent to follower Vector(user, follower103), Chunk: 1/1 10:27:39,40 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] SnapshotManager - leader102: Snapshot success - sequence number: -1 10:27:39,40 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActorSnapshotMessageSupport - leader102: SnapshotComplete received 10:27:39,40 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): handleInstallSnapshot: InstallSnapshot{term=3, leaderId=leader102, lastIncludedIndex=2, lastIncludedTerm=3, datasize=351, chunk=1/1, lastChunkHashCode=OptionalInt[-1], serverConfig=ClusterConfig{serverInfo=[ServerInfo[peerId=follower103, isVoting=false], ServerInfo[peerId=leader102, isVoting=true]]}} 10:27:39,40 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - follower103: Lagging 1 entries behind leader leader102 and reached 1 (of expected -1) 10:27:39,40 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotTracker - follower103 (Follower): addChunk: chunkIndex=1, lastChunkIndex=0, collectedChunks.size=0, lastChunkHashCode=-1 10:27:39,40 AM [test-pekko.actor.default-dispatcher-5] [INFO] Follower - follower103 (Follower): Snapshot received from leader: leader102 10:27:39,40 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - follower103: Applying snapshot on follower: org.opendaylight.controller.cluster.io.FileBackedOutputStream$1@387f55f6 10:27:39,41 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - follower103: Converted InstallSnapshot from leader: leader102 to state 10:27:39,41 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - follower103: lastSequenceNumber prior to persisting applied snapshot: -1 10:27:39,41 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - follower103: Snapshot success - sequence number: -1 10:27:39,41 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorContextImpl - follower103: Moving last applied index from 1 to 2 10:27:39,41 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower103: Set currentTerm=3, votedFor=null 10:27:39,41 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorContextImpl - follower103: Updated server config: isVoting: false, peers: [PeerInfo [id=leader102, address=pekko://test/user/leader102, votingState=VOTING]] 10:27:39,41 AM [test-pekko.actor.default-dispatcher-5] [INFO] MockRaftActor - follower103: applySnapshot called 10:27:39,41 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower103 (Follower): handleInstallSnapshot returning: InstallSnapshotReply{term=3, followerId=follower103, chunkIndex=1, success=true} 10:27:39,41 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader102 (Leader): handleInstallSnapshotReply: InstallSnapshotReply{term=3, followerId=follower103, chunkIndex=1, success=true} 10:27:39,41 AM [test-pekko.actor.default-dispatcher-18] [INFO] AbstractLeader - leader102 (Leader): Snapshot successfully installed on follower follower103 (last chunk 1) - matchIndex set to 2, nextIndex set to 3 10:27:39,41 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] SnapshotManager - leader102: fakeSnapshot purging log to 1 for term 3 10:27:39,41 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorSnapshotMessageSupport - follower103: SnapshotComplete received 10:27:39,48 AM [main] [INFO] NonVotingFollowerIntegrationTest - testFollowerResyncWithOneMoreLeaderLogEntryAfterNonPersistentLeaderRestart ending 10:27:39,48 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/follower103-collector105#742347342] 10:27:39,49 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower103] 10:27:39,50 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/leader102-collector106#344144041] 10:27:39,50 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader102] 10:27:39,50 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/leader102-collector107#757792345] 10:27:39,50 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader102] 10:27:39,53 AM [main] [INFO] NonVotingFollowerIntegrationTest - testFollowerResyncWithMoreLeaderLogEntriesAndDownPeerAfterNonPersistentLeaderRestart starting [WARN] [02/15/2025 10:27:39.055] [test-pekko.actor.default-dispatcher-18] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/follower109]: org.opendaylight.controller.cluster.common.actor.Monitor@1fcbcc52 10:27:39,56 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActor - follower109: Starting recovery with journal batch size 1000 [WARN] [02/15/2025 10:27:39.058] [test-pekko.actor.default-dispatcher-18] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader108]: org.opendaylight.controller.cluster.common.actor.Monitor@79643ba3 10:27:39,59 AM [test-pekko.actor.default-dispatcher-11] [INFO] RaftActor - leader108: Starting recovery with journal batch size 1000 10:27:39,59 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest13655141066554199168/follower109/TermInfo.properties does not exist java.nio.file.NoSuchFileException: /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest13655141066554199168/follower109/TermInfo.properties at java.base/sun.nio.fs.UnixException.translateToIOException(UnixException.java:92) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:106) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:111) at java.base/sun.nio.fs.UnixFileSystemProvider.newByteChannel(UnixFileSystemProvider.java:261) at java.base/java.nio.file.Files.newByteChannel(Files.java:379) at java.base/java.nio.file.Files.newByteChannel(Files.java:431) at java.base/java.nio.file.spi.FileSystemProvider.newInputStream(FileSystemProvider.java:420) at java.base/java.nio.file.Files.newInputStream(Files.java:159) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadFile(PropertiesTermInfoStore.java:108) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadAndSetTerm(PropertiesTermInfoStore.java:78) at org.opendaylight.controller.cluster.raft.RaftActorRecoverySupport.(RaftActorRecoverySupport.java:62) at org.opendaylight.controller.cluster.raft.RaftActor.newRaftActorRecoverySupport(RaftActor.java:181) at org.opendaylight.controller.cluster.raft.MockRaftActor.newRaftActorRecoverySupport(MockRaftActor.java:85) at org.opendaylight.controller.cluster.raft.RaftActor.handleRecover(RaftActor.java:166) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:33) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:29) at scala.PartialFunction.applyOrElse(PartialFunction.scala:214) at scala.PartialFunction.applyOrElse$(PartialFunction.scala:213) at org.apache.pekko.japi.pf.UnitCaseStatement.applyOrElse(CaseStatements.scala:29) at scala.PartialFunction$OrElse.apply(PartialFunction.scala:266) at org.apache.pekko.persistence.Eventsourced$$anon$2$$anonfun$1.applyOrElse(Eventsourced.scala:651) at org.apache.pekko.actor.Actor.aroundReceive(Actor.scala:547) at org.apache.pekko.actor.Actor.aroundReceive$(Actor.scala:545) at org.apache.pekko.persistence.AbstractPersistentActor.org$apache$pekko$persistence$Eventsourced$$super$aroundReceive(PersistentActor.scala:305) at org.apache.pekko.persistence.Eventsourced$$anon$3.stateReceive(Eventsourced.scala:769) at org.apache.pekko.persistence.Eventsourced.aroundReceive(Eventsourced.scala:256) at org.apache.pekko.persistence.Eventsourced.aroundReceive$(Eventsourced.scala:255) at org.apache.pekko.persistence.AbstractPersistentActor.aroundReceive(PersistentActor.scala:305) at org.apache.pekko.actor.ActorCell.receiveMessage(ActorCell.scala:590) at org.apache.pekko.actor.ActorCell.invoke(ActorCell.scala:557) at org.apache.pekko.dispatch.Mailbox.processMailbox(Mailbox.scala:280) at org.apache.pekko.dispatch.Mailbox.run(Mailbox.scala:241) at org.apache.pekko.dispatch.Mailbox.exec(Mailbox.scala:253) at java.base/java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:387) at java.base/java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1312) at java.base/java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1843) at java.base/java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1808) at java.base/java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:188) 10:27:39,60 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower109: Set currentTerm=1, votedFor=leader108 10:27:39,60 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest13655141066554199168/leader108/TermInfo.properties does not exist java.nio.file.NoSuchFileException: /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest13655141066554199168/leader108/TermInfo.properties at java.base/sun.nio.fs.UnixException.translateToIOException(UnixException.java:92) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:106) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:111) at java.base/sun.nio.fs.UnixFileSystemProvider.newByteChannel(UnixFileSystemProvider.java:261) at java.base/java.nio.file.Files.newByteChannel(Files.java:379) at java.base/java.nio.file.Files.newByteChannel(Files.java:431) at java.base/java.nio.file.spi.FileSystemProvider.newInputStream(FileSystemProvider.java:420) at java.base/java.nio.file.Files.newInputStream(Files.java:159) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadFile(PropertiesTermInfoStore.java:108) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadAndSetTerm(PropertiesTermInfoStore.java:78) at org.opendaylight.controller.cluster.raft.RaftActorRecoverySupport.(RaftActorRecoverySupport.java:62) at org.opendaylight.controller.cluster.raft.RaftActor.newRaftActorRecoverySupport(RaftActor.java:181) at org.opendaylight.controller.cluster.raft.MockRaftActor.newRaftActorRecoverySupport(MockRaftActor.java:85) at org.opendaylight.controller.cluster.raft.RaftActor.handleRecover(RaftActor.java:166) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:33) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:29) at scala.PartialFunction.applyOrElse(PartialFunction.scala:214) at scala.PartialFunction.applyOrElse$(PartialFunction.scala:213) at org.apache.pekko.japi.pf.UnitCaseStatement.applyOrElse(CaseStatements.scala:29) at scala.PartialFunction$OrElse.apply(PartialFunction.scala:266) at org.apache.pekko.persistence.Eventsourced$$anon$2$$anonfun$1.applyOrElse(Eventsourced.scala:651) at org.apache.pekko.actor.Actor.aroundReceive(Actor.scala:547) at org.apache.pekko.actor.Actor.aroundReceive$(Actor.scala:545) at org.apache.pekko.persistence.AbstractPersistentActor.org$apache$pekko$persistence$Eventsourced$$super$aroundReceive(PersistentActor.scala:305) at org.apache.pekko.persistence.Eventsourced$$anon$3.stateReceive(Eventsourced.scala:769) at org.apache.pekko.persistence.Eventsourced.aroundReceive(Eventsourced.scala:256) at org.apache.pekko.persistence.Eventsourced.aroundReceive$(Eventsourced.scala:255) at org.apache.pekko.persistence.AbstractPersistentActor.aroundReceive(PersistentActor.scala:305) at org.apache.pekko.actor.ActorCell.receiveMessage(ActorCell.scala:590) at org.apache.pekko.actor.ActorCell.invoke(ActorCell.scala:557) at org.apache.pekko.dispatch.Mailbox.processMailbox(Mailbox.scala:280) at org.apache.pekko.dispatch.Mailbox.run(Mailbox.scala:241) at org.apache.pekko.dispatch.Mailbox.exec(Mailbox.scala:253) at java.base/java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:387) at java.base/java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1312) at java.base/java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1843) at java.base/java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1808) at java.base/java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:188) 10:27:39,61 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - leader108: Set currentTerm=1, votedFor=leader108 10:27:39,61 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorRecoverySupport - leader108: Received ReplicatedLogEntry for recovery: index: 0, size: 143 10:27:39,61 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorContextImpl - leader108: Updated server config: isVoting: true, peers: [PeerInfo [id=follower109, address=pekko://test/user/follower109, votingState=NON_VOTING]] 10:27:39,61 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorRecoverySupport - leader108: Recovery completed - Switching actor to Follower - last log index = -1, last log term = -1, snapshot index = -1, snapshot term = -1, journal size = 0 10:27:39,62 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorRecoverySupport - follower109: Received ReplicatedLogEntry for recovery: index: 0, size: 143 10:27:39,62 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorContextImpl - follower109: Updated server config: isVoting: false, peers: [PeerInfo [id=leader108, address=pekko://test/user/leader108, votingState=VOTING]] 10:27:39,62 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActorRecoverySupport - follower109: Recovery completed - Switching actor to Follower - last log index = -1, last log term = -1, snapshot index = -1, snapshot term = -1, journal size = 0 10:27:39,67 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - leader108: Set currentTerm=1, votedFor=leader108 10:27:39,67 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorRecoverySupport - leader108: Local TermInfo store seeded with TermInfo{term=1, votedFor=leader108} 10:27:39,68 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower109: Set currentTerm=1, votedFor=leader108 10:27:39,68 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActorRecoverySupport - follower109: Local TermInfo store seeded with TermInfo{term=1, votedFor=leader108} 10:27:39,513 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] DefaultConfigParamsImpl - No custom RaftPolicy specified. Using DefaultRaftPolicy 10:27:39,514 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - leader108 (Follower): Checking if this node is isolated in the cluster unreachable set [],all members [] self member: Member(pekko://test@10.30.170.64:17355, Removed) 10:27:39,514 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - leader108 (Follower): Received ElectionTimeout - switching to Candidate 10:27:39,514 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Candidate - leader108 (Candidate): Election: Candidate has following voting peers: [] 10:27:39,517 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - leader108: Set currentTerm=2, votedFor=leader108 10:27:39,517 AM [test-pekko.actor.default-dispatcher-17] [INFO] Candidate - leader108 (Candidate): Starting new election term 2 10:27:39,517 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorBehavior - leader108 (Follower) :- Switching from behavior Follower to Candidate, election term: 2 10:27:39,518 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Candidate - leader108 (Candidate): Received ElectionTimeout 10:27:39,518 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): Election: Leader has following peers: [follower109] 10:27:39,518 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower109: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 10:27:39,518 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorBehavior - leader108 (Candidate) :- Switching from behavior Candidate to Leader, election term: 2 10:27:39,518 AM [test-pekko.actor.default-dispatcher-5] [INFO] Follower - follower109 (Follower): Term 2 in "AppendEntries{term=2, leaderId=leader108, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 1 - updating term 10:27:39,521 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower109: Set currentTerm=2, votedFor=null 10:27:39,522 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - follower109: Last sync leader does not match current leader leader108, need to catch up to -1 10:27:39,522 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower109 updated: matchIndex: -1, nextIndex: 0 10:27:39,522 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower109: active: true, followerNextIndex: 0, leaderLastIndex: -1, leaderSnapShotIndex: -1 [WARN] [02/15/2025 10:27:39.522] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/follower109] unhandled message from Actor[pekko://test/deadLetters]: org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus@51d7bfa 10:27:39,572 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader108: Persist data SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:39,572 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - leader108: Append log entry and persist SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:39,572 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader108 (Leader): Replicate message: identifier: MockIdentifier{value=zero}, logIndex: 0, isSendImmediate: true 10:27:39,572 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - leader108 (Leader): Setting last applied to 0 10:27:39,572 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorContextImpl - leader108: Moving last applied index from -1 to 0 10:27:39,572 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader108: Applying state for log index 0 data zero 10:27:39,573 AM [test-pekko.actor.default-dispatcher-5] [INFO] MockRaftActor - leader108: applyState called: zero 10:27:39,573 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower109: active: true, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 10:27:39,573 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader108 (Leader): sendAppendEntries: 0 is present for follower follower109 10:27:39,573 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader108 (Leader): Sending AppendEntries to follower follower109: AppendEntries{term=2, leaderId=leader108, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=2, payload=zero]]} 10:27:39,573 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader108: Persisting ApplyJournalEntries with index=0 10:27:39,573 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - leader108: persist complete SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:39,573 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower109 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=leader108, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=2, payload=zero]]} 10:27:39,573 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader108: Persist data SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:39,573 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower109 (Follower): Number of entries to be appended = 1 10:27:39,573 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - leader108: Append log entry and persist SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:39,573 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower109 (Follower): After cleanup, lastIndex: -1, entries to be added from: 0 10:27:39,573 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower109 (Follower): Append entry to log zero 10:27:39,573 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader108 (Leader): Replicate message: identifier: MockIdentifier{value=one}, logIndex: 1, isSendImmediate: true 10:27:39,573 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] ReplicatedLogImpl - follower109: Append log entry and persist SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:39,573 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - leader108 (Leader): Setting last applied to 1 10:27:39,573 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] ReplicatedLogImpl - follower109: persist complete SimpleReplicatedLogEntry [index=0, term=2, payload=zero] 10:27:39,573 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorContextImpl - leader108: Moving last applied index from 0 to 1 10:27:39,573 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader108: Applying state for log index 1 data one 10:27:39,573 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower109 (Follower): Log size is now 1 10:27:39,573 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower109 (Follower): Commit index set to 0 10:27:39,573 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower109 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=follower109, logLastIndex=0, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:39,573 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SyncStatusTracker - follower109: Lagging 0 entries behind leader leader108 and reached 0 (of expected -1) 10:27:39,573 AM [test-pekko.actor.default-dispatcher-5] [INFO] MockRaftActor - leader108: applyState called: one 10:27:39,573 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower109 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 0, context.getLastApplied(): -1, lastIndex(): 0 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorBehavior - follower109 (Follower): Setting last applied to 0 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorContextImpl - follower109: Moving last applied index from -1 to 0 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActor - follower109: Applying state for log index 0 data zero 10:27:39,574 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower109: active: true, followerNextIndex: 0, leaderLastIndex: 1, leaderSnapShotIndex: -1 10:27:39,574 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader108 (Leader): sendAppendEntries: 0 is present for follower follower109 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [INFO] MockRaftActor - follower109: applyState called: zero 10:27:39,574 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader108 (Leader): Sending AppendEntries to follower follower109: AppendEntries{term=2, leaderId=leader108, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=2, payload=zero], SimpleReplicatedLogEntry [index=1, term=2, payload=one]]} 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActor - follower109: Persisting ApplyJournalEntries with index=0 10:27:39,574 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader108 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower109 updated: matchIndex: 0, nextIndex: 1 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower109 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=leader108, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=2, payload=zero], SimpleReplicatedLogEntry [index=1, term=2, payload=one]]} 10:27:39,574 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - leader108: fakeSnapshot purging log to 0 for term 2 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower109 (Follower): Number of entries to be appended = 2 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower109 (Follower): matchEntry SimpleReplicatedLogEntry [index=0, term=2, payload=zero] is present: existingEntryTerm: 2 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower109 (Follower): After cleanup, lastIndex: 0, entries to be added from: 1 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower109 (Follower): Append entry to log one 10:27:39,574 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower109: active: true, followerNextIndex: 1, leaderLastIndex: 1, leaderSnapShotIndex: 0 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] ReplicatedLogImpl - follower109: Append log entry and persist SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:39,574 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader108 (Leader): sendAppendEntries: 1 is present for follower follower109 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] ReplicatedLogImpl - follower109: persist complete SimpleReplicatedLogEntry [index=1, term=2, payload=one] 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower109 (Follower): Log size is now 2 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower109 (Follower): Commit index set to 1 10:27:39,574 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader108 (Leader): Sending AppendEntries to follower follower109: AppendEntries{term=2, leaderId=leader108, prevLogIndex=0, prevLogTerm=2, leaderCommit=1, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=1, term=2, payload=one]]} 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower109 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=follower109, logLastIndex=1, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SyncStatusTracker - follower109: Lagging 0 entries behind leader leader108 and reached 1 (of expected -1) 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower109 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 1, context.getLastApplied(): 0, lastIndex(): 1 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorBehavior - follower109 (Follower): Setting last applied to 1 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorContextImpl - follower109: Moving last applied index from 0 to 1 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActor - follower109: Applying state for log index 1 data one 10:27:39,574 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActor - leader108: Persisting ApplyJournalEntries with index=1 10:27:39,574 AM [test-pekko.actor.default-dispatcher-17] [INFO] MockRaftActor - follower109: applyState called: one 10:27:39,574 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower109 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=leader108, prevLogIndex=0, prevLogTerm=2, leaderCommit=1, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=1, term=2, payload=one]]} 10:27:39,575 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower109 (Follower): Number of entries to be appended = 1 10:27:39,575 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower109 (Follower): matchEntry SimpleReplicatedLogEntry [index=1, term=2, payload=one] is present: existingEntryTerm: 2 10:27:39,575 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower109 (Follower): After cleanup, lastIndex: 1, entries to be added from: 1 10:27:39,575 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower109 (Follower): Log size is now 2 10:27:39,575 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower109 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=follower109, logLastIndex=1, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:39,575 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower109: Lagging 0 entries behind leader leader108 and reached 1 (of expected -1) 10:27:39,575 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - follower109: fakeSnapshot purging log to 0 for term 2 10:27:39,575 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower109: Persisting ApplyJournalEntries with index=1 10:27:39,575 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] ReplicatedLogImpl - leader108: persist complete SimpleReplicatedLogEntry [index=1, term=2, payload=one] [WARN] [02/15/2025 10:27:39.575] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/follower109] unhandled message from Actor[pekko://test/deadLetters]: org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus@ee6dd5 10:27:39,575 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader108 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower109 updated: matchIndex: 1, nextIndex: 2 10:27:39,575 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower109: active: true, followerNextIndex: 2, leaderLastIndex: 1, leaderSnapShotIndex: 0 10:27:39,575 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader108: Persist data SimpleReplicatedLogEntry [index=2, term=2, payload=two] 10:27:39,575 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - leader108: Append log entry and persist SimpleReplicatedLogEntry [index=2, term=2, payload=two] 10:27:39,576 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): Replicate message: identifier: MockIdentifier{value=two}, logIndex: 2, isSendImmediate: true 10:27:39,576 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - leader108 (Leader): Setting last applied to 2 10:27:39,576 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorContextImpl - leader108: Moving last applied index from 1 to 2 10:27:39,576 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader108: Applying state for log index 2 data two 10:27:39,576 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - leader108: applyState called: two 10:27:39,576 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower109: active: true, followerNextIndex: 2, leaderLastIndex: 2, leaderSnapShotIndex: 0 10:27:39,576 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): sendAppendEntries: 2 is present for follower follower109 10:27:39,576 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): Sending AppendEntries to follower follower109: AppendEntries{term=2, leaderId=leader108, prevLogIndex=1, prevLogTerm=2, leaderCommit=2, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=2, term=2, payload=two]]} 10:27:39,576 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader108: Persisting ApplyJournalEntries with index=2 10:27:39,576 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - leader108: persist complete SimpleReplicatedLogEntry [index=2, term=2, payload=two] 10:27:39,576 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - leader108: fakeSnapshot purging log to 1 for term 2 10:27:39,576 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower109 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=leader108, prevLogIndex=1, prevLogTerm=2, leaderCommit=2, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=2, term=2, payload=two]]} 10:27:39,576 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower109 (Follower): Number of entries to be appended = 1 10:27:39,576 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower109 (Follower): After cleanup, lastIndex: 1, entries to be added from: 0 10:27:39,576 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower109 (Follower): Append entry to log two 10:27:39,576 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] ReplicatedLogImpl - follower109: Append log entry and persist SimpleReplicatedLogEntry [index=2, term=2, payload=two] 10:27:39,576 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] ReplicatedLogImpl - follower109: persist complete SimpleReplicatedLogEntry [index=2, term=2, payload=two] 10:27:39,576 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower109 (Follower): Log size is now 2 10:27:39,576 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower109 (Follower): Commit index set to 2 10:27:39,576 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower109 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=follower109, logLastIndex=2, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:39,576 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] SyncStatusTracker - follower109: Lagging 0 entries behind leader leader108 and reached 2 (of expected -1) 10:27:39,576 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower109 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 2, context.getLastApplied(): 1, lastIndex(): 2 10:27:39,576 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActorBehavior - follower109 (Follower): Setting last applied to 2 10:27:39,576 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActorContextImpl - follower109: Moving last applied index from 1 to 2 10:27:39,576 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActor - follower109: Applying state for log index 2 data two 10:27:39,577 AM [test-pekko.actor.default-dispatcher-11] [INFO] MockRaftActor - follower109: applyState called: two 10:27:39,577 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower109 updated: matchIndex: 2, nextIndex: 3 10:27:39,577 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower109: active: true, followerNextIndex: 3, leaderLastIndex: 2, leaderSnapShotIndex: 1 10:27:39,577 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActor - follower109: Persisting ApplyJournalEntries with index=2 10:27:39,755 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] SyncStatusTracker - follower109: Lagging 0 entries behind leader leader108 and reached 2 (of expected -1) 10:27:39,755 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] SnapshotManager - follower109: fakeSnapshot purging log to 1 for term 2 10:27:39,788 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActor - follower110: Starting recovery with journal batch size 1000 [WARN] [02/15/2025 10:27:39.788] [test-pekko.actor.default-dispatcher-17] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/follower110]: org.opendaylight.controller.cluster.common.actor.Monitor@6a5e50b1 10:27:39,790 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest13655141066554199168/follower110/TermInfo.properties does not exist java.nio.file.NoSuchFileException: /tmp/org.opendaylight.controller.cluster.raft.NonVotingFollowerIntegrationTest13655141066554199168/follower110/TermInfo.properties at java.base/sun.nio.fs.UnixException.translateToIOException(UnixException.java:92) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:106) at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:111) at java.base/sun.nio.fs.UnixFileSystemProvider.newByteChannel(UnixFileSystemProvider.java:261) at java.base/java.nio.file.Files.newByteChannel(Files.java:379) at java.base/java.nio.file.Files.newByteChannel(Files.java:431) at java.base/java.nio.file.spi.FileSystemProvider.newInputStream(FileSystemProvider.java:420) at java.base/java.nio.file.Files.newInputStream(Files.java:159) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadFile(PropertiesTermInfoStore.java:108) at org.opendaylight.controller.cluster.raft.PropertiesTermInfoStore.loadAndSetTerm(PropertiesTermInfoStore.java:78) at org.opendaylight.controller.cluster.raft.RaftActorRecoverySupport.(RaftActorRecoverySupport.java:62) at org.opendaylight.controller.cluster.raft.RaftActor.newRaftActorRecoverySupport(RaftActor.java:181) at org.opendaylight.controller.cluster.raft.MockRaftActor.newRaftActorRecoverySupport(MockRaftActor.java:85) at org.opendaylight.controller.cluster.raft.RaftActor.handleRecover(RaftActor.java:166) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:33) at org.apache.pekko.japi.pf.UnitCaseStatement.apply(CaseStatements.scala:29) at scala.PartialFunction.applyOrElse(PartialFunction.scala:214) at scala.PartialFunction.applyOrElse$(PartialFunction.scala:213) at org.apache.pekko.japi.pf.UnitCaseStatement.applyOrElse(CaseStatements.scala:29) at scala.PartialFunction$OrElse.apply(PartialFunction.scala:266) at org.apache.pekko.persistence.Eventsourced$$anon$2$$anonfun$1.applyOrElse(Eventsourced.scala:651) at org.apache.pekko.actor.Actor.aroundReceive(Actor.scala:547) at org.apache.pekko.actor.Actor.aroundReceive$(Actor.scala:545) at org.apache.pekko.persistence.AbstractPersistentActor.org$apache$pekko$persistence$Eventsourced$$super$aroundReceive(PersistentActor.scala:305) at org.apache.pekko.persistence.Eventsourced$$anon$3.stateReceive(Eventsourced.scala:769) at org.apache.pekko.persistence.Eventsourced.aroundReceive(Eventsourced.scala:256) at org.apache.pekko.persistence.Eventsourced.aroundReceive$(Eventsourced.scala:255) at org.apache.pekko.persistence.AbstractPersistentActor.aroundReceive(PersistentActor.scala:305) at org.apache.pekko.actor.ActorCell.receiveMessage(ActorCell.scala:590) at org.apache.pekko.actor.ActorCell.invoke(ActorCell.scala:557) at org.apache.pekko.dispatch.Mailbox.processMailbox(Mailbox.scala:280) at org.apache.pekko.dispatch.Mailbox.run(Mailbox.scala:241) at org.apache.pekko.dispatch.Mailbox.exec(Mailbox.scala:253) at java.base/java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:387) at java.base/java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1312) at java.base/java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1843) at java.base/java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1808) at java.base/java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:188) 10:27:39,790 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorRecoverySupport - follower110: Received ReplicatedLogEntry for recovery: index: 0, size: 174 10:27:39,790 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorContextImpl - follower110: Updated server config: isVoting: true, peers: [PeerInfo [id=follower109, address=pekko://test/user/follower109, votingState=NON_VOTING], PeerInfo [id=downPeer, address=null, votingState=NON_VOTING], PeerInfo [id=leader108, address=pekko://test/user/leader108, votingState=VOTING]] 10:27:39,790 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorRecoverySupport - follower110: Recovery completed - Switching actor to Follower - last log index = -1, last log term = -1, snapshot index = -1, snapshot term = -1, journal size = 0 10:27:39,795 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - follower110: Set currentTerm=0, votedFor=null 10:27:39,795 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorRecoverySupport - follower110: Local TermInfo store seeded with TermInfo{term=0} [WARN] [02/15/2025 10:27:39.797] [test-pekko.actor.default-dispatcher-17] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader108]: org.opendaylight.controller.cluster.common.actor.Monitor@753e0e92 10:27:39,797 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActor - leader108: Starting recovery with journal batch size 1000 10:27:39,799 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - leader108: Set currentTerm=2, votedFor=leader108 10:27:39,799 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - leader108: Set currentTerm=2, votedFor=leader108 10:27:39,799 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorRecoverySupport - leader108: Received ReplicatedLogEntry for recovery: index: 0, size: 174 10:27:39,799 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorContextImpl - leader108: Updated server config: isVoting: true, peers: [PeerInfo [id=follower109, address=pekko://test/user/follower109, votingState=NON_VOTING], PeerInfo [id=downPeer, address=null, votingState=NON_VOTING], PeerInfo [id=follower110, address=pekko://test/user/follower110, votingState=VOTING]] 10:27:39,799 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorRecoverySupport - leader108: Recovery completed - Switching actor to Follower - last log index = -1, last log term = -1, snapshot index = -1, snapshot term = -1, journal size = 0 10:27:39,799 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorRecoverySupport - leader108: restoring local TermInfo{term=2, votedFor=leader108} 10:27:39,799 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - leader108: Set currentTerm=2, votedFor=leader108 10:27:40,314 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - leader108 (Follower): Checking if this node is isolated in the cluster unreachable set [],all members [] self member: Member(pekko://test@10.30.170.64:17355, Removed) 10:27:40,314 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - leader108 (Follower): Received ElectionTimeout - switching to Candidate 10:27:40,314 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Candidate - leader108 (Candidate): Election: Candidate has following voting peers: [follower110] 10:27:40,317 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] PropertiesTermInfoStore - leader108: Set currentTerm=3, votedFor=leader108 10:27:40,317 AM [test-pekko.actor.default-dispatcher-17] [INFO] Candidate - leader108 (Candidate): Starting new election term 3 10:27:40,318 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Candidate - leader108 (Candidate): Sending RequestVote{term=3, candidateId=leader108, lastLogIndex=-1, lastLogTerm=-1} to peer follower110 10:27:40,318 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorBehavior - leader108 (Follower) :- Switching from behavior Follower to Candidate, election term: 3 10:27:40,318 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - follower110 (Follower): Found higher term in RequestVote rpc, verifying whether it's safe to update term. 10:27:40,318 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - follower110 (Follower): Cluster state: [] 10:27:40,318 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - follower110 (Follower): Candidate in requestVote:RequestVote{term=3, candidateId=leader108, lastLogIndex=-1, lastLogTerm=-1} with higher term appears reachable, updating term. 10:27:40,318 AM [test-pekko.actor.default-dispatcher-5] [INFO] Follower - follower110 (Follower): Term 3 in "RequestVote{term=3, candidateId=leader108, lastLogIndex=-1, lastLogTerm=-1}" message is greater than follower's term 0 - updating term 10:27:40,321 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower110: Set currentTerm=3, votedFor=null 10:27:40,321 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - follower110 (Follower): In requestVote: RequestVote{term=3, candidateId=leader108, lastLogIndex=-1, lastLogTerm=-1} - currentTerm: 3, votedFor: null, lastIndex: -1, lastTerm: -1 10:27:40,324 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower110: Set currentTerm=3, votedFor=leader108 10:27:40,324 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - follower110 (Follower): requestVote returning: RequestVoteReply{term=3, voteGranted=true} 10:27:40,324 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Candidate - leader108 (Candidate): RaftRPC message received RequestVoteReply{term=3, voteGranted=true}, my term is 3 10:27:40,324 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Candidate - leader108 (Candidate): handleRequestVoteReply: RequestVoteReply{term=3, voteGranted=true}, current voteCount: 1 10:27:40,324 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): Election: Leader has following peers: [follower109, downPeer, follower110] 10:27:40,324 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower109: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 10:27:40,324 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower110: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 10:27:40,324 AM [test-pekko.actor.default-dispatcher-17] [INFO] RaftActorBehavior - leader108 (Candidate) :- Switching from behavior Candidate to Leader, election term: 3 10:27:40,325 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] SyncStatusTracker - follower110: Last sync leader does not match current leader leader108, need to catch up to -1 10:27:40,325 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower110 updated: matchIndex: -1, nextIndex: 0 [WARN] [02/15/2025 10:27:40.325] [test-pekko.actor.default-dispatcher-11] [pekko://test/user/follower110] unhandled message from Actor[pekko://test/deadLetters]: org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus@7d7f127 10:27:40,325 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower110: active: true, followerNextIndex: 0, leaderLastIndex: -1, leaderSnapShotIndex: -1 10:27:40,355 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] RaftActor - leader108: Persist data SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] 10:27:40,355 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] ReplicatedLogImpl - leader108: Append log entry and persist SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] 10:27:40,355 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): Replicate message: identifier: MockIdentifier{value=zero-1}, logIndex: 0, isSendImmediate: true 10:27:40,355 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower109: active: false, followerNextIndex: -1, leaderLastIndex: 0, leaderSnapShotIndex: -1 10:27:40,355 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower110: active: true, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 10:27:40,355 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): sendAppendEntries: 0 is present for follower follower110 10:27:40,355 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): Sending AppendEntries to follower follower110: AppendEntries{term=3, leaderId=leader108, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1]]} 10:27:40,355 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] ReplicatedLogImpl - leader108: persist complete SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] 10:27:40,356 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower110 (Follower): handleAppendEntries: AppendEntries{term=3, leaderId=leader108, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1]]} 10:27:40,356 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower110 (Follower): Number of entries to be appended = 1 10:27:40,356 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower110 (Follower): After cleanup, lastIndex: -1, entries to be added from: 0 10:27:40,356 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower110 (Follower): Append entry to log zero-1 10:27:40,356 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] ReplicatedLogImpl - follower110: Append log entry and persist SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] 10:27:40,356 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] ReplicatedLogImpl - follower110: persist complete SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] 10:27:40,356 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] RaftActor - leader108: Persist data SimpleReplicatedLogEntry [index=1, term=3, payload=one-1] 10:27:40,356 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] ReplicatedLogImpl - leader108: Append log entry and persist SimpleReplicatedLogEntry [index=1, term=3, payload=one-1] 10:27:40,356 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower110 (Follower): Log size is now 1 10:27:40,356 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): Replicate message: identifier: MockIdentifier{value=one-1}, logIndex: 1, isSendImmediate: true 10:27:40,356 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] Follower - follower110 (Follower): handleAppendEntries returning : AppendEntriesReply{term=3, success=true, followerId=follower110, logLastIndex=0, logLastTerm=3, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:40,356 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SyncStatusTracker - follower110: Lagging 0 entries behind leader leader108 and reached -1 (of expected -1) 10:27:40,356 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower109: active: false, followerNextIndex: -1, leaderLastIndex: 1, leaderSnapShotIndex: -1 10:27:40,356 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower110: active: true, followerNextIndex: 0, leaderLastIndex: 1, leaderSnapShotIndex: -1 10:27:40,356 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): sendAppendEntries: 0 is present for follower follower110 10:27:40,356 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower110 updated: matchIndex: 0, nextIndex: 1 [WARN] [02/15/2025 10:27:40.356] [test-pekko.actor.default-dispatcher-17] [pekko://test/user/follower110] unhandled message from Actor[pekko://test/deadLetters]: org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus@4151e8cc 10:27:40,356 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): Applying to log - commitIndex: 0, lastAppliedIndex: -1 10:27:40,356 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] RaftActorBehavior - leader108 (Leader): Setting last applied to 0 10:27:40,356 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] RaftActorContextImpl - leader108: Moving last applied index from -1 to 0 10:27:40,356 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] RaftActor - leader108: Applying state for log index 0 data zero-1 10:27:40,356 AM [test-pekko.actor.default-dispatcher-18] [INFO] MockRaftActor - leader108: applyState called: zero-1 10:27:40,357 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower110: active: true, followerNextIndex: 1, leaderLastIndex: 1, leaderSnapShotIndex: -1 10:27:40,357 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): sendAppendEntries: 1 is present for follower follower110 10:27:40,357 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): Sending AppendEntries to follower follower110: AppendEntries{term=3, leaderId=leader108, prevLogIndex=0, prevLogTerm=3, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=1, term=3, payload=one-1]]} 10:27:40,357 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] ReplicatedLogImpl - leader108: persist complete SimpleReplicatedLogEntry [index=1, term=3, payload=one-1] 10:27:40,357 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] RaftActor - leader108: Persisting ApplyJournalEntries with index=0 10:27:40,357 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower110 (Follower): handleAppendEntries: AppendEntries{term=3, leaderId=leader108, prevLogIndex=0, prevLogTerm=3, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=1, term=3, payload=one-1]]} 10:27:40,357 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower110 (Follower): Number of entries to be appended = 1 10:27:40,357 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] RaftActor - leader108: Persist data SimpleReplicatedLogEntry [index=2, term=3, payload=two-1] 10:27:40,357 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower110 (Follower): After cleanup, lastIndex: 0, entries to be added from: 0 10:27:40,357 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] ReplicatedLogImpl - leader108: Append log entry and persist SimpleReplicatedLogEntry [index=2, term=3, payload=two-1] 10:27:40,357 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower110 (Follower): Append entry to log one-1 10:27:40,357 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): Replicate message: identifier: MockIdentifier{value=two-1}, logIndex: 2, isSendImmediate: true 10:27:40,357 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] ReplicatedLogImpl - follower110: Append log entry and persist SimpleReplicatedLogEntry [index=1, term=3, payload=one-1] 10:27:40,357 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] ReplicatedLogImpl - follower110: persist complete SimpleReplicatedLogEntry [index=1, term=3, payload=one-1] 10:27:40,357 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower110 (Follower): Log size is now 2 10:27:40,357 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower109: active: false, followerNextIndex: -1, leaderLastIndex: 2, leaderSnapShotIndex: -1 10:27:40,357 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower110 (Follower): Commit index set to 0 10:27:40,357 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower110 (Follower): handleAppendEntries returning : AppendEntriesReply{term=3, success=true, followerId=follower110, logLastIndex=1, logLastTerm=3, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:40,357 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] SyncStatusTracker - follower110: Lagging 0 entries behind leader leader108 and reached 0 (of expected -1) 10:27:40,357 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower110: active: true, followerNextIndex: 1, leaderLastIndex: 2, leaderSnapShotIndex: -1 10:27:40,357 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] Follower - follower110 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 0, context.getLastApplied(): -1, lastIndex(): 1 10:27:40,357 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): sendAppendEntries: 1 is present for follower follower110 10:27:40,357 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActorBehavior - follower110 (Follower): Setting last applied to 0 10:27:40,357 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActorContextImpl - follower110: Moving last applied index from -1 to 0 10:27:40,357 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActor - follower110: Applying state for log index 0 data zero-1 10:27:40,357 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower110 updated: matchIndex: 1, nextIndex: 2 10:27:40,357 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): Applying to log - commitIndex: 1, lastAppliedIndex: 0 10:27:40,357 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] RaftActorBehavior - leader108 (Leader): Setting last applied to 1 10:27:40,357 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] RaftActorContextImpl - leader108: Moving last applied index from 0 to 1 10:27:40,358 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] RaftActor - leader108: Applying state for log index 1 data one-1 10:27:40,358 AM [test-pekko.actor.default-dispatcher-11] [INFO] MockRaftActor - follower110: applyState called: zero-1 10:27:40,358 AM [test-pekko.actor.default-dispatcher-18] [INFO] MockRaftActor - leader108: applyState called: one-1 10:27:40,358 AM [test-pekko.actor.default-dispatcher-11] [DEBUG] RaftActor - follower110: Persisting ApplyJournalEntries with index=0 10:27:40,358 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower110: active: true, followerNextIndex: 2, leaderLastIndex: 2, leaderSnapShotIndex: -1 10:27:40,358 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): sendAppendEntries: 2 is present for follower follower110 10:27:40,358 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] AbstractLeader - leader108 (Leader): Sending AppendEntries to follower follower110: AppendEntries{term=3, leaderId=leader108, prevLogIndex=1, prevLogTerm=3, leaderCommit=1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=2, term=3, payload=two-1]]} 10:27:40,358 AM [test-pekko.actor.default-dispatcher-18] [DEBUG] ReplicatedLogImpl - leader108: persist complete SimpleReplicatedLogEntry [index=2, term=3, payload=two-1] 10:27:40,358 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader108: Persisting ApplyJournalEntries with index=1 10:27:40,358 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader108: Persist data SimpleReplicatedLogEntry [index=3, term=3, payload=three-1] 10:27:40,358 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - leader108: Append log entry and persist SimpleReplicatedLogEntry [index=3, term=3, payload=three-1] 10:27:40,358 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower110 (Follower): handleAppendEntries: AppendEntries{term=3, leaderId=leader108, prevLogIndex=1, prevLogTerm=3, leaderCommit=1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=2, term=3, payload=two-1]]} 10:27:40,358 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): Replicate message: identifier: MockIdentifier{value=three-1}, logIndex: 3, isSendImmediate: true 10:27:40,358 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower110 (Follower): Number of entries to be appended = 1 10:27:40,358 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower110 (Follower): After cleanup, lastIndex: 1, entries to be added from: 0 10:27:40,358 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower110 (Follower): Append entry to log two-1 10:27:40,358 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - follower110: Append log entry and persist SimpleReplicatedLogEntry [index=2, term=3, payload=two-1] 10:27:40,358 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower109: active: false, followerNextIndex: -1, leaderLastIndex: 3, leaderSnapShotIndex: -1 10:27:40,358 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - follower110: persist complete SimpleReplicatedLogEntry [index=2, term=3, payload=two-1] 10:27:40,358 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower110 (Follower): Log size is now 3 10:27:40,358 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower110 (Follower): Commit index set to 1 10:27:40,358 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower110 (Follower): handleAppendEntries returning : AppendEntriesReply{term=3, success=true, followerId=follower110, logLastIndex=2, logLastTerm=3, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:40,358 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower110: active: true, followerNextIndex: 2, leaderLastIndex: 3, leaderSnapShotIndex: -1 10:27:40,358 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): sendAppendEntries: 2 is present for follower follower110 10:27:40,358 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SyncStatusTracker - follower110: Lagging 0 entries behind leader leader108 and reached 1 (of expected -1) 10:27:40,358 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower110 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 1, context.getLastApplied(): 0, lastIndex(): 2 10:27:40,358 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorBehavior - follower110 (Follower): Setting last applied to 1 10:27:40,358 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorContextImpl - follower110: Moving last applied index from 0 to 1 10:27:40,358 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - follower110: Applying state for log index 1 data one-1 10:27:40,358 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower110 updated: matchIndex: 2, nextIndex: 3 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): Applying to log - commitIndex: 2, lastAppliedIndex: 1 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - leader108 (Leader): Setting last applied to 2 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorContextImpl - leader108: Moving last applied index from 1 to 2 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader108: Applying state for log index 2 data two-1 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [INFO] MockRaftActor - follower110: applyState called: one-1 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - leader108: applyState called: two-1 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower110: active: true, followerNextIndex: 3, leaderLastIndex: 3, leaderSnapShotIndex: -1 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): sendAppendEntries: 3 is present for follower follower110 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - follower110: Persisting ApplyJournalEntries with index=1 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): Sending AppendEntries to follower follower110: AppendEntries{term=3, leaderId=leader108, prevLogIndex=2, prevLogTerm=3, leaderCommit=2, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=3, term=3, payload=three-1]]} 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - leader108: persist complete SimpleReplicatedLogEntry [index=3, term=3, payload=three-1] 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower110 (Follower): handleAppendEntries: AppendEntries{term=3, leaderId=leader108, prevLogIndex=2, prevLogTerm=3, leaderCommit=2, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=3, term=3, payload=three-1]]} 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower110 (Follower): Number of entries to be appended = 1 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower110 (Follower): After cleanup, lastIndex: 2, entries to be added from: 0 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower110 (Follower): Append entry to log three-1 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - follower110: Append log entry and persist SimpleReplicatedLogEntry [index=3, term=3, payload=three-1] 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader108: Persisting ApplyJournalEntries with index=2 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - follower110: persist complete SimpleReplicatedLogEntry [index=3, term=3, payload=three-1] 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower110 (Follower): Log size is now 4 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower110 (Follower): Commit index set to 2 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader108: Persist data SimpleReplicatedLogEntry [index=4, term=3, payload=four-1] 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - leader108: Append log entry and persist SimpleReplicatedLogEntry [index=4, term=3, payload=four-1] 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower110 (Follower): handleAppendEntries returning : AppendEntriesReply{term=3, success=true, followerId=follower110, logLastIndex=3, logLastTerm=3, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SyncStatusTracker - follower110: Lagging 0 entries behind leader leader108 and reached 2 (of expected -1) 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): Replicate message: identifier: MockIdentifier{value=four-1}, logIndex: 4, isSendImmediate: true 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower110 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 2, context.getLastApplied(): 1, lastIndex(): 3 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorBehavior - follower110 (Follower): Setting last applied to 2 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorContextImpl - follower110: Moving last applied index from 1 to 2 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - follower110: Applying state for log index 2 data two-1 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower109: active: false, followerNextIndex: -1, leaderLastIndex: 4, leaderSnapShotIndex: -1 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [INFO] MockRaftActor - follower110: applyState called: two-1 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower110: active: true, followerNextIndex: 3, leaderLastIndex: 4, leaderSnapShotIndex: -1 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): sendAppendEntries: 3 is present for follower follower110 10:27:40,359 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - follower110: Persisting ApplyJournalEntries with index=2 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower110 updated: matchIndex: 3, nextIndex: 4 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): Applying to log - commitIndex: 3, lastAppliedIndex: 2 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - leader108 (Leader): Setting last applied to 3 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorContextImpl - leader108: Moving last applied index from 2 to 3 10:27:40,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader108: Applying state for log index 3 data three-1 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - leader108: applyState called: three-1 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower110: active: true, followerNextIndex: 4, leaderLastIndex: 4, leaderSnapShotIndex: -1 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): sendAppendEntries: 4 is present for follower follower110 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): Sending AppendEntries to follower follower110: AppendEntries{term=3, leaderId=leader108, prevLogIndex=3, prevLogTerm=3, leaderCommit=3, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=4, term=3, payload=four-1]]} 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - leader108: persist complete SimpleReplicatedLogEntry [index=4, term=3, payload=four-1] 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader108: Persisting ApplyJournalEntries with index=3 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower110 (Follower): handleAppendEntries: AppendEntries{term=3, leaderId=leader108, prevLogIndex=3, prevLogTerm=3, leaderCommit=3, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=4, term=3, payload=four-1]]} 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower110 (Follower): Number of entries to be appended = 1 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower110 (Follower): After cleanup, lastIndex: 3, entries to be added from: 0 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower110 (Follower): Append entry to log four-1 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower110: Append log entry and persist SimpleReplicatedLogEntry [index=4, term=3, payload=four-1] 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower110: persist complete SimpleReplicatedLogEntry [index=4, term=3, payload=four-1] 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower110 (Follower): Log size is now 5 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower110 (Follower): Commit index set to 3 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower110 (Follower): handleAppendEntries returning : AppendEntriesReply{term=3, success=true, followerId=follower110, logLastIndex=4, logLastTerm=3, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower110: Lagging 0 entries behind leader leader108 and reached 3 (of expected -1) 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower110 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 3, context.getLastApplied(): 2, lastIndex(): 4 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - follower110 (Follower): Setting last applied to 3 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorContextImpl - follower110: Moving last applied index from 2 to 3 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower110: Applying state for log index 3 data three-1 10:27:40,360 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - follower110: applyState called: three-1 10:27:40,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower110: Persisting ApplyJournalEntries with index=3 10:27:40,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower110 updated: matchIndex: 4, nextIndex: 5 10:27:40,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): Applying to log - commitIndex: 4, lastAppliedIndex: 3 10:27:40,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - leader108 (Leader): Setting last applied to 4 10:27:40,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorContextImpl - leader108: Moving last applied index from 3 to 4 10:27:40,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader108: Applying state for log index 4 data four-1 10:27:40,361 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - leader108: applyState called: four-1 10:27:40,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower110: active: true, followerNextIndex: 5, leaderLastIndex: 4, leaderSnapShotIndex: -1 10:27:40,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader108: Persisting ApplyJournalEntries with index=4 10:27:40,362 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower110 (Follower): Commit index set to 4 10:27:40,362 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - follower110: Lagging 0 entries behind leader leader108 and reached 4 (of expected -1) 10:27:40,362 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower110 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 4, context.getLastApplied(): 3, lastIndex(): 4 10:27:40,362 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - follower110 (Follower): Setting last applied to 4 10:27:40,362 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorContextImpl - follower110: Moving last applied index from 3 to 4 10:27:40,362 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - follower110: Applying state for log index 4 data four-1 10:27:40,363 AM [test-pekko.actor.default-dispatcher-5] [INFO] MockRaftActor - follower110: applyState called: four-1 10:27:40,363 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - follower110: Persisting ApplyJournalEntries with index=4 10:27:40,444 AM [test-pekko.actor.default-dispatcher-5] [INFO] Follower - follower109 (Follower): Term 3 in "AppendEntries{term=3, leaderId=leader108, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 2 - updating term 10:27:40,447 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower109: Set currentTerm=3, votedFor=null 10:27:40,447 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - follower109: Lagging -3 entries behind leader leader108 and reached 2 (of expected -1) 10:27:40,448 AM [test-pekko.actor.default-dispatcher-5] [INFO] AbstractLeader - leader108 (Leader): handleAppendEntriesReply: follower follower109 last log term 2 for index 2 conflicts with the leader's 3 - set the follower's next index to 1 10:27:40,448 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower109: active: true, followerNextIndex: 1, leaderLastIndex: 4, leaderSnapShotIndex: -1 10:27:40,448 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader108 (Leader): sendAppendEntries: 1 is present for follower follower109 10:27:40,448 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader108 (Leader): Sending AppendEntries to follower follower109: AppendEntries{term=3, leaderId=leader108, prevLogIndex=0, prevLogTerm=3, leaderCommit=4, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=1, term=3, payload=one-1], SimpleReplicatedLogEntry [index=2, term=3, payload=two-1], SimpleReplicatedLogEntry [index=3, term=3, payload=three-1], SimpleReplicatedLogEntry [index=4, term=3, payload=four-1]]} 10:27:40,448 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower109 (Follower): handleAppendEntries: AppendEntries{term=3, leaderId=leader108, prevLogIndex=0, prevLogTerm=3, leaderCommit=4, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=1, term=3, payload=one-1], SimpleReplicatedLogEntry [index=2, term=3, payload=two-1], SimpleReplicatedLogEntry [index=3, term=3, payload=three-1], SimpleReplicatedLogEntry [index=4, term=3, payload=four-1]]} 10:27:40,448 AM [test-pekko.actor.default-dispatcher-5] [INFO] Follower - follower109 (Follower): The prevLogIndex 0 was found in the log but the term 2 is not equal to the append entries prevLogTerm 3 - lastIndex: 2, snapshotIndex: 1, snapshotTerm: 2 10:27:40,448 AM [test-pekko.actor.default-dispatcher-5] [INFO] Follower - follower109 (Follower): Follower is out-of-sync so sending negative reply: AppendEntriesReply{term=3, success=false, followerId=follower109, logLastIndex=2, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 10:27:40,448 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - follower109: Lagging 2 entries behind leader leader108 and reached 2 (of expected -1) 10:27:40,448 AM [test-pekko.actor.default-dispatcher-17] [INFO] AbstractLeader - leader108 (Leader): handleAppendEntriesReply - received unsuccessful reply: AppendEntriesReply{term=3, success=false, followerId=follower109, logLastIndex=2, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5}, leader snapshotIndex: -1, snapshotTerm: -1, replicatedToAllIndex: -1 10:27:40,449 AM [test-pekko.actor.default-dispatcher-17] [INFO] AbstractLeader - leader108 (Leader): follower follower109 last log term 2 conflicts with the leader's 3 - dec next index to 0 10:27:40,449 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): Checking sendAppendEntries for follower follower109: active: true, followerNextIndex: 0, leaderLastIndex: 4, leaderSnapShotIndex: -1 10:27:40,449 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): sendAppendEntries: 0 is present for follower follower109 10:27:40,449 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): Sending AppendEntries to follower follower109: AppendEntries{term=3, leaderId=leader108, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=4, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1], SimpleReplicatedLogEntry [index=1, term=3, payload=one-1], SimpleReplicatedLogEntry [index=2, term=3, payload=two-1], SimpleReplicatedLogEntry [index=3, term=3, payload=three-1], SimpleReplicatedLogEntry [index=4, term=3, payload=four-1]]} 10:27:40,449 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower109 (Follower): handleAppendEntries: AppendEntries{term=3, leaderId=leader108, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=4, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1], SimpleReplicatedLogEntry [index=1, term=3, payload=one-1], SimpleReplicatedLogEntry [index=2, term=3, payload=two-1], SimpleReplicatedLogEntry [index=3, term=3, payload=three-1], SimpleReplicatedLogEntry [index=4, term=3, payload=four-1]]} 10:27:40,449 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower109 (Follower): Number of entries to be appended = 5 10:27:40,449 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower109 (Follower): matchEntry SimpleReplicatedLogEntry [index=0, term=3, payload=zero-1] is present: existingEntryTerm: -1 10:27:40,449 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower109 (Follower): matchEntry SimpleReplicatedLogEntry [index=1, term=3, payload=one-1] is present: existingEntryTerm: 2 10:27:40,449 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] DefaultConfigParamsImpl - No custom RaftPolicy specified. Using DefaultRaftPolicy 10:27:40,449 AM [test-pekko.actor.default-dispatcher-5] [INFO] Follower - follower109 (Follower): Removing entries from log starting at 1, commitIndex: 2, lastApplied: 2 10:27:40,449 AM [test-pekko.actor.default-dispatcher-5] [INFO] Follower - follower109 (Follower): Could not remove entries - sending reply to force snapshot 10:27:40,449 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - follower109: Lagging 2 entries behind leader leader108 and reached 2 (of expected -1) 10:27:40,449 AM [test-pekko.actor.default-dispatcher-17] [INFO] AbstractLeader - leader108 (Leader): handleAppendEntriesReply - received unsuccessful reply: AppendEntriesReply{term=3, success=false, followerId=follower109, logLastIndex=2, logLastTerm=2, forceInstallSnapshot=true, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5}, leader snapshotIndex: -1, snapshotTerm: -1, replicatedToAllIndex: -1 10:27:40,449 AM [test-pekko.actor.default-dispatcher-17] [INFO] SnapshotManager - leader108: Initiating snapshot capture CaptureSnapshot [lastAppliedIndex=4, lastAppliedTerm=3, lastIndex=4, lastTerm=3, installSnapshotInitiated=, replicatedToAllIndex=-1, replicatedToAllTerm=-1, unAppliedEntries size=0, mandatoryTrim=false] to install on follower109 10:27:40,449 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SnapshotManager - leader108: lastSequenceNumber prior to capture: -1 10:27:40,450 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorSnapshotMessageSupport - leader108: CaptureSnapshotReply received by actor 10:27:40,450 AM [test-pekko.actor.default-dispatcher-17] [INFO] SnapshotManager - leader108: Persisting of snapshot done: Snapshot [lastIndex=4, lastTerm=3, lastAppliedIndex=4, lastAppliedTerm=3, unAppliedEntries size=0, state=MockSnapshotState [state=[zero-1, one-1, two-1, three-1, four-1]], electionTerm=3, electionVotedFor=leader108, ServerConfigPayload=ClusterConfig{serverInfo=[ServerInfo[peerId=follower109, isVoting=false], ServerInfo[peerId=downPeer, isVoting=false], ServerInfo[peerId=follower110, isVoting=true], ServerInfo[peerId=leader108, isVoting=true]]}] 10:27:40,450 AM [test-pekko.actor.default-dispatcher-17] [INFO] SnapshotManager - leader108: Removed in-memory snapshotted entries, adjusted snaphsotIndex: -1 and term: -1 10:27:40,450 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): sendInstallSnapshot 10:27:40,450 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] LeaderInstallSnapshotState - leader108 (Leader): Snapshot 390 bytes, total chunks to send: 1 10:27:40,450 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] LeaderInstallSnapshotState - leader108 (Leader): Next chunk: total length=390, offset=0, size=390, hashCode=-929342248 10:27:40,450 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): next snapshot chunk size for follower follower109: 390 10:27:40,450 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): InstallSnapshot sent to follower Vector(user, follower109), Chunk: 1/1 10:27:40,451 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] SnapshotManager - leader108: Snapshot success - sequence number: -1 10:27:40,450 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower109 (Follower): handleInstallSnapshot: InstallSnapshot{term=3, leaderId=leader108, lastIncludedIndex=4, lastIncludedTerm=3, datasize=390, chunk=1/1, lastChunkHashCode=OptionalInt[-1], serverConfig=ClusterConfig{serverInfo=[ServerInfo[peerId=follower109, isVoting=false], ServerInfo[peerId=downPeer, isVoting=false], ServerInfo[peerId=follower110, isVoting=true], ServerInfo[peerId=leader108, isVoting=true]]}} 10:27:40,451 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - follower109: Lagging 2 entries behind leader leader108 and reached 2 (of expected -1) 10:27:40,451 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] RaftActorSnapshotMessageSupport - leader108: SnapshotComplete received 10:27:40,451 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotTracker - follower109 (Follower): addChunk: chunkIndex=1, lastChunkIndex=0, collectedChunks.size=0, lastChunkHashCode=-1 10:27:40,451 AM [test-pekko.actor.default-dispatcher-5] [INFO] Follower - follower109 (Follower): Snapshot received from leader: leader108 10:27:40,451 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - follower109: Applying snapshot on follower: org.opendaylight.controller.cluster.io.FileBackedOutputStream$1@268bc77f 10:27:40,452 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - follower109: Converted InstallSnapshot from leader: leader108 to state 10:27:40,452 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - follower109: lastSequenceNumber prior to persisting applied snapshot: -1 10:27:40,452 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - follower109: Snapshot success - sequence number: -1 10:27:40,452 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorContextImpl - follower109: Moving last applied index from 2 to 4 10:27:40,452 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower109: Set currentTerm=3, votedFor=null 10:27:40,452 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorContextImpl - follower109: Updated server config: isVoting: false, peers: [PeerInfo [id=downPeer, address=null, votingState=NON_VOTING], PeerInfo [id=leader108, address=pekko://test/user/leader108, votingState=VOTING], PeerInfo [id=follower110, address=null, votingState=VOTING]] 10:27:40,452 AM [test-pekko.actor.default-dispatcher-5] [INFO] MockRaftActor - follower109: applySnapshot called 10:27:40,452 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - follower109 (Follower): handleInstallSnapshot returning: InstallSnapshotReply{term=3, followerId=follower109, chunkIndex=1, success=true} 10:27:40,452 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorSnapshotMessageSupport - follower109: SnapshotComplete received 10:27:40,452 AM [test-pekko.actor.default-dispatcher-17] [DEBUG] AbstractLeader - leader108 (Leader): handleInstallSnapshotReply: InstallSnapshotReply{term=3, followerId=follower109, chunkIndex=1, success=true} 10:27:40,453 AM [test-pekko.actor.default-dispatcher-17] [INFO] AbstractLeader - leader108 (Leader): Snapshot successfully installed on follower follower109 (last chunk 1) - matchIndex set to 4, nextIndex set to 5 10:27:40,456 AM [main] [INFO] NonVotingFollowerIntegrationTest - testFollowerResyncWithMoreLeaderLogEntriesAndDownPeerAfterNonPersistentLeaderRestart ending 10:27:40,456 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/follower109-collector111#-1215550074] 10:27:40,467 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower109] 10:27:40,468 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/leader108-collector112#-1553866127] 10:27:40,468 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader108] 10:27:40,469 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/follower110-collector113#-842815588] 10:27:40,469 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower110] 10:27:40,469 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/leader108-collector114#-110278918] 10:27:40,470 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader108] [INFO] [02/15/2025 10:27:40.472] [main] [CoordinatedShutdown(pekko://test)] Running CoordinatedShutdown with reason [ActorSystemTerminateReason] 10:27:40,472 AM [test-pekko.actor.default-dispatcher-5] [INFO] CoordinatedShutdown - Running CoordinatedShutdown with reason [ActorSystemTerminateReason] 10:27:40,473 AM [test-pekko.actor.default-dispatcher-11] [INFO] Cluster - Cluster Node [pekko://test@10.30.170.64:17355] - Exiting completed 10:27:40,473 AM [test-pekko.actor.default-dispatcher-11] [INFO] Cluster - Cluster Node [pekko://test@10.30.170.64:17355] - Shutting down... 10:27:40,474 AM [test-pekko.actor.default-dispatcher-11] [INFO] Cluster - Cluster Node [pekko://test@10.30.170.64:17355] - Successfully shut down 10:27:40,475 AM [test-pekko.actor.default-dispatcher-11] [INFO] RemoteActorRefProvider$RemotingTerminator - Shutting down remote daemon. 10:27:40,475 AM [test-pekko.actor.default-dispatcher-11] [INFO] RemoteActorRefProvider$RemotingTerminator - Remote daemon shut down; proceeding with flushing remote transports. [WARN] [02/15/2025 10:27:40.475] [test-pekko.actor.default-dispatcher-17] [pekko://test/system/cluster/core/daemon] unhandled message from Actor[pekko://test/deadLetters]: Leave(pekko://test@10.30.170.64:17355) [INFO] [02/15/2025 10:27:40.473] [test-pekko.actor.internal-dispatcher-10] [Cluster(pekko://test)] Cluster Node [pekko://test@10.30.170.64:17355] - Exiting completed [INFO] [02/15/2025 10:27:40.473] [test-pekko.actor.internal-dispatcher-10] [Cluster(pekko://test)] Cluster Node [pekko://test@10.30.170.64:17355] - Shutting down... [INFO] [02/15/2025 10:27:40.474] [test-pekko.actor.internal-dispatcher-10] [Cluster(pekko://test)] Cluster Node [pekko://test@10.30.170.64:17355] - Successfully shut down [INFO] [02/15/2025 10:27:40.475] [test-pekko.remote.default-remote-dispatcher-7] [pekko://test@10.30.170.64:17355/system/remoting-terminator] Shutting down remote daemon. [INFO] [02/15/2025 10:27:40.475] [test-pekko.remote.default-remote-dispatcher-7] [pekko://test@10.30.170.64:17355/system/remoting-terminator] Remote daemon shut down; proceeding with flushing remote transports. [INFO] [02/15/2025 10:27:40.478] [test-pekko.remote.default-remote-dispatcher-8] [pekko://test@10.30.170.64:17355/system/remoting-terminator] Remoting shut down. [DEBUG] [02/15/2025 10:27:40.479] [test-pekko.actor.internal-dispatcher-2] [EventStream] shutting down: StandardOutLogger 10:27:40,479 AM [test-pekko.actor.default-dispatcher-5] [INFO] RemoteActorRefProvider$RemotingTerminator - Remoting shut down.