[DEBUG] [02/28/2026 01:11:52.561] [main] [EventStream(pekko://test)] logger log1-TestEventListener started 01:11:52,562 AM [test-pekko.actor.default-dispatcher-5] [INFO] Slf4jLogger - Slf4jLogger started [DEBUG] [02/28/2026 01:11:52.562] [main] [EventStream(pekko://test)] logger log2-Slf4jLogger started [DEBUG] [02/28/2026 01:11:52.562] [main] [EventStream(pekko://test)] Default Loggers started [INFO] [02/28/2026 01:11:52.584] [main] [ArteryTransport(pekko://test)] Remoting started with transport [Artery tcp]; listening on address [pekko://test@10.30.171.17:17355] with UID [-3926653799741638642] 01:11:52,585 AM [test-pekko.actor.default-dispatcher-7] [INFO] ArteryTransport - Remoting started with transport [Artery tcp]; listening on address [pekko://test@10.30.171.17:17355] with UID [-3926653799741638642] [INFO] [02/28/2026 01:11:52.586] [main] [Cluster(pekko://test)] Cluster Node [pekko://test@10.30.171.17:17355] - Starting up, Pekko version [1.2.1] ... 01:11:52,586 AM [test-pekko.actor.default-dispatcher-7] [INFO] Cluster - Cluster Node [pekko://test@10.30.171.17:17355] - Starting up, Pekko version [1.2.1] ... [INFO] [02/28/2026 01:11:52.593] [main] [Cluster(pekko://test)] Cluster Node [pekko://test@10.30.171.17:17355] - Registered cluster JMX MBean [pekko:type=Cluster] 01:11:52,593 AM [test-pekko.actor.default-dispatcher-7] [INFO] Cluster - Cluster Node [pekko://test@10.30.171.17:17355] - Registered cluster JMX MBean [pekko:type=Cluster] [INFO] [02/28/2026 01:11:52.593] [main] [Cluster(pekko://test)] Cluster Node [pekko://test@10.30.171.17:17355] - Started up successfully 01:11:52,593 AM [test-pekko.actor.default-dispatcher-7] [INFO] Cluster - Cluster Node [pekko://test@10.30.171.17:17355] - Started up successfully [INFO] [02/28/2026 01:11:52.595] [test-pekko.actor.internal-dispatcher-2] [Cluster(pekko://test)] Cluster Node [pekko://test@10.30.171.17:17355] - No downing-provider-class configured, manual cluster downing required, see https://pekko.apache.org/docs/pekko/current/typed/cluster.html#downing [INFO] [02/28/2026 01:11:52.595] [test-pekko.actor.internal-dispatcher-2] [Cluster(pekko://test)] Cluster Node [pekko://test@10.30.171.17:17355] - No seed-nodes configured, manual cluster join required, see https://pekko.apache.org/docs/pekko/current/typed/cluster.html#joining 01:11:52,596 AM [test-pekko.actor.default-dispatcher-7] [INFO] Cluster - Cluster Node [pekko://test@10.30.171.17:17355] - No downing-provider-class configured, manual cluster downing required, see https://pekko.apache.org/docs/pekko/current/typed/cluster.html#downing 01:11:52,596 AM [test-pekko.actor.default-dispatcher-7] [INFO] Cluster - Cluster Node [pekko://test@10.30.171.17:17355] - No seed-nodes configured, manual cluster join required, see https://pekko.apache.org/docs/pekko/current/typed/cluster.html#joining 01:11:52,613 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithOperationInProgress starting 01:11:52,615 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorVotingConfigSupportTest$MockNewFollowerRaftActor - Actor created TestActor[pekko://test/user/new-server109] 01:11:52,616 AM [test-pekko.actor.default-dispatcher-6] [INFO] RaftActor - new-server: Starting recovery with journal batch size 1000 01:11:52,617 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - new-server: started executor 01:11:52,617 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - new-server: started executor 01:11:52,617 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] EntryJournalV1 - new-server: metadata journal open: replayFrom=1 applyTo=0 01:11:52,618 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] EntryJournalV1 - new-server: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:52,618 AM [test-pekko.actor.default-dispatcher-6] [INFO] EnabledRaftStorage - new-server: journal open: applyTo=0 01:11:52,618 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActor - new-server: recovering to non-persistent 01:11:52,618 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] PropertiesTermInfoStore - /tmp/junit-13082111928546194308/new-server/TermInfo.properties does not exist 01:11:52,618 AM [new-server-writer-35] [DEBUG] JournalWriteTask - new-server: journal writer started 01:11:52,618 AM [new-server-writer-35] [DEBUG] JournalWriteTask - new-server: waiting to receive commands [WARN] [02/28/2026 01:11:52.618] [test-pekko.actor.default-dispatcher-7] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/new-server109]: org.opendaylight.controller.cluster.common.actor.Monitor@497f7d81 [INFO] [pekkoDeadLetter][02/28/2026 01:11:52.619] [test-pekko.actor.default-dispatcher-7] [pekko://test/user/termination-monitor] Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/new-server109] 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'. 01:11:52,619 AM [test-pekko.actor.default-dispatcher-7] [INFO] EmptyLocalActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/new-server109] 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'. 01:11:52,622 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=0, votedFor=null 01:11:52,622 AM [test-pekko.actor.default-dispatcher-6] [INFO] Recovery - new-server: Local TermInfo store seeded with TermInfo{term=0} 01:11:52,622 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-13082111928546194308/new-server/TermInfo.properties 01:11:52,622 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-13082111928546194308/new-server/journal-v1-1.log 01:11:52,622 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-13082111928546194308/new-server/metadata-v1-1.log 01:11:52,622 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - new-server: no eligible files found 01:11:52,622 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractReplicatedLog - new-server: Moving last applied index from -1 to -1 01:11:52,622 AM [test-pekko.actor.default-dispatcher-6] [INFO] Recovery - new-server: Recovery completed in in 4.259 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:52,622 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActor - new-server: Recovery completed and can restore from snapshot 01:11:52,633 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorVotingConfigSupportTest$MockLeaderRaftActor - Actor created TestActor[pekko://test/user/leader110] [WARN] [02/28/2026 01:11:52.633] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader110]: org.opendaylight.controller.cluster.common.actor.Monitor@13af82c5 [INFO] [pekkoDeadLetter][02/28/2026 01:11:52.633] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/leader110] 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'. 01:11:52,633 AM [test-pekko.actor.default-dispatcher-5] [INFO] EmptyLocalActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/leader110] 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'. 01:11:52,634 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:52,634 AM [test-pekko.actor.default-dispatcher-6] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:52,634 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - leader: started executor 01:11:52,634 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - leader: started executor 01:11:52,635 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:52,635 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:52,635 AM [test-pekko.actor.default-dispatcher-6] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:52,635 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:52,635 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] PropertiesTermInfoStore - /tmp/junit-13082111928546194308/leader/TermInfo.properties does not exist 01:11:52,635 AM [leader-writer-36] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:52,635 AM [leader-writer-36] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:52,641 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:52,641 AM [test-pekko.actor.default-dispatcher-6] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=1, votedFor=} 01:11:52,641 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-13082111928546194308/leader/TermInfo.properties 01:11:52,641 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-13082111928546194308/leader/journal-v1-1.log 01:11:52,641 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-13082111928546194308/leader/metadata-v1-1.log 01:11:52,641 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - leader: no eligible files found 01:11:52,641 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:52,641 AM [test-pekko.actor.default-dispatcher-6] [INFO] Recovery - leader: Recovery completed in in 5.930 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:52,641 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:52,642 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractLeader - leader (Leader): Election: Leader has following peers: [] 01:11:52,657 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorVotingConfigSupport - leader: onAddServer: AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server109, votingMember=true], state: Idle 01:11:52,670 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server109, votingMember=true] 01:11:52,670 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractReplicatedLog - leader: Capturing Snapshot : lastLogEntry is null. Using snapshot values lastAppliedIndex -1 and lastAppliedTerm -1 instead. 01:11:52,670 AM [test-pekko.actor.default-dispatcher-6] [INFO] SnapshotManager - leader: 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 new-server 01:11:52,670 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] SnapshotManager - leader: last applied journal index prior to capture: 0 01:11:52,670 AM [test-pekko.actor.default-dispatcher-6] [INFO] MockRaftActor - leader: support() called 01:11:52,671 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating capture snapshot for new server new-server 01:11:52,671 AM [leader-%d669686] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:52,674 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:52,674 AM [test-pekko.actor.default-dispatcher-6] [INFO] SnapshotManager - leader: Persising snapshot at EntryInfo[index=-1, term=-1]/EntryInfo[index=-1, term=-1] 01:11:52,674 AM [test-pekko.actor.default-dispatcher-6] [INFO] MockRaftActor - leader: support() called 01:11:52,675 AM [test-pekko.actor.default-dispatcher-6] [INFO] SnapshotManager - leader: Removed in-memory snapshotted entries, adjusted snapshotIndex: -1 and term: -1 01:11:52,675 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractLeader - leader (Leader): sendInstallSnapshot 01:11:52,675 AM [leader-%d669687] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-13082111928546194308/leader/snapshot-0000000069A240D8-283C4939.tmp 01:11:52,675 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] LeaderInstallSnapshotState - leader (Leader): Snapshot 157 bytes, total chunks to send: 1 01:11:52,675 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] LeaderInstallSnapshotState - leader (Leader): Next chunk: total length=157, offset=0, size=157, hashCode=1546036366 01:11:52,675 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractLeader - leader (Leader): next snapshot chunk size for follower new-server: 157 01:11:52,675 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractLeader - leader (Leader): InstallSnapshot sent to follower Vector(user, new-server109), Chunk: 1/1 01:11:52,677 AM [leader-%d669687] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-13082111928546194308/leader/snapshot-0000000069A240D8-283C4939.v1 01:11:52,677 AM [leader-%d669687] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-13082111928546194308/leader/TermInfo.properties 01:11:52,677 AM [leader-%d669687] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-13082111928546194308/leader/journal-v1-1.log 01:11:52,677 AM [leader-%d669687] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-13082111928546194308/leader/metadata-v1-1.log 01:11:52,678 AM [leader-%d669687] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-13082111928546194308/leader/snapshot-0000000069A240D8-283C4939.v1 01:11:52,678 AM [leader-%d669687] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:52.675039545Z, file=/tmp/junit-13082111928546194308/leader/snapshot-0000000069A240D8-283C4939.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:52,678 AM [leader-%d669687] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:52,678 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:52,678 AM [test-pekko.actor.default-dispatcher-6] [INFO] SnapshotManager - leader: snapshot is durable as of 2026-02-28T01:11:52.675039545Z 01:11:52,678 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] SnapshotManager - leader: Snapshot success, discarding journal entries up to 0 01:11:52,678 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorSnapshotMessageSupport - leader: SnapshotComplete received 01:11:52,710 AM [test-pekko.actor.default-dispatcher-5] [INFO] Follower - new-server (Follower): Term 1 in "InstallSnapshot{term=1, leaderId=leader, lastIncludedIndex=-1, lastIncludedTerm=-1, datasize=157, chunk=1/1, lastChunkHashCode=OptionalInt[-1]}" message is greater than follower's term 0 - updating term 01:11:52,710 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorVotingConfigSupport - leader: onAddServer: AddServer [newServerId=new-server2, newServerAddress=pekko://test/user/follower107, votingMember=false], state: InstallingSnapshot 01:11:52,713 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorVotingConfigSupport - leader: Server operation already in progress - queueing AddServer [newServerId=new-server2, newServerAddress=pekko://test/user/follower107, votingMember=false] 01:11:52,715 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=1, votedFor=null 01:11:52,715 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - new-server (Follower): handleInstallSnapshot: InstallSnapshot{term=1, leaderId=leader, lastIncludedIndex=-1, lastIncludedTerm=-1, datasize=157, chunk=1/1, lastChunkHashCode=OptionalInt[-1]} 01:11:52,715 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - new-server: Last sync leader does not match current leader leader, need to catch up to -1 01:11:52,715 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotTracker - new-server (Follower): addChunk: chunkIndex=1, lastChunkIndex=0, collectedChunks.size=0, lastChunkHashCode=-1 01:11:52,715 AM [test-pekko.actor.default-dispatcher-5] [INFO] Follower - new-server (Follower): Snapshot received from leader: leader 01:11:52,715 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - new-server: Applying snapshot on follower: PlainSnapshotSource{io=MemoryStreamSource{size=157}} 01:11:52,715 AM [test-pekko.actor.default-dispatcher-5] [INFO] MockRaftActor - new-server: support() called [WARN] [02/28/2026 01:11:52.716] [test-pekko.actor.default-dispatcher-6] [pekko://test/user/new-server109] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=new-server, initialSyncDone=false] [INFO] [pekkoDeadLetter][02/28/2026 01:11:52.716] [test-pekko.actor.default-dispatcher-6] [pekko://test/user/new-server109] Message [org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus] to TestActor[pekko://test/user/new-server109] 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'. 01:11:52,716 AM [test-pekko.actor.default-dispatcher-7] [INFO] TestActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus] to TestActor[pekko://test/user/new-server109] 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'. 01:11:52,717 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - new-server: Converted InstallSnapshot from leader: leader to state 01:11:52,717 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - new-server: last applied journal index prior to persisting applied snapshot: 0 01:11:52,717 AM [test-pekko.actor.default-dispatcher-5] [INFO] MockRaftActor - new-server: support() called 01:11:52,717 AM [new-server-%d492360] [DEBUG] RaftStorage - new-server: starting snapshot writeout to /tmp/junit-13082111928546194308/new-server/snapshot-0000000069A240D8-2AC322AA.tmp 01:11:52,719 AM [new-server-%d492360] [DEBUG] RaftStorage - new-server: finished snapshot writeout to /tmp/junit-13082111928546194308/new-server/snapshot-0000000069A240D8-2AC322AA.v1 01:11:52,719 AM [new-server-%d492360] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-13082111928546194308/new-server/snapshot-0000000069A240D8-2AC322AA.v1 01:11:52,719 AM [new-server-%d492360] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-13082111928546194308/new-server/TermInfo.properties 01:11:52,719 AM [new-server-%d492360] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-13082111928546194308/new-server/journal-v1-1.log 01:11:52,719 AM [new-server-%d492360] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-13082111928546194308/new-server/metadata-v1-1.log 01:11:52,719 AM [new-server-%d492360] [DEBUG] RaftStorage - new-server: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:52.717431466Z, file=/tmp/junit-13082111928546194308/new-server/snapshot-0000000069A240D8-2AC322AA.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:52,719 AM [new-server-%d492360] [DEBUG] RaftStorageCompleter - new-server: 1 completion(s) pending 01:11:52,719 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorageCompleter - new-server: running 1 completion(s) 01:11:52,719 AM [test-pekko.actor.default-dispatcher-6] [INFO] SnapshotManager - new-server: snapshot is durable as of 2026-02-28T01:11:52.717431466Z 01:11:52,720 AM [test-pekko.actor.default-dispatcher-6] [INFO] MockRaftActor - new-server: support() called 01:11:52,721 AM [test-pekko.actor.default-dispatcher-6] [INFO] MockRaftActor - new-server: applySnapshot called 01:11:52,721 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): handleInstallSnapshot returning: InstallSnapshotReply{term=1, followerId=new-server, chunkIndex=1, success=true} 01:11:52,721 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] SnapshotManager - new-server: Snapshot success, discarding journal entries up to 0 01:11:52,721 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorSnapshotMessageSupport - new-server: SnapshotComplete received 01:11:52,721 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): handleInstallSnapshotReply: InstallSnapshotReply{term=1, followerId=new-server, chunkIndex=1, success=true} 01:11:52,721 AM [test-pekko.actor.default-dispatcher-5] [INFO] AbstractLeader - leader (Leader): Snapshot successfully installed on follower new-server (last chunk 1) - matchIndex set to -1, nextIndex set to 0 01:11:52,721 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - Sent message UnInitializedFollowerSnapshotReply to self 01:11:52,722 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: onUnInitializedFollowerSnapshotReply: UnInitializedFollowerSnapshotReply [followerId=new-server] 01:11:52,722 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: New server configuration : [ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]] 01:11:52,722 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Persist data index=0 term=1 command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:52,722 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - leader: Append log entry and persist JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:52,722 AM [leader-%d669688] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-13082111928546194308/leader/snapshot-0000000069A240D8-2B15C9F8.tmp 01:11:52,722 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Replicate message: identifier: ServerOperationContextIdentifier{value=f70925c0-81be-4c11-bc15-c67fdf19e5fe}, logIndex: 0, isSendImmediate: true 01:11:52,723 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server: active: true, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:52,723 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower new-server 01:11:52,723 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower new-server: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:52,723 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): handleAppendEntries: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:52,724 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): Number of entries to be appended = 1 01:11:52,724 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): After cleanup, lastIndex: -1, entries to be added from: 0 01:11:52,724 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:52,724 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] ReplicatedLogImpl - new-server: Append log entry and persist JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:52,724 AM [new-server-%d492361] [DEBUG] RaftStorage - new-server: starting snapshot writeout to /tmp/junit-13082111928546194308/new-server/snapshot-0000000069A240D8-2B2DF0CE.tmp 01:11:52,724 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] PeerInfos - new-server: Updated server config: isVoting: true, peers: [PeerInfo [id=leader, address=null, votingState=VOTING]] 01:11:52,724 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): Log size is now 1 01:11:52,724 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): handleAppendEntries returning : AppendEntriesReply{term=1, success=true, followerId=new-server, logLastIndex=0, logLastTerm=1, forceInstallSnapshot=false, needsLeaderAddress=true, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:52,724 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] SyncStatusTracker - new-server: Lagging 0 entries behind leader leader and reached -1 (of expected -1) 01:11:52,724 AM [leader-%d669688] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-13082111928546194308/leader/snapshot-0000000069A240D8-2B15C9F8.v1 01:11:52,725 AM [leader-%d669688] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-13082111928546194308/leader/TermInfo.properties 01:11:52,725 AM [leader-%d669688] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-13082111928546194308/leader/journal-v1-1.log 01:11:52,725 AM [leader-%d669688] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-13082111928546194308/leader/metadata-v1-1.log 01:11:52,725 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Returning OK for operation AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server109, votingMember=true] 01:11:52,725 AM [leader-%d669688] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-13082111928546194308/leader/snapshot-0000000069A240D8-283C4939.v1 01:11:52,725 AM [leader-%d669688] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-13082111928546194308/leader/snapshot-0000000069A240D8-2B15C9F8.v1 01:11:52,725 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorageCompleter - new-server: awaiting more completions to resolve 1 synchronized callback(s) 01:11:52,725 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for new-server updated: matchIndex: 0, nextIndex: 1 01:11:52,725 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server: active: true, followerNextIndex: 1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:52,725 AM [leader-%d669688] [DEBUG] RaftStorage - leader: deleted snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:52.675039545Z, file=/tmp/junit-13082111928546194308/leader/snapshot-0000000069A240D8-283C4939.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:52,726 AM [leader-%d669688] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:52.722848248Z, file=/tmp/junit-13082111928546194308/leader/snapshot-0000000069A240D8-2B15C9F8.v1, size=86, entryCompress=NONE, stateCompress=NONE} 01:11:52,726 AM [leader-%d669688] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:52,726 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:52,726 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - leader: persist complete JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:52,726 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Applying to log - commitIndex: 0, lastAppliedIndex: -1 01:11:52,726 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - leader (Leader): Setting last applied to 0 01:11:52,726 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to 0 01:11:52,726 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:52,726 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActorVotingConfigSupport - leader: VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} has been successfully replicated to a majority of followers 01:11:52,726 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating AddServer [newServerId=new-server2, newServerAddress=pekko://test/user/follower107, votingMember=false] 01:11:52,726 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: New follower is non-voting - directly persisting new server configuration 01:11:52,726 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: New server configuration : [ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]] 01:11:52,726 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Persist data index=1 term=1 command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:52,726 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - leader: Append log entry and persist JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:52,726 AM [new-server-%d492361] [DEBUG] RaftStorage - new-server: finished snapshot writeout to /tmp/junit-13082111928546194308/new-server/snapshot-0000000069A240D8-2B2DF0CE.v1 01:11:52,726 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Replicate message: identifier: ServerOperationContextIdentifier{value=d4c4eecc-e231-46ea-9a51-a4c4581fd581}, logIndex: 1, isSendImmediate: true 01:11:52,726 AM [new-server-%d492361] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-13082111928546194308/new-server/snapshot-0000000069A240D8-2AC322AA.v1 01:11:52,727 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server: active: true, followerNextIndex: 1, leaderLastIndex: 1, leaderSnapShotIndex: -1 01:11:52,727 AM [leader-%d669689] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-13082111928546194308/leader/snapshot-0000000069A240D8-2B534E84.tmp 01:11:52,727 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 1 is present for follower new-server 01:11:52,727 AM [new-server-%d492361] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-13082111928546194308/new-server/TermInfo.properties 01:11:52,727 AM [new-server-%d492361] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-13082111928546194308/new-server/journal-v1-1.log 01:11:52,727 AM [new-server-%d492361] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-13082111928546194308/new-server/snapshot-0000000069A240D8-2B2DF0CE.v1 01:11:52,727 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower new-server: AppendEntries{term=1, leaderId=leader, prevLogIndex=0, prevLogTerm=1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:52,727 AM [new-server-%d492361] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-13082111928546194308/new-server/metadata-v1-1.log 01:11:52,727 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server2: active: false, followerNextIndex: 0, leaderLastIndex: 1, leaderSnapShotIndex: -1 01:11:52,727 AM [new-server-%d492361] [DEBUG] RaftStorage - new-server: deleted snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:52.717431466Z, file=/tmp/junit-13082111928546194308/new-server/snapshot-0000000069A240D8-2AC322AA.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:52,727 AM [new-server-%d492361] [DEBUG] RaftStorage - new-server: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:52.724431054Z, file=/tmp/junit-13082111928546194308/new-server/snapshot-0000000069A240D8-2B2DF0CE.v1, size=86, entryCompress=NONE, stateCompress=NONE} 01:11:52,727 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Returning OK for operation AddServer [newServerId=new-server2, newServerAddress=pekko://test/user/follower107, votingMember=false] 01:11:52,727 AM [new-server-%d492361] [DEBUG] RaftStorageCompleter - new-server: 1 completion(s) pending 01:11:52,727 AM [test-pekko.actor.default-dispatcher-7] [DEBUG] SyncStatusTracker - new-server2: Last sync leader does not match current leader leader, need to catch up to -1 01:11:52,727 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower new-server2 01:11:52,727 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower new-server2: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}, JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:52,728 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorageCompleter - new-server: running 1 completion(s) 01:11:52,728 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] ReplicatedLogImpl - new-server: persist complete JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false} 01:11:52,728 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorageCompleter - new-server: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@78acf929} 01:11:52,728 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorageCompleter - new-server: synchronized callbacks after 2.980 ms 01:11:52,729 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): handleAppendEntries: AppendEntries{term=1, leaderId=leader, prevLogIndex=0, prevLogTerm=1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:52,729 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): Number of entries to be appended = 1 01:11:52,729 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): After cleanup, lastIndex: 0, entries to be added from: 0 01:11:52,729 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:52,729 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] ReplicatedLogImpl - new-server: Append log entry and persist JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:52,730 AM [leader-%d669689] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-13082111928546194308/leader/snapshot-0000000069A240D8-2B534E84.v1 01:11:52,730 AM [new-server-%d492362] [DEBUG] RaftStorage - new-server: starting snapshot writeout to /tmp/junit-13082111928546194308/new-server/snapshot-0000000069A240D8-2B7D177E.tmp 01:11:52,731 AM [leader-%d669689] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-13082111928546194308/leader/snapshot-0000000069A240D8-2B534E84.v1 01:11:52,731 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] PeerInfos - new-server: Updated server config: isVoting: true, peers: [PeerInfo [id=leader, address=null, votingState=VOTING], PeerInfo [id=new-server2, address=null, votingState=NON_VOTING]] 01:11:52,731 AM [leader-%d669689] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-13082111928546194308/leader/TermInfo.properties 01:11:52,731 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): Log size is now 2 01:11:52,731 AM [leader-%d669689] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-13082111928546194308/leader/journal-v1-1.log 01:11:52,731 AM [leader-%d669689] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-13082111928546194308/leader/metadata-v1-1.log 01:11:52,731 AM [leader-%d669689] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-13082111928546194308/leader/snapshot-0000000069A240D8-2B15C9F8.v1 01:11:52,731 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): Commit index set to 0 01:11:52,731 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): handleAppendEntries returning : AppendEntriesReply{term=1, success=true, followerId=new-server, logLastIndex=1, logLastTerm=1, forceInstallSnapshot=false, needsLeaderAddress=true, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:52,731 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] SyncStatusTracker - new-server: Lagging 0 entries behind leader leader and reached 0 (of expected -1) 01:11:52,731 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 0, context.getLastApplied(): -1, lastIndex(): 1 01:11:52,731 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorBehavior - new-server (Follower): Setting last applied to 0 01:11:52,731 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractReplicatedLog - new-server: Moving last applied index from -1 to 0 01:11:52,731 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActor - new-server: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:52,732 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorageCompleter - new-server: awaiting more completions to resolve 1 synchronized callback(s) 01:11:52,732 AM [leader-%d669689] [DEBUG] RaftStorage - leader: deleted snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:52.722848248Z, file=/tmp/junit-13082111928546194308/leader/snapshot-0000000069A240D8-2B15C9F8.v1, size=86, entryCompress=NONE, stateCompress=NONE} 01:11:52,732 AM [leader-%d669689] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:52.726879876Z, file=/tmp/junit-13082111928546194308/leader/snapshot-0000000069A240D8-2B534E84.v1, size=100, entryCompress=NONE, stateCompress=NONE} 01:11:52,732 AM [leader-%d669689] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:52,732 AM [new-server-%d492362] [DEBUG] RaftStorage - new-server: finished snapshot writeout to /tmp/junit-13082111928546194308/new-server/snapshot-0000000069A240D8-2B7D177E.v1 01:11:52,733 AM [new-server-%d492362] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-13082111928546194308/new-server/snapshot-0000000069A240D8-2B7D177E.v1 01:11:52,733 AM [new-server-%d492362] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-13082111928546194308/new-server/TermInfo.properties 01:11:52,733 AM [new-server-%d492362] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-13082111928546194308/new-server/journal-v1-1.log 01:11:52,733 AM [new-server-%d492362] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-13082111928546194308/new-server/snapshot-0000000069A240D8-2B2DF0CE.v1 01:11:52,733 AM [new-server-%d492362] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-13082111928546194308/new-server/metadata-v1-1.log 01:11:52,733 AM [new-server-%d492362] [DEBUG] RaftStorage - new-server: deleted snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:52.724431054Z, file=/tmp/junit-13082111928546194308/new-server/snapshot-0000000069A240D8-2B2DF0CE.v1, size=86, entryCompress=NONE, stateCompress=NONE} 01:11:52,733 AM [new-server-%d492362] [DEBUG] RaftStorage - new-server: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:52.729618302Z, file=/tmp/junit-13082111928546194308/new-server/snapshot-0000000069A240D8-2B7D177E.v1, size=100, entryCompress=NONE, stateCompress=NONE} 01:11:52,733 AM [new-server-%d492362] [DEBUG] RaftStorageCompleter - new-server: 1 completion(s) pending 01:11:52,733 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorageCompleter - new-server: running 1 completion(s) 01:11:52,733 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] ReplicatedLogImpl - new-server: persist complete JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false} 01:11:52,733 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorageCompleter - new-server: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@76b4c15a} 01:11:52,733 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorageCompleter - new-server: synchronized callbacks after 1.540 ms 01:11:52,734 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:52,734 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - leader: persist complete JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:52,734 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for new-server updated: matchIndex: 1, nextIndex: 2 01:11:52,734 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Applying to log - commitIndex: 1, lastAppliedIndex: 0 01:11:52,734 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - leader (Leader): Setting last applied to 1 01:11:52,734 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from 0 to 1 01:11:52,734 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Applying state for log index 1 data VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:52,735 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server: active: true, followerNextIndex: 2, leaderLastIndex: 1, leaderSnapShotIndex: -1 [ERROR] [02/28/2026 01:11:52.733] [test-pekko.actor.internal-dispatcher-4] [pekko://test/user/follower107] Cannot invoke "org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.getReplicatedToAllIndex()" because "currentBehavior" is null java.lang.NullPointerException: Cannot invoke "org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.getReplicatedToAllIndex()" because "currentBehavior" is null at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.SnapshotManager.trimLog(SnapshotManager.java:663) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.performSnapshotWithoutCapture(RaftActorBehavior.java:438) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.Follower.handleAppendEntries(Follower.java:222) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.appendEntries(RaftActorBehavior.java:152) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.handleMessage(RaftActorBehavior.java:375) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.Follower.handleMessage(Follower.java:502) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.ForwardMessageToBehaviorActor.onReceive(ForwardMessageToBehaviorActor.java:25) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.UntypedAbstractActor$$anon$1.applyOrElse(AbstractActor.scala:341) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.Actor.aroundReceive(Actor.scala:547) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.Actor.aroundReceive$(Actor.scala:481) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.AbstractActor.aroundReceive(AbstractActor.scala:229) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.ActorCell.receiveMessage(ActorCell.scala:590) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.ActorCell.invoke(ActorCell.scala:557) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.dispatch.Mailbox.processMailbox(Mailbox.scala:273) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.dispatch.Mailbox.run(Mailbox.scala:234) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.dispatch.Mailbox.exec(Mailbox.scala:246) 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) [WARN] [02/28/2026 01:11:52.736] [test-pekko.actor.default-dispatcher-7] [pekko://test/user/new-server109] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=new-server, initialSyncDone=true] [INFO] [pekkoDeadLetter][02/28/2026 01:11:52.735] [test-pekko.actor.default-dispatcher-6] [pekko://test/user/new-server109] Message [org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus] to TestActor[pekko://test/user/new-server109] 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'. 01:11:52,736 AM [test-pekko.actor.default-dispatcher-7] [DEBUG] Follower - new-server (Follower): Commit index set to 1 01:11:52,736 AM [test-pekko.actor.default-dispatcher-7] [DEBUG] SyncStatusTracker - new-server: Lagging 0 entries behind leader leader and reached 1 (of expected -1) 01:11:52,736 AM [test-pekko.actor.default-dispatcher-7] [DEBUG] Follower - new-server (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 1, context.getLastApplied(): 0, lastIndex(): 1 01:11:52,736 AM [test-pekko.actor.default-dispatcher-7] [DEBUG] RaftActorBehavior - new-server (Follower): Setting last applied to 1 01:11:52,736 AM [test-pekko.actor.default-dispatcher-7] [DEBUG] AbstractReplicatedLog - new-server: Moving last applied index from 0 to 1 01:11:52,736 AM [test-pekko.actor.default-dispatcher-7] [DEBUG] RaftActor - new-server: Applying state for log index 1 data VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:52,749 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActorVotingConfigSupport - leader: VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} has been successfully replicated to a majority of followers 01:11:52,749 AM [test-pekko.actor.default-dispatcher-13] [ERROR] OneForOneStrategy - Cannot invoke "org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.getReplicatedToAllIndex()" because "currentBehavior" is null java.lang.NullPointerException: Cannot invoke "org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.getReplicatedToAllIndex()" because "currentBehavior" is null at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.SnapshotManager.trimLog(SnapshotManager.java:663) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.performSnapshotWithoutCapture(RaftActorBehavior.java:438) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.Follower.handleAppendEntries(Follower.java:222) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.appendEntries(RaftActorBehavior.java:152) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.handleMessage(RaftActorBehavior.java:375) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.Follower.handleMessage(Follower.java:502) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.ForwardMessageToBehaviorActor.onReceive(ForwardMessageToBehaviorActor.java:25) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.UntypedAbstractActor$$anon$1.applyOrElse(AbstractActor.scala:341) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.Actor.aroundReceive(Actor.scala:547) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.Actor.aroundReceive$(Actor.scala:481) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.AbstractActor.aroundReceive(AbstractActor.scala:229) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.ActorCell.receiveMessage(ActorCell.scala:590) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.ActorCell.invoke(ActorCell.scala:557) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.dispatch.Mailbox.processMailbox(Mailbox.scala:273) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.dispatch.Mailbox.run(Mailbox.scala:234) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.dispatch.Mailbox.exec(Mailbox.scala:246) 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) 01:11:52,750 AM [test-pekko.actor.default-dispatcher-13] [INFO] TestActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus] to TestActor[pekko://test/user/new-server109] 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'. 01:11:52,779 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithOperationInProgress ending 01:11:52,779 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower107] 01:11:52,791 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/new-serverCollector108#1555283066] 01:11:52,791 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/new-server109] 01:11:52,791 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EnabledRaftStorage - new-server: terminating thread VirtualThread[#258,new-server-writer-35]/waiting 01:11:52,792 AM [new-server-writer-35] [DEBUG] JournalWriteTask - new-server: received 1 commands after 173.6 ms 01:11:52,792 AM [new-server-writer-35] [DEBUG] JournalWriteTask - new-server: completed 1 commands in 41.60 μs 01:11:52,792 AM [new-server-writer-35] [DEBUG] JournalWriteTask - new-server: journal writer stopped 01:11:52,793 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - new-server: journal closed 01:11:52,793 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - new-server: journal closed 01:11:52,793 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:52,793 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:52,793 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader110] 01:11:52,793 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#259,leader-writer-36]/waiting 01:11:52,793 AM [leader-writer-36] [DEBUG] JournalWriteTask - leader: received 1 commands after 157.8 ms 01:11:52,793 AM [leader-writer-36] [DEBUG] JournalWriteTask - leader: completed 1 commands in 19.81 μs 01:11:52,793 AM [leader-writer-36] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:52,794 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:52,794 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - leader: journal closed 01:11:52,794 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:52,794 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:52,794 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leaderCollector111] 01:11:52,798 AM [main] [INFO] RaftActorVotingConfigSupportTest - testRemoveServerNonExistentServer starting 01:11:52,799 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupportTest$MockLeaderRaftActor - Actor created TestActor[pekko://test/user/leader113] 01:11:52,799 AM [test-pekko.actor.default-dispatcher-13] [INFO] EmptyLocalActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/leader113] 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/28/2026 01:11:52.799] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader113]: org.opendaylight.controller.cluster.common.actor.Monitor@5f15a192 [INFO] [pekkoDeadLetter][02/28/2026 01:11:52.799] [test-pekko.actor.default-dispatcher-13] [pekko://test/user/termination-monitor] Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/leader113] 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'. 01:11:52,801 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:52,801 AM [test-pekko.actor.default-dispatcher-15] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:52,801 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: started executor 01:11:52,801 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: started executor 01:11:52,802 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:52,803 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:52,803 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:52,803 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:52,803 AM [leader-writer-37] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:52,803 AM [leader-writer-37] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:52,803 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - /tmp/junit-2127324345293817444/leader/TermInfo.properties does not exist 01:11:52,805 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:52,805 AM [test-pekko.actor.default-dispatcher-15] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=1, votedFor=} 01:11:52,806 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-2127324345293817444/leader/TermInfo.properties 01:11:52,806 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-2127324345293817444/leader/journal-v1-1.log 01:11:52,806 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-2127324345293817444/leader/metadata-v1-1.log 01:11:52,806 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: no eligible files found 01:11:52,806 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:52,806 AM [test-pekko.actor.default-dispatcher-15] [INFO] Recovery - leader: Recovery completed in in 3.001 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:52,806 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:52,806 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractLeader - leader (Leader): Election: Leader has following peers: [follower] 01:11:52,806 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 01:11:52,817 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupport - leader: onRemoveServer: RemoveServer{serverId='new-server'}, state: Idle 01:11:52,819 AM [main] [INFO] RaftActorVotingConfigSupportTest - testRemoveServerNonExistentServer ending 01:11:52,819 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower112] 01:11:52,830 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader113] 01:11:52,831 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#272,leader-writer-37]/waiting 01:11:52,831 AM [leader-writer-37] [DEBUG] JournalWriteTask - leader: received 1 commands after 28.19 ms 01:11:52,831 AM [leader-writer-37] [DEBUG] JournalWriteTask - leader: completed 1 commands in 55.35 μs 01:11:52,831 AM [leader-writer-37] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:52,832 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:52,832 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - leader: journal closed 01:11:52,832 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:52,832 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:52,842 AM [main] [INFO] RaftActorVotingConfigSupportTest - testRemoveServerWithNoLeader starting 01:11:52,842 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] MockRaftActor - Actor created TestActor[pekko://test/user/leader115] 01:11:52,844 AM [test-pekko.actor.default-dispatcher-15] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:52,844 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: started executor 01:11:52,845 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: started executor [WARN] [02/28/2026 01:11:52.845] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader115]: org.opendaylight.controller.cluster.common.actor.Monitor@352e9cc3 [INFO] [pekkoDeadLetter][02/28/2026 01:11:52.845] [test-pekko.actor.default-dispatcher-13] [pekko://test/user/termination-monitor] Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/leader115] 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'. 01:11:52,846 AM [test-pekko.actor.default-dispatcher-13] [INFO] EmptyLocalActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/leader115] 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'. 01:11:52,846 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:52,846 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:52,846 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:52,846 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:52,846 AM [leader-writer-38] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:52,847 AM [leader-writer-38] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:52,847 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - /tmp/junit-6610686788234284512/leader/TermInfo.properties does not exist 01:11:52,852 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=0, votedFor=null 01:11:52,852 AM [test-pekko.actor.default-dispatcher-15] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=0} 01:11:52,852 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-6610686788234284512/leader/TermInfo.properties 01:11:52,852 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-6610686788234284512/leader/journal-v1-1.log 01:11:52,852 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-6610686788234284512/leader/metadata-v1-1.log 01:11:52,853 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: no eligible files found 01:11:52,853 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:52,853 AM [test-pekko.actor.default-dispatcher-15] [INFO] Recovery - leader: Recovery completed in in 6.080 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:52,853 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:52,866 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupport - leader: onRemoveServer: RemoveServer{serverId='follower'}, state: Idle 01:11:52,866 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupport - leader: No leader - returning NO_LEADER reply 01:11:52,867 AM [main] [INFO] RaftActorVotingConfigSupportTest - testRemoveServerWithNoLeader ending 01:11:52,867 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower114] 01:11:52,879 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader115] 01:11:52,879 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#273,leader-writer-38]/waiting 01:11:52,880 AM [leader-writer-38] [DEBUG] JournalWriteTask - leader: received 1 commands after 33.31 ms 01:11:52,880 AM [leader-writer-38] [DEBUG] JournalWriteTask - leader: completed 1 commands in 76.27 μs 01:11:52,880 AM [leader-writer-38] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:52,881 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:52,881 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - leader: journal closed 01:11:52,881 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:52,881 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:52,888 AM [main] [INFO] RaftActorVotingConfigSupportTest - testRemoveServerLeader starting 01:11:52,888 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupportTest$MockLeaderRaftActor - Actor created TestActor[pekko://test/user/leader118] [WARN] [02/28/2026 01:11:52.889] [test-pekko.actor.default-dispatcher-13] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader118]: org.opendaylight.controller.cluster.common.actor.Monitor@15cf0fc1 [INFO] [pekkoDeadLetter][02/28/2026 01:11:52.889] [test-pekko.actor.default-dispatcher-13] [pekko://test/user/termination-monitor] Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/leader118] to Actor[pekko://test/user/termination-monitor] was not delivered. [7] 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'. 01:11:52,889 AM [test-pekko.actor.default-dispatcher-16] [INFO] EmptyLocalActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/leader118] to Actor[pekko://test/user/termination-monitor] was not delivered. [7] 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'. 01:11:52,890 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:52,890 AM [test-pekko.actor.default-dispatcher-15] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:52,891 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: started executor 01:11:52,891 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: started executor 01:11:52,891 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:52,892 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:52,892 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:52,892 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:52,892 AM [leader-writer-39] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:52,892 AM [leader-writer-39] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:52,892 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - /tmp/junit-3308373452416289789/leader/TermInfo.properties does not exist 01:11:52,895 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:52,895 AM [test-pekko.actor.default-dispatcher-15] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=1, votedFor=} 01:11:52,895 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-3308373452416289789/leader/TermInfo.properties 01:11:52,895 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-3308373452416289789/leader/journal-v1-1.log 01:11:52,895 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-3308373452416289789/leader/metadata-v1-1.log 01:11:52,895 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: no eligible files found 01:11:52,895 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:52,895 AM [test-pekko.actor.default-dispatcher-15] [INFO] Recovery - leader: Recovery completed in in 2.953 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:52,895 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:52,895 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractLeader - leader (Leader): Election: Leader has following peers: [follower] 01:11:52,896 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 [WARN] [02/28/2026 01:11:52.896] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/follower117] received dead letter from TestActor[pekko://test/user/leader118]: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]} 01:11:52,896 AM [test-pekko.actor.default-dispatcher-13] [INFO] EmptyLocalActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.raft.messages.AppendEntries] from TestActor[pekko://test/user/leader118] to Actor[pekko://test/user/follower117] was not delivered. [8] dead letters encountered. If this is not an expected behavior then Actor[pekko://test/user/follower117] 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'. [INFO] [pekkoDeadLetter][02/28/2026 01:11:52.896] [test-pekko.actor.default-dispatcher-13] [pekko://test/user/follower117] Message [org.opendaylight.controller.cluster.raft.messages.AppendEntries] from TestActor[pekko://test/user/leader118] to Actor[pekko://test/user/follower117] was not delivered. [8] dead letters encountered. If this is not an expected behavior then Actor[pekko://test/user/follower117] 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'. 01:11:52,902 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupportTest$CollectingMockRaftActor - Actor created TestActor[pekko://test/user/follower117] [WARN] [02/28/2026 01:11:52.902] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/follower117]: org.opendaylight.controller.cluster.common.actor.Monitor@7e4b0b33 [INFO] [pekkoDeadLetter][02/28/2026 01:11:52.903] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/follower117] 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'. 01:11:52,903 AM [test-pekko.actor.default-dispatcher-13] [INFO] EmptyLocalActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.common.actor.Monitor] from TestActor[pekko://test/user/follower117] 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'. 01:11:52,903 AM [test-pekko.actor.default-dispatcher-15] [INFO] RaftActor - follower: Starting recovery with journal batch size 1000 01:11:52,903 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - follower: started executor 01:11:52,904 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - follower: started executor 01:11:52,904 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - follower: metadata journal open: replayFrom=1 applyTo=0 01:11:52,905 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - follower: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:52,905 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - follower: journal open: applyTo=0 01:11:52,905 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - follower: recovering to non-persistent 01:11:52,905 AM [follower-writer-40] [DEBUG] JournalWriteTask - follower: journal writer started 01:11:52,905 AM [follower-writer-40] [DEBUG] JournalWriteTask - follower: waiting to receive commands 01:11:52,905 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - /tmp/junit-3308373452416289789/follower/TermInfo.properties does not exist 01:11:52,910 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - follower: Set currentTerm=0, votedFor=null 01:11:52,910 AM [test-pekko.actor.default-dispatcher-15] [INFO] Recovery - follower: Local TermInfo store seeded with TermInfo{term=0} 01:11:52,910 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-3308373452416289789/follower/TermInfo.properties 01:11:52,910 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-3308373452416289789/follower/journal-v1-1.log 01:11:52,910 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-3308373452416289789/follower/metadata-v1-1.log 01:11:52,910 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - follower: no eligible files found 01:11:52,910 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - follower: Moving last applied index from -1 to -1 01:11:52,910 AM [test-pekko.actor.default-dispatcher-15] [INFO] Recovery - follower: Recovery completed in in 5.508 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:52,910 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - follower: Recovery completed and can restore from snapshot 01:11:52,921 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupport - leader: onRemoveServer: RemoveServer{serverId='leader'}, state: Idle 01:11:52,924 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupport - leader: New server configuration : [ServerInfo[peerId=follower, isVoting=true]] 01:11:52,924 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - leader: Persist data index=0 term=1 command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true]]} 01:11:52,924 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] ReplicatedLogImpl - leader: Append log entry and persist JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true]]}, pending=true} 01:11:52,925 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractLeader - leader (Leader): Replicate message: identifier: ServerOperationContextIdentifier{value=c965ff4c-36cd-4589-8272-1d4f1a16385f}, logIndex: 0, isSendImmediate: true 01:11:52,925 AM [leader-%d706094] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-3308373452416289789/leader/snapshot-0000000069A240D8-3725E78D.tmp 01:11:52,925 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: false, followerNextIndex: -1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:52,925 AM [test-pekko.actor.default-dispatcher-13] [INFO] Follower - follower (Follower): Term 1 in "AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 0 - updating term 01:11:52,926 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupport - leader: Returning OK for operation RemoveServer{serverId='leader'} 01:11:52,940 AM [leader-%d706094] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-3308373452416289789/leader/snapshot-0000000069A240D8-3725E78D.v1 01:11:52,940 AM [leader-%d706094] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-3308373452416289789/leader/snapshot-0000000069A240D8-3725E78D.v1 01:11:52,941 AM [leader-%d706094] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-3308373452416289789/leader/TermInfo.properties 01:11:52,941 AM [leader-%d706094] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-3308373452416289789/leader/journal-v1-1.log 01:11:52,941 AM [leader-%d706094] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-3308373452416289789/leader/metadata-v1-1.log 01:11:52,941 AM [leader-%d706094] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:52.925230989Z, file=/tmp/junit-3308373452416289789/leader/snapshot-0000000069A240D8-3725E78D.v1, size=75, entryCompress=NONE, stateCompress=NONE} 01:11:52,941 AM [leader-%d706094] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:52,941 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - follower: Set currentTerm=1, votedFor=null 01:11:52,941 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SyncStatusTracker - follower: Last sync leader does not match current leader leader, need to catch up to -1 01:11:52,941 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:52,942 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - leader: persist complete JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true]]}, pending=true} [WARN] [02/28/2026 01:11:52.942] [test-pekko.actor.default-dispatcher-13] [pekko://test/user/follower117] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=follower, initialSyncDone=false] 01:11:52,942 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for follower updated: matchIndex: -1, nextIndex: 0 01:11:52,942 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: true, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:52,942 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower follower [INFO] [pekkoDeadLetter][02/28/2026 01:11:52.942] [test-pekko.actor.default-dispatcher-13] [pekko://test/user/follower117] Message [org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus] to TestActor[pekko://test/user/follower117] was unhandled. [10] dead letters encountered, no more dead letters will be logged in next [5.000 min]. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 01:11:52,942 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower follower: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true]]}, pending=false}]} 01:11:52,943 AM [test-pekko.actor.default-dispatcher-13] [INFO] TestActorRef - pekkoDeadLetter Message [org.opendaylight.controller.cluster.raft.base.messages.FollowerInitialSyncUpStatus] to TestActor[pekko://test/user/follower117] was unhandled. [10] dead letters encountered, no more dead letters will be logged in next [5.000 min]. This logging can be turned off or adjusted with configuration settings 'pekko.log-dead-letters' and 'pekko.log-dead-letters-during-shutdown'. 01:11:52,943 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower (Follower): handleAppendEntries: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true]]}, pending=false}]} 01:11:52,943 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower (Follower): Number of entries to be appended = 1 01:11:52,943 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower (Follower): After cleanup, lastIndex: -1, entries to be added from: 0 01:11:52,943 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true]]} 01:11:52,943 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] ReplicatedLogImpl - follower: Append log entry and persist JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true]]}, pending=false} 01:11:52,943 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PeerInfos - follower: Updated server config: isVoting: true, peers: [] 01:11:52,943 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower (Follower): Log size is now 1 01:11:52,943 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower (Follower): handleAppendEntries returning : AppendEntriesReply{term=1, success=true, followerId=follower, logLastIndex=0, logLastTerm=1, forceInstallSnapshot=false, needsLeaderAddress=true, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:52,943 AM [follower-%d623786] [DEBUG] RaftStorage - follower: starting snapshot writeout to /tmp/junit-3308373452416289789/follower/snapshot-0000000069A240D8-383C00E8.tmp 01:11:52,943 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SyncStatusTracker - follower: Lagging 0 entries behind leader leader and reached -1 (of expected -1) 01:11:52,943 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - follower: awaiting more completions to resolve 1 synchronized callback(s) 01:11:52,943 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for follower updated: matchIndex: 0, nextIndex: 1 01:11:52,944 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Applying to log - commitIndex: 0, lastAppliedIndex: -1 01:11:52,944 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - leader (Leader): Setting last applied to 0 01:11:52,944 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to 0 01:11:52,944 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true]]} 01:11:52,944 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: true, followerNextIndex: 1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:52,944 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActorVotingConfigSupport - leader: VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true]]} has been successfully replicated to a majority of followers 01:11:52,946 AM [follower-%d623786] [DEBUG] RaftStorage - follower: finished snapshot writeout to /tmp/junit-3308373452416289789/follower/snapshot-0000000069A240D8-383C00E8.v1 01:11:52,946 AM [follower-%d623786] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-3308373452416289789/follower/TermInfo.properties 01:11:52,946 AM [follower-%d623786] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-3308373452416289789/follower/journal-v1-1.log 01:11:52,946 AM [follower-%d623786] [DEBUG] RaftStorage - follower: selected SNAPSHOT_V1 to handle file /tmp/junit-3308373452416289789/follower/snapshot-0000000069A240D8-383C00E8.v1 01:11:52,946 AM [follower-%d623786] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-3308373452416289789/follower/metadata-v1-1.log 01:11:52,946 AM [follower-%d623786] [DEBUG] RaftStorage - follower: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:52.943456488Z, file=/tmp/junit-3308373452416289789/follower/snapshot-0000000069A240D8-383C00E8.v1, size=75, entryCompress=NONE, stateCompress=NONE} 01:11:52,946 AM [follower-%d623786] [DEBUG] RaftStorageCompleter - follower: 1 completion(s) pending 01:11:52,946 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - follower: running 1 completion(s) 01:11:52,946 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] ReplicatedLogImpl - follower: persist complete JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true]]}, pending=false} 01:11:52,946 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - follower: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@1f0c9ca0} 01:11:52,946 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - follower: synchronized callbacks after 2.855 ms 01:11:52,946 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower (Follower): Commit index set to 0 01:11:52,946 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SyncStatusTracker - follower: Lagging 0 entries behind leader leader and reached 0 (of expected -1) 01:11:52,946 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 0, context.getLastApplied(): -1, lastIndex(): 0 01:11:52,946 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorBehavior - follower (Follower): Setting last applied to 0 01:11:52,946 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractReplicatedLog - follower: Moving last applied index from -1 to 0 01:11:52,947 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActor - follower: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true]]} [WARN] [02/28/2026 01:11:52.947] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/leader118] unhandled message from TestActor[pekko://test/user/leader118]: ServerRemoved [serverId=leader] [WARN] [02/28/2026 01:11:52.947] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/follower117] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=follower, initialSyncDone=true] 01:11:52,977 AM [main] [INFO] RaftActorVotingConfigSupportTest - testRemoveServerLeader ending 01:11:52,978 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower116] 01:11:52,989 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader118] 01:11:52,990 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#274,leader-writer-39]/waiting 01:11:52,990 AM [leader-writer-39] [DEBUG] JournalWriteTask - leader: received 1 commands after 97.64 ms 01:11:52,990 AM [leader-writer-39] [DEBUG] JournalWriteTask - leader: completed 1 commands in 46.14 μs 01:11:52,990 AM [leader-writer-39] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:52,991 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:52,991 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - leader: journal closed 01:11:52,991 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:52,991 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:52,991 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leaderCollector119] 01:11:52,992 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/collector120#-1963867683] 01:11:52,992 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower117] 01:11:52,993 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EnabledRaftStorage - follower: terminating thread VirtualThread[#275,follower-writer-40]/waiting 01:11:52,993 AM [follower-writer-40] [DEBUG] JournalWriteTask - follower: received 1 commands after 88.15 ms 01:11:52,993 AM [follower-writer-40] [DEBUG] JournalWriteTask - follower: completed 1 commands in 36.89 μs 01:11:52,993 AM [follower-writer-40] [DEBUG] JournalWriteTask - follower: journal writer stopped 01:11:52,993 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - follower: journal closed 01:11:52,993 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - follower: journal closed 01:11:52,993 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - follower: stopped executor with 0 remaining tasks 01:11:52,993 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - follower: stopped executor with 0 remaining tasks 01:11:53,1 AM [main] [INFO] RaftActorVotingConfigSupportTest - testChangeToVotingWithNoLeaderAndOtherLeaderElected starting 01:11:53,4 AM [main] [DEBUG] PropertiesTermInfoStore - node1: Set currentTerm=1, votedFor=node1 01:11:53,5 AM [main] [DEBUG] EntryJournalV1 - node1: metadata journal open: replayFrom=1 applyTo=0 01:11:53,6 AM [main] [DEBUG] EntryJournalV1 - node1: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:53,10 AM [main] [DEBUG] EntryJournalV1 - node1: journal closed 01:11:53,13 AM [main] [DEBUG] PropertiesTermInfoStore - node2: Set currentTerm=1, votedFor=node1 01:11:53,13 AM [main] [DEBUG] EntryJournalV1 - node2: metadata journal open: replayFrom=1 applyTo=0 01:11:53,13 AM [main] [DEBUG] EntryJournalV1 - node2: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:53,17 AM [main] [DEBUG] EntryJournalV1 - node2: journal closed 01:11:53,18 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupportTest$CollectingMockRaftActor - Actor created TestActor[pekko://test/user/node1] [WARN] [02/28/2026 01:11:53.019] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/node1]: org.opendaylight.controller.cluster.common.actor.Monitor@4d517fd4 01:11:53,21 AM [test-pekko.actor.default-dispatcher-15] [INFO] RaftActor - node1: Starting recovery with journal batch size 1000 01:11:53,21 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node1: started executor 01:11:53,21 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node1: started executor 01:11:53,22 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - node1: metadata journal open: replayFrom=1 applyTo=0 01:11:53,23 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - node1: journal open: firstIndex=1 lastIndex=1 replayFrom=1 fileEntries=0 01:11:53,23 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - node1: journal open: applyTo=0 01:11:53,23 AM [node1-writer-41] [DEBUG] JournalWriteTask - node1: journal writer started 01:11:53,23 AM [node1-writer-41] [DEBUG] JournalWriteTask - node1: waiting to receive commands 01:11:53,23 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - node1: starting journal recovery 01:11:53,24 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - node1: Set currentTerm=1, votedFor=node1 01:11:53,24 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node1: skipping unrecognized file /tmp/junit-16259366548566886699/node1/TermInfo.properties 01:11:53,24 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node1: skipping unrecognized file /tmp/junit-16259366548566886699/node1/journal-v1-1.log 01:11:53,24 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node1: skipping unrecognized file /tmp/junit-16259366548566886699/node1/metadata-v1-1.log 01:11:53,24 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node1: no eligible files found 01:11:53,24 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - node1: Moving last applied index from -1 to -1 01:11:53,24 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] JournalRecovery - node1: applying entries up to 0 01:11:53,25 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] JournalRecovery - node1: recovered journal DefaultLogEntry[index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=false], ServerInfo[peerId=node2, isVoting=true]]}] 01:11:53,25 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PeerInfos - node1: Updated server config: isVoting: false, peers: [PeerInfo [id=node2, address=null, votingState=VOTING]] 01:11:53,25 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - node1: Moving last applied index from -1 to -1 01:11:53,25 AM [test-pekko.actor.default-dispatcher-15] [INFO] Recovery - node1: Recovery completed in in 1.786 ms: last log index = 0, last log term = 1, napshot index = -1, snapshot term = -1, journal size = 1 01:11:53,25 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - node1: Recovery completed and cannot restore from snapshot 01:11:53,27 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupportTest$CollectingMockRaftActor - Actor created TestActor[pekko://test/user/node2] [WARN] [02/28/2026 01:11:53.027] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/node2]: org.opendaylight.controller.cluster.common.actor.Monitor@3f3a5edd 01:11:53,28 AM [test-pekko.actor.default-dispatcher-15] [INFO] RaftActor - node2: Starting recovery with journal batch size 1000 01:11:53,28 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node2: started executor 01:11:53,28 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node2: started executor 01:11:53,28 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - node2: metadata journal open: replayFrom=1 applyTo=0 01:11:53,29 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - node2: journal open: firstIndex=1 lastIndex=1 replayFrom=1 fileEntries=0 01:11:53,29 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - node2: journal open: applyTo=0 01:11:53,29 AM [node2-writer-42] [DEBUG] JournalWriteTask - node2: journal writer started 01:11:53,29 AM [node2-writer-42] [DEBUG] JournalWriteTask - node2: waiting to receive commands 01:11:53,29 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - node2: starting journal recovery 01:11:53,29 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - node2: Set currentTerm=1, votedFor=node1 01:11:53,29 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node2: skipping unrecognized file /tmp/junit-16259366548566886699/node2/TermInfo.properties 01:11:53,29 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node2: skipping unrecognized file /tmp/junit-16259366548566886699/node2/journal-v1-1.log 01:11:53,29 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node2: skipping unrecognized file /tmp/junit-16259366548566886699/node2/metadata-v1-1.log 01:11:53,29 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node2: no eligible files found 01:11:53,29 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - node2: Moving last applied index from -1 to -1 01:11:53,29 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] JournalRecovery - node2: applying entries up to 0 01:11:53,30 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] JournalRecovery - node2: recovered journal DefaultLogEntry[index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=false], ServerInfo[peerId=node2, isVoting=true]]}] 01:11:53,30 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PeerInfos - node2: Updated server config: isVoting: true, peers: [PeerInfo [id=node1, address=null, votingState=NON_VOTING]] 01:11:53,30 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - node2: Moving last applied index from -1 to -1 01:11:53,30 AM [test-pekko.actor.default-dispatcher-15] [INFO] Recovery - node2: Recovery completed in in 759.1 μs: last log index = 0, last log term = 1, napshot index = -1, snapshot term = -1, journal size = 1 01:11:53,30 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - node2: Recovery completed and cannot restore from snapshot 01:11:53,41 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupport - node1: onChangeServersVotingStatus: ChangeServersVotingStatus [serverVotingStatusMap={node1=true, node2=true}, serversVisited=[]], state: Idle 01:11:53,47 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupport - Initiating ChangeServersVotingStatusState 01:11:53,47 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupport - node1: Sending local ElectionTimeout to start leader election 01:11:53,47 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PeerInfos - node1: Updated server config: isVoting: true, peers: [PeerInfo [id=node2, address=null, votingState=VOTING]] 01:11:53,47 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - node1 (Follower): Received TimeoutNow - switching to Candidate 01:11:53,48 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Candidate - node1 (Candidate): Election: Candidate has following voting peers: [node2] 01:11:53,50 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - node1: Set currentTerm=2, votedFor=node1 01:11:53,50 AM [test-pekko.actor.default-dispatcher-15] [INFO] Candidate - node1 (Candidate): Starting new election term 2 01:11:53,50 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Candidate - node1 (Candidate): Sending RequestVote{term=2, candidateId=node1, lastLogIndex=0, lastLogTerm=1} to peer node2 01:11:53,51 AM [test-pekko.actor.default-dispatcher-15] [INFO] RaftActorBehavior - node1 (Follower) :- Switching from behavior Follower to Candidate, election term: 2 01:11:53,92 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - node2 (Follower): Received TimeoutNow - switching to Candidate 01:11:53,93 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Candidate - node2 (Candidate): Election: Candidate has following voting peers: [] 01:11:53,95 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - node2: Set currentTerm=2, votedFor=node2 01:11:53,95 AM [test-pekko.actor.default-dispatcher-13] [INFO] Candidate - node2 (Candidate): Starting new election term 2 01:11:53,95 AM [test-pekko.actor.default-dispatcher-13] [INFO] RaftActorBehavior - node2 (Follower) :- Switching from behavior Follower to Candidate, election term: 2 01:11:53,96 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Candidate - node2 (Candidate): Received ElectionTimeout 01:11:53,96 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - node2 (Leader): Election: Leader has following peers: [node1] 01:11:53,96 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - node2 (Leader): Checking sendAppendEntries for follower node1: active: false, followerNextIndex: -1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:53,96 AM [test-pekko.actor.default-dispatcher-13] [INFO] RaftActorBehavior - node2 (Candidate) :- Switching from behavior Candidate to Leader, election term: 2 01:11:53,96 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Candidate - node1 (Candidate): RaftRPC message received AppendEntries{term=2, leaderId=node2, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}, my term is 2 01:11:53,97 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Candidate - node1 (Candidate): handleAppendEntries: AppendEntries{term=2, leaderId=node2, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]} 01:11:53,97 AM [test-pekko.actor.default-dispatcher-15] [INFO] Candidate - node1 (Candidate): New Leader node2 sent an AppendEntries to Candidate for term 2 - will switch to Follower 01:11:53,97 AM [test-pekko.actor.default-dispatcher-15] [INFO] RaftActorBehavior - node1 (Candidate) :- Switching from behavior Candidate to Follower, election term: 2 01:11:53,217 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SyncStatusTracker - node1: Last sync leader does not match current leader node2, need to catch up to -1 01:11:53,217 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupport - node1: New leader node2 elected 01:11:53,217 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - node2 (Leader): handleAppendEntriesReply - FollowerLogInformation for node1 updated: matchIndex: 0, nextIndex: 1 01:11:53,217 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupport - node1: Forwarding ChangeServersVotingStatus [serverVotingStatusMap={node1=true, node2=true}, serversVisited=[]] to new leader 01:11:53,217 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - node2 (Leader): Not updating commit index to 0 - retrieved log entry with index 0, term 1 does not match the current term 2 01:11:53,217 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PeerInfos - node1: Updated server config: isVoting: false, peers: [PeerInfo [id=node2, address=pekko://test/user/node2, votingState=VOTING]] 01:11:53,217 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - node1: getLeaderAddress leaderId = node2 peerAddress = pekko://test/user/node2 01:11:53,217 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - node2 (Leader): Checking sendAppendEntries for follower node1: active: true, followerNextIndex: 1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:53,218 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupport - node1: Not leader - forwarding to leader ActorSelection[Anchor(pekko://test/), Path(/user/node2)] 01:11:53,218 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - node2: onChangeServersVotingStatus: ChangeServersVotingStatus [serverVotingStatusMap={node1=true, node2=true}, serversVisited=[]], state: Idle 01:11:53,218 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - Initiating ChangeServersVotingStatusState [WARN] [02/28/2026 01:11:53.218] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/node1] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=node1, initialSyncDone=false] 01:11:53,218 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PeerInfos - node2: Updated server config: isVoting: true, peers: [PeerInfo [id=node1, address=pekko://test/user/node1, votingState=VOTING]] 01:11:53,218 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - node2: New server configuration : [ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]] 01:11:53,218 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - node2: Persist data index=1 term=2 command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]} 01:11:53,218 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - node2: Append log entry and persist JournaledLogEntry{index=1, term=2, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]}, pending=true} 01:11:53,219 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - node2 (Leader): Replicate message: identifier: ServerOperationContextIdentifier{value=09b3dde7-61f1-481f-8b5f-8c7ed8410c0f}, logIndex: 1, isSendImmediate: true 01:11:53,219 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - node2 (Leader): Checking sendAppendEntries for follower node1: active: true, followerNextIndex: 1, leaderLastIndex: 1, leaderSnapShotIndex: -1 01:11:53,219 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - node2 (Leader): sendAppendEntries: 1 is present for follower node1 01:11:53,219 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - node2 (Leader): Sending AppendEntries to follower node1: AppendEntries{term=2, leaderId=node2, prevLogIndex=0, prevLogTerm=1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=1, term=2, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]}, pending=true}]} 01:11:53,219 AM [node2-writer-42] [DEBUG] JournalWriteTask - node2: received 1 commands after 190.1 ms 01:11:53,219 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - node2: Returning OK for operation ChangeServersVotingStatus [serverVotingStatusMap={node1=true, node2=true}, serversVisited=[]] 01:11:53,219 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - node1 (Follower): handleAppendEntries: AppendEntries{term=2, leaderId=node2, prevLogIndex=0, prevLogTerm=1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=1, term=2, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]}, pending=true}]} 01:11:53,219 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - node1 (Follower): Number of entries to be appended = 1 01:11:53,220 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - node1 (Follower): After cleanup, lastIndex: 0, entries to be added from: 0 01:11:53,220 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - node1 (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]} 01:11:53,220 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] ReplicatedLogImpl - node1: Append log entry and persist JournaledLogEntry{index=1, term=2, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]}, pending=true} 01:11:53,220 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PeerInfos - node1: Updated server config: isVoting: true, peers: [PeerInfo [id=node2, address=pekko://test/user/node2, votingState=VOTING]] 01:11:53,220 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - node1 (Follower): Log size is now 2 01:11:53,220 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - node1 (Follower): handleAppendEntries returning : AppendEntriesReply{term=2, success=true, followerId=node1, logLastIndex=1, logLastTerm=2, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:53,220 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SyncStatusTracker - node1: Lagging 0 entries behind leader node2 and reached -1 (of expected -1) 01:11:53,220 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - node1: awaiting more completions to resolve 1 synchronized callback(s) 01:11:53,220 AM [node1-writer-41] [DEBUG] JournalWriteTask - node1: received 1 commands after 196.6 ms 01:11:53,221 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - node2 (Leader): handleAppendEntriesReply - FollowerLogInformation for node1 updated: matchIndex: 1, nextIndex: 2 01:11:53,221 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - node2 (Leader): Not updating commit index to 0 - retrieved log entry with index 0, term 1 does not match the current term 2 01:11:53,221 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - node2 (Leader): Checking sendAppendEntries for follower node1: active: true, followerNextIndex: 2, leaderLastIndex: 1, leaderSnapShotIndex: -1 01:11:53,230 AM [node1-writer-41] [DEBUG] RaftStorageCompleter - node1: 1 completion(s) pending 01:11:53,230 AM [node2-writer-42] [DEBUG] RaftStorageCompleter - node2: 1 completion(s) pending 01:11:53,230 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - node1: running 1 completion(s) 01:11:53,230 AM [node1-writer-41] [DEBUG] JournalWriteTask - node1: completed 1 commands in 9.686 ms 01:11:53,230 AM [node1-writer-41] [DEBUG] JournalWriteTask - node1: waiting to receive commands 01:11:53,230 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] ReplicatedLogImpl - node1: persist complete JournaledLogEntry{index=1, term=2, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]}, pending=false} 01:11:53,230 AM [node2-writer-42] [DEBUG] JournalWriteTask - node2: completed 1 commands in 10.51 ms 01:11:53,230 AM [node2-writer-42] [DEBUG] JournalWriteTask - node2: waiting to receive commands 01:11:53,230 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - node1: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=1, term=2, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@36b9dd76} 01:11:53,230 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - node1: synchronized callbacks after 10.07 ms 01:11:53,230 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorageCompleter - node2: running 1 completion(s) 01:11:53,230 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] ReplicatedLogImpl - node2: persist complete JournaledLogEntry{index=1, term=2, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]}, pending=true} 01:11:53,230 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractLeader - node2 (Leader): Not updating commit index to 0 - retrieved log entry with index 0, term 1 does not match the current term 2 [WARN] [02/28/2026 01:11:53.230] [test-pekko.actor.default-dispatcher-13] [pekko://test/user/node1] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=node1, initialSyncDone=true] 01:11:53,230 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractLeader - node2 (Leader): Applying to log - commitIndex: 1, lastAppliedIndex: -1 01:11:53,231 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - node2 (Leader): Setting last applied to 0 01:11:53,231 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - node2: Moving last applied index from -1 to 0 01:11:53,231 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - node2: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=false], ServerInfo[peerId=node2, isVoting=true]]} 01:11:53,231 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - node2 (Leader): Setting last applied to 1 01:11:53,231 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - node2: Moving last applied index from 0 to 1 01:11:53,231 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - node2: Applying state for log index 1 data VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]} 01:11:53,231 AM [node2-writer-42] [DEBUG] JournalWriteTask - node2: received 1 commands after 790.9 μs 01:11:53,231 AM [node2-writer-42] [DEBUG] EntryJournalV1 - node2: updated meta to JournalMeta[replayFrom=1, applyTo=2] 01:11:53,231 AM [node2-writer-42] [DEBUG] RaftStorageCompleter - node2: 1 completion(s) pending 01:11:53,231 AM [node2-writer-42] [DEBUG] JournalWriteTask - node2: completed 1 commands in 411.8 μs 01:11:53,231 AM [node2-writer-42] [DEBUG] JournalWriteTask - node2: waiting to receive commands 01:11:53,232 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SnapshotManager - node2: fakeSnapshot purging log to 0 for term 2 01:11:53,232 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorageCompleter - node2: running 1 completion(s) 01:11:53,232 AM [test-pekko.actor.default-dispatcher-15] [INFO] RaftActorVotingConfigSupport - node2: VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]} has been successfully replicated to a majority of followers 01:11:53,337 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - node1 (Follower): Commit index set to 1 01:11:53,337 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SyncStatusTracker - node1: Lagging 0 entries behind leader node2 and reached 1 (of expected -1) 01:11:53,337 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - node1 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 1, context.getLastApplied(): -1, lastIndex(): 1 01:11:53,337 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - node1 (Follower): Setting last applied to 0 01:11:53,337 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - node1: Moving last applied index from -1 to 0 01:11:53,337 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - node1: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=false], ServerInfo[peerId=node2, isVoting=true]]} 01:11:53,337 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - node1 (Follower): Setting last applied to 1 01:11:53,337 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - node1: Moving last applied index from 0 to 1 01:11:53,337 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - node1: Applying state for log index 1 data VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]} 01:11:53,337 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SnapshotManager - node1: fakeSnapshot purging log to 0 for term 2 01:11:53,337 AM [node1-writer-41] [DEBUG] JournalWriteTask - node1: received 1 commands after 107.5 ms 01:11:53,338 AM [node1-writer-41] [DEBUG] EntryJournalV1 - node1: updated meta to JournalMeta[replayFrom=1, applyTo=2] 01:11:53,338 AM [node1-writer-41] [DEBUG] RaftStorageCompleter - node1: 1 completion(s) pending 01:11:53,338 AM [node1-writer-41] [DEBUG] JournalWriteTask - node1: completed 1 commands in 282.7 μs 01:11:53,338 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - node1: running 1 completion(s) 01:11:53,338 AM [node1-writer-41] [DEBUG] JournalWriteTask - node1: waiting to receive commands 01:11:53,456 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - node1: Lagging 0 entries behind leader node2 and reached 1 (of expected -1) 01:11:53,525 AM [main] [INFO] RaftActorVotingConfigSupportTest - testChangeToVotingWithNoLeaderAndOtherLeaderElected ending 01:11:53,525 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower122] 01:11:53,538 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/collector123#-802347929] 01:11:53,538 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/node1] 01:11:53,539 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EnabledRaftStorage - node1: terminating thread VirtualThread[#278,node1-writer-41]/waiting 01:11:53,539 AM [node1-writer-41] [DEBUG] JournalWriteTask - node1: received 1 commands after 201.0 ms 01:11:53,539 AM [node1-writer-41] [DEBUG] JournalWriteTask - node1: completed 1 commands in 25.42 μs 01:11:53,539 AM [node1-writer-41] [DEBUG] JournalWriteTask - node1: journal writer stopped 01:11:53,540 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - node1: journal closed 01:11:53,540 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - node1: journal closed 01:11:53,540 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node1: stopped executor with 0 remaining tasks 01:11:53,540 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node1: stopped executor with 0 remaining tasks 01:11:53,540 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/collector124#-14523844] 01:11:53,541 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/node2] 01:11:53,541 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EnabledRaftStorage - node2: terminating thread VirtualThread[#279,node2-writer-42]/waiting 01:11:53,541 AM [node2-writer-42] [DEBUG] JournalWriteTask - node2: received 1 commands after 310.1 ms 01:11:53,542 AM [node2-writer-42] [DEBUG] JournalWriteTask - node2: completed 1 commands in 21.10 μs 01:11:53,542 AM [node2-writer-42] [DEBUG] JournalWriteTask - node2: journal writer stopped 01:11:53,543 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - node2: journal closed 01:11:53,543 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - node2: journal closed 01:11:53,543 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node2: stopped executor with 0 remaining tasks 01:11:53,543 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node2: stopped executor with 0 remaining tasks 01:11:53,548 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithInstallSnapshotTimeout starting 01:11:53,550 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupportTest$MockNewFollowerRaftActor - Actor created TestActor[pekko://test/user/new-server127] [WARN] [02/28/2026 01:11:53.550] [test-pekko.actor.default-dispatcher-13] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/new-server127]: org.opendaylight.controller.cluster.common.actor.Monitor@39f0f147 01:11:53,551 AM [test-pekko.actor.default-dispatcher-15] [INFO] RaftActor - new-server: Starting recovery with journal batch size 1000 01:11:53,552 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - new-server: started executor 01:11:53,552 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - new-server: started executor 01:11:53,553 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - new-server: metadata journal open: replayFrom=1 applyTo=0 01:11:53,553 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - new-server: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:53,553 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - new-server: journal open: applyTo=0 01:11:53,553 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - new-server: recovering to non-persistent 01:11:53,553 AM [new-server-writer-43] [DEBUG] JournalWriteTask - new-server: journal writer started 01:11:53,553 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - /tmp/junit-7426973176912236376/new-server/TermInfo.properties does not exist 01:11:53,553 AM [new-server-writer-43] [DEBUG] JournalWriteTask - new-server: waiting to receive commands 01:11:53,556 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=0, votedFor=null 01:11:53,556 AM [test-pekko.actor.default-dispatcher-15] [INFO] Recovery - new-server: Local TermInfo store seeded with TermInfo{term=0} 01:11:53,556 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-7426973176912236376/new-server/TermInfo.properties 01:11:53,556 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-7426973176912236376/new-server/journal-v1-1.log 01:11:53,556 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-7426973176912236376/new-server/metadata-v1-1.log 01:11:53,557 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - new-server: no eligible files found 01:11:53,557 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - new-server: Moving last applied index from -1 to -1 01:11:53,557 AM [test-pekko.actor.default-dispatcher-15] [INFO] Recovery - new-server: Recovery completed in in 3.257 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:53,557 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - new-server: Recovery completed and can restore from snapshot 01:11:53,559 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorVotingConfigSupportTest$MockLeaderRaftActor - Actor created TestActor[pekko://test/user/leader128] [WARN] [02/28/2026 01:11:53.559] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader128]: org.opendaylight.controller.cluster.common.actor.Monitor@51a244de 01:11:53,560 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:53,560 AM [test-pekko.actor.default-dispatcher-13] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:53,560 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: started executor 01:11:53,560 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: started executor 01:11:53,561 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:53,562 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:53,562 AM [test-pekko.actor.default-dispatcher-13] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:53,562 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:53,562 AM [leader-writer-44] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:53,562 AM [leader-writer-44] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:53,562 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - /tmp/junit-7426973176912236376/leader/TermInfo.properties does not exist 01:11:53,566 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:53,566 AM [test-pekko.actor.default-dispatcher-13] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=1, votedFor=} 01:11:53,567 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-7426973176912236376/leader/TermInfo.properties 01:11:53,567 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-7426973176912236376/leader/journal-v1-1.log 01:11:53,567 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-7426973176912236376/leader/metadata-v1-1.log 01:11:53,567 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: no eligible files found 01:11:53,567 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:53,567 AM [test-pekko.actor.default-dispatcher-13] [INFO] Recovery - leader: Recovery completed in in 4.978 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:53,567 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:53,567 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): Election: Leader has following peers: [] 01:11:53,579 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorVotingConfigSupport - onUnInitializedFollowerSnapshotReply was called in state Idle 01:11:53,579 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorVotingConfigSupport - leader: onAddServer: AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server127, votingMember=true], state: Idle 01:11:53,579 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server127, votingMember=true] 01:11:53,579 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractReplicatedLog - leader: Capturing Snapshot : lastLogEntry is null. Using snapshot values lastAppliedIndex -1 and lastAppliedTerm -1 instead. 01:11:53,579 AM [test-pekko.actor.default-dispatcher-13] [INFO] SnapshotManager - leader: 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 new-server 01:11:53,579 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SnapshotManager - leader: last applied journal index prior to capture: 0 01:11:53,579 AM [test-pekko.actor.default-dispatcher-13] [INFO] MockRaftActor - leader: support() called 01:11:53,579 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating capture snapshot for new server new-server 01:11:53,580 AM [leader-%d804078] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:53,580 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:53,580 AM [test-pekko.actor.default-dispatcher-13] [INFO] SnapshotManager - leader: Persising snapshot at EntryInfo[index=-1, term=-1]/EntryInfo[index=-1, term=-1] 01:11:53,580 AM [test-pekko.actor.default-dispatcher-13] [INFO] MockRaftActor - leader: support() called 01:11:53,580 AM [test-pekko.actor.default-dispatcher-13] [INFO] SnapshotManager - leader: Removed in-memory snapshotted entries, adjusted snapshotIndex: -1 and term: -1 01:11:53,580 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): sendInstallSnapshot 01:11:53,580 AM [leader-%d804079] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-7426973176912236376/leader/snapshot-0000000069A240D9-229BB825.tmp 01:11:53,580 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] LeaderInstallSnapshotState - leader (Leader): Snapshot 157 bytes, total chunks to send: 1 01:11:53,580 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] LeaderInstallSnapshotState - leader (Leader): Next chunk: total length=157, offset=0, size=157, hashCode=1546036366 01:11:53,580 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): next snapshot chunk size for follower new-server: 157 01:11:53,581 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): InstallSnapshot sent to follower Vector(user, new-server127), Chunk: 1/1 01:11:53,583 AM [leader-%d804079] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-7426973176912236376/leader/snapshot-0000000069A240D9-229BB825.v1 01:11:53,583 AM [leader-%d804079] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-7426973176912236376/leader/snapshot-0000000069A240D9-229BB825.v1 01:11:53,583 AM [leader-%d804079] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-7426973176912236376/leader/TermInfo.properties 01:11:53,583 AM [leader-%d804079] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-7426973176912236376/leader/journal-v1-1.log 01:11:53,583 AM [leader-%d804079] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-7426973176912236376/leader/metadata-v1-1.log 01:11:53,583 AM [leader-%d804079] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:53.580630565Z, file=/tmp/junit-7426973176912236376/leader/snapshot-0000000069A240D9-229BB825.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:53,583 AM [leader-%d804079] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:53,583 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:53,583 AM [test-pekko.actor.default-dispatcher-15] [INFO] SnapshotManager - leader: snapshot is durable as of 2026-02-28T01:11:53.580630565Z 01:11:53,584 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SnapshotManager - leader: Snapshot success, discarding journal entries up to 0 01:11:53,584 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorSnapshotMessageSupport - leader: SnapshotComplete received 01:11:53,697 AM [test-pekko.actor.default-dispatcher-13] [INFO] Follower - new-server (Follower): Term 1 in "AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 0 - updating term 01:11:53,703 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=1, votedFor=null 01:11:53,703 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SyncStatusTracker - new-server: Last sync leader does not match current leader leader, need to catch up to -1 [WARN] [02/28/2026 01:11:53.703] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/new-server127] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=new-server, initialSyncDone=false] 01:11:53,703 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for new-server updated: matchIndex: -1, nextIndex: 0 01:11:53,795 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: handleInstallSnapshotTimeout for new server new-server 01:11:53,796 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Returning TIMEOUT for operation AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server127, votingMember=true] 01:11:53,796 AM [test-pekko.actor.default-dispatcher-5] [WARN] RaftActorVotingConfigSupport - leader: Timeout occured for new server new-server while installing snapshot 01:11:53,797 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithInstallSnapshotTimeout ending 01:11:53,797 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower125] 01:11:53,809 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/new-serverCollector126#74399284] 01:11:53,809 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/new-server127] 01:11:53,809 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EnabledRaftStorage - new-server: terminating thread VirtualThread[#282,new-server-writer-43]/waiting 01:11:53,810 AM [new-server-writer-43] [DEBUG] JournalWriteTask - new-server: received 1 commands after 256.4 ms 01:11:53,810 AM [new-server-writer-43] [DEBUG] JournalWriteTask - new-server: completed 1 commands in 39.62 μs 01:11:53,810 AM [new-server-writer-43] [DEBUG] JournalWriteTask - new-server: journal writer stopped 01:11:53,811 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - new-server: journal closed 01:11:53,811 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - new-server: journal closed 01:11:53,811 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:53,811 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:53,811 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader128] 01:11:53,811 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#283,leader-writer-44]/waiting 01:11:53,811 AM [leader-writer-44] [DEBUG] JournalWriteTask - leader: received 1 commands after 249.7 ms 01:11:53,812 AM [leader-writer-44] [DEBUG] JournalWriteTask - leader: completed 1 commands in 19.65 μs 01:11:53,812 AM [leader-writer-44] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:53,812 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:53,812 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - leader: journal closed 01:11:53,812 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:53,812 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:53,817 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithNoExistingFollower starting 01:11:53,819 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupportTest$MockNewFollowerRaftActor - Actor created TestActor[pekko://test/user/new-server131] [WARN] [02/28/2026 01:11:53.820] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/new-server131]: org.opendaylight.controller.cluster.common.actor.Monitor@6f0f8765 01:11:53,821 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActor - new-server: Starting recovery with journal batch size 1000 01:11:53,821 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: started executor 01:11:53,821 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: started executor 01:11:53,822 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - new-server: metadata journal open: replayFrom=1 applyTo=0 01:11:53,823 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - new-server: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:53,823 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - new-server: journal open: applyTo=0 01:11:53,823 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - new-server: recovering to non-persistent 01:11:53,823 AM [new-server-writer-45] [DEBUG] JournalWriteTask - new-server: journal writer started 01:11:53,823 AM [new-server-writer-45] [DEBUG] JournalWriteTask - new-server: waiting to receive commands 01:11:53,824 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - /tmp/junit-11929070120360375623/new-server/TermInfo.properties does not exist 01:11:53,828 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=0, votedFor=null 01:11:53,828 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - new-server: Local TermInfo store seeded with TermInfo{term=0} 01:11:53,829 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-11929070120360375623/new-server/TermInfo.properties 01:11:53,829 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-11929070120360375623/new-server/journal-v1-1.log 01:11:53,829 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-11929070120360375623/new-server/metadata-v1-1.log 01:11:53,829 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: no eligible files found 01:11:53,829 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - new-server: Moving last applied index from -1 to -1 01:11:53,829 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - new-server: Recovery completed in in 5.230 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:53,829 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - new-server: Recovery completed and can restore from snapshot 01:11:53,830 AM [main] [DEBUG] AbstractReplicatedLog - : Moving last applied index from -1 to 1 01:11:53,830 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupportTest$MockLeaderRaftActor - Actor created TestActor[pekko://test/user/leader132] [WARN] [02/28/2026 01:11:53.830] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader132]: org.opendaylight.controller.cluster.common.actor.Monitor@3498e32a 01:11:53,831 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:53,831 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:53,831 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: started executor 01:11:53,831 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: started executor 01:11:53,832 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:53,832 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:53,832 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:53,832 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:53,832 AM [leader-writer-46] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:53,832 AM [leader-writer-46] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:53,832 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - /tmp/junit-11929070120360375623/leader/TermInfo.properties does not exist 01:11:53,834 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:53,834 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=1, votedFor=} 01:11:53,834 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-11929070120360375623/leader/TermInfo.properties 01:11:53,834 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-11929070120360375623/leader/journal-v1-1.log 01:11:53,835 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-11929070120360375623/leader/metadata-v1-1.log 01:11:53,835 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: no eligible files found 01:11:53,835 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:53,835 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - leader: Recovery completed in in 2.473 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:53,835 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:53,835 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Election: Leader has following peers: [] 01:11:53,837 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: onAddServer: AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server131, votingMember=true], state: Idle 01:11:53,837 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server131, votingMember=true] 01:11:53,838 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - leader: 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 new-server 01:11:53,838 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - leader: last applied journal index prior to capture: 2 01:11:53,838 AM [test-pekko.actor.default-dispatcher-5] [INFO] MockRaftActor - leader: support() called 01:11:53,838 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating capture snapshot for new server new-server 01:11:53,838 AM [leader-%d964129] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:53,838 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:53,838 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - leader: Persising snapshot at EntryInfo[index=1, term=1]/EntryInfo[index=1, term=1] 01:11:53,839 AM [test-pekko.actor.default-dispatcher-5] [INFO] MockRaftActor - leader: support() called 01:11:53,839 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - leader: Removed in-memory snapshotted entries, adjusted snapshotIndex: -1 and term: -1 01:11:53,839 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): sendInstallSnapshot 01:11:53,839 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] LeaderInstallSnapshotState - leader (Leader): Snapshot 157 bytes, total chunks to send: 1 01:11:53,839 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] LeaderInstallSnapshotState - leader (Leader): Next chunk: total length=157, offset=0, size=157, hashCode=1546036366 01:11:53,839 AM [leader-%d964130] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-11929070120360375623/leader/snapshot-0000000069A240D9-32056338.tmp 01:11:53,839 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): next snapshot chunk size for follower new-server: 157 01:11:53,839 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): InstallSnapshot sent to follower Vector(user, new-server131), Chunk: 1/1 01:11:53,839 AM [test-pekko.actor.default-dispatcher-16] [INFO] Follower - new-server (Follower): Term 1 in "InstallSnapshot{term=1, leaderId=leader, lastIncludedIndex=1, lastIncludedTerm=1, datasize=157, chunk=1/1, lastChunkHashCode=OptionalInt[-1]}" message is greater than follower's term 0 - updating term 01:11:53,842 AM [leader-%d964130] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-11929070120360375623/leader/snapshot-0000000069A240D9-32056338.v1 01:11:53,842 AM [leader-%d964130] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-11929070120360375623/leader/snapshot-0000000069A240D9-32056338.v1 01:11:53,842 AM [leader-%d964130] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-11929070120360375623/leader/TermInfo.properties 01:11:53,842 AM [leader-%d964130] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-11929070120360375623/leader/journal-v1-1.log 01:11:53,842 AM [leader-%d964130] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-11929070120360375623/leader/metadata-v1-1.log 01:11:53,842 AM [leader-%d964130] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:53.839213880Z, file=/tmp/junit-11929070120360375623/leader/snapshot-0000000069A240D9-32056338.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:53,842 AM [leader-%d964130] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:53,842 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:53,842 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - leader: snapshot is durable as of 2026-02-28T01:11:53.839213880Z 01:11:53,842 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - leader: Snapshot success, discarding journal entries up to 2 01:11:53,842 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorSnapshotMessageSupport - leader: SnapshotComplete received 01:11:53,843 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=1, votedFor=null 01:11:53,843 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - new-server (Follower): handleInstallSnapshot: InstallSnapshot{term=1, leaderId=leader, lastIncludedIndex=1, lastIncludedTerm=1, datasize=157, chunk=1/1, lastChunkHashCode=OptionalInt[-1]} 01:11:53,843 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - new-server: Last sync leader does not match current leader leader, need to catch up to 1 01:11:53,843 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotTracker - new-server (Follower): addChunk: chunkIndex=1, lastChunkIndex=0, collectedChunks.size=0, lastChunkHashCode=-1 01:11:53,843 AM [test-pekko.actor.default-dispatcher-16] [INFO] Follower - new-server (Follower): Snapshot received from leader: leader 01:11:53,843 AM [test-pekko.actor.default-dispatcher-16] [INFO] SnapshotManager - new-server: Applying snapshot on follower: PlainSnapshotSource{io=MemoryStreamSource{size=157}} 01:11:53,843 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - new-server: support() called [WARN] [02/28/2026 01:11:53.843] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/new-server131] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=new-server, initialSyncDone=false] 01:11:53,844 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - new-server: Converted InstallSnapshot from leader: leader to state 01:11:53,844 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - new-server: last applied journal index prior to persisting applied snapshot: 0 01:11:53,844 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - new-server: support() called 01:11:53,844 AM [new-server-%d804629] [DEBUG] RaftStorage - new-server: starting snapshot writeout to /tmp/junit-11929070120360375623/new-server/snapshot-0000000069A240D9-3256D4CA.tmp 01:11:53,846 AM [new-server-%d804629] [DEBUG] RaftStorage - new-server: finished snapshot writeout to /tmp/junit-11929070120360375623/new-server/snapshot-0000000069A240D9-3256D4CA.v1 01:11:53,846 AM [new-server-%d804629] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-11929070120360375623/new-server/snapshot-0000000069A240D9-3256D4CA.v1 01:11:53,846 AM [new-server-%d804629] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-11929070120360375623/new-server/TermInfo.properties 01:11:53,846 AM [new-server-%d804629] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-11929070120360375623/new-server/journal-v1-1.log 01:11:53,846 AM [new-server-%d804629] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-11929070120360375623/new-server/metadata-v1-1.log 01:11:53,846 AM [new-server-%d804629] [DEBUG] RaftStorage - new-server: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:53.844551370Z, file=/tmp/junit-11929070120360375623/new-server/snapshot-0000000069A240D9-3256D4CA.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:53,847 AM [new-server-%d804629] [DEBUG] RaftStorageCompleter - new-server: 1 completion(s) pending 01:11:53,847 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorageCompleter - new-server: running 1 completion(s) 01:11:53,847 AM [test-pekko.actor.default-dispatcher-15] [INFO] SnapshotManager - new-server: snapshot is durable as of 2026-02-28T01:11:53.844551370Z 01:11:53,847 AM [test-pekko.actor.default-dispatcher-15] [INFO] MockRaftActor - new-server: support() called 01:11:53,847 AM [test-pekko.actor.default-dispatcher-15] [INFO] MockRaftActor - new-server: applySnapshot called 01:11:53,847 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - new-server (Follower): handleInstallSnapshot returning: InstallSnapshotReply{term=1, followerId=new-server, chunkIndex=1, success=true} 01:11:53,847 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SnapshotManager - new-server: Snapshot success, discarding journal entries up to 0 01:11:53,847 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorSnapshotMessageSupport - new-server: SnapshotComplete received 01:11:53,847 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): handleInstallSnapshotReply: InstallSnapshotReply{term=1, followerId=new-server, chunkIndex=1, success=true} 01:11:53,847 AM [test-pekko.actor.default-dispatcher-16] [INFO] AbstractLeader - leader (Leader): Snapshot successfully installed on follower new-server (last chunk 1) - matchIndex set to 1, nextIndex set to 2 01:11:53,847 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - Sent message UnInitializedFollowerSnapshotReply to self 01:11:53,847 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - leader: fakeSnapshot purging log to 0 for term 1 01:11:53,847 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: onUnInitializedFollowerSnapshotReply: UnInitializedFollowerSnapshotReply [followerId=new-server] 01:11:53,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: New server configuration : [ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]] 01:11:53,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader: Persist data index=2 term=1 command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:53,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - leader: Append log entry and persist JournaledLogEntry{index=2, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:53,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Replicate message: identifier: ServerOperationContextIdentifier{value=149bbd99-19a9-4b01-8b37-efc6ef289056}, logIndex: 2, isSendImmediate: true 01:11:53,848 AM [leader-%d964131] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-11929070120360375623/leader/snapshot-0000000069A240D9-3290E88B.tmp 01:11:53,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server: active: true, followerNextIndex: 2, leaderLastIndex: 2, leaderSnapShotIndex: 0 01:11:53,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 2 is present for follower new-server 01:11:53,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower new-server: AppendEntries{term=1, leaderId=leader, prevLogIndex=1, prevLogTerm=1, leaderCommit=1, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[JournaledLogEntry{index=2, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:53,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: Returning OK for operation AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server131, votingMember=true] 01:11:53,848 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - new-server (Follower): handleAppendEntries: AppendEntries{term=1, leaderId=leader, prevLogIndex=1, prevLogTerm=1, leaderCommit=1, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[JournaledLogEntry{index=2, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:53,848 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - new-server (Follower): Number of entries to be appended = 1 01:11:53,848 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - new-server (Follower): After cleanup, lastIndex: 1, entries to be added from: 0 01:11:53,848 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - new-server (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:53,849 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - new-server: Append log entry and persist JournaledLogEntry{index=2, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:53,849 AM [new-server-%d804630] [DEBUG] RaftStorage - new-server: starting snapshot writeout to /tmp/junit-11929070120360375623/new-server/snapshot-0000000069A240D9-329C52DC.tmp 01:11:53,849 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PeerInfos - new-server: Updated server config: isVoting: true, peers: [PeerInfo [id=leader, address=null, votingState=VOTING]] 01:11:53,849 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - new-server (Follower): Log size is now 1 01:11:53,849 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - new-server (Follower): handleAppendEntries returning : AppendEntriesReply{term=1, success=true, followerId=new-server, logLastIndex=2, logLastTerm=1, forceInstallSnapshot=false, needsLeaderAddress=true, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:53,849 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - new-server: Lagging 0 entries behind leader leader and reached 1 (of expected 1) 01:11:53,849 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for new-server updated: matchIndex: 2, nextIndex: 3 01:11:53,849 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - new-server: awaiting more completions to resolve 1 synchronized callback(s) 01:11:53,849 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server: active: true, followerNextIndex: 3, leaderLastIndex: 2, leaderSnapShotIndex: 0 01:11:53,850 AM [leader-%d964131] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-11929070120360375623/leader/snapshot-0000000069A240D9-3290E88B.v1 01:11:53,850 AM [leader-%d964131] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-11929070120360375623/leader/snapshot-0000000069A240D9-3290E88B.v1 01:11:53,850 AM [leader-%d964131] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-11929070120360375623/leader/snapshot-0000000069A240D9-32056338.v1 01:11:53,851 AM [leader-%d964131] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-11929070120360375623/leader/TermInfo.properties 01:11:53,851 AM [leader-%d964131] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-11929070120360375623/leader/journal-v1-1.log 01:11:53,851 AM [leader-%d964131] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-11929070120360375623/leader/metadata-v1-1.log 01:11:53,851 AM [leader-%d964131] [DEBUG] RaftStorage - leader: deleted snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:53.839213880Z, file=/tmp/junit-11929070120360375623/leader/snapshot-0000000069A240D9-32056338.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:53,851 AM [leader-%d964131] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:53.848357515Z, file=/tmp/junit-11929070120360375623/leader/snapshot-0000000069A240D9-3290E88B.v1, size=86, entryCompress=NONE, stateCompress=NONE} 01:11:53,851 AM [leader-%d964131] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:53,851 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:53,851 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - leader: persist complete JournaledLogEntry{index=2, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:53,851 AM [new-server-%d804630] [DEBUG] RaftStorage - new-server: finished snapshot writeout to /tmp/junit-11929070120360375623/new-server/snapshot-0000000069A240D9-329C52DC.v1 01:11:53,851 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Applying to log - commitIndex: 2, lastAppliedIndex: 1 01:11:53,851 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - leader (Leader): Setting last applied to 2 01:11:53,851 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from 1 to 2 01:11:53,851 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader: Applying state for log index 2 data VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:53,851 AM [new-server-%d804630] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-11929070120360375623/new-server/snapshot-0000000069A240D9-3256D4CA.v1 01:11:53,851 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - leader: fakeSnapshot purging log to 1 for term 1 01:11:53,851 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActorVotingConfigSupport - leader: VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} has been successfully replicated to a majority of followers 01:11:53,851 AM [new-server-%d804630] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-11929070120360375623/new-server/snapshot-0000000069A240D9-329C52DC.v1 01:11:53,851 AM [new-server-%d804630] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-11929070120360375623/new-server/TermInfo.properties 01:11:53,851 AM [new-server-%d804630] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-11929070120360375623/new-server/journal-v1-1.log 01:11:53,851 AM [new-server-%d804630] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-11929070120360375623/new-server/metadata-v1-1.log 01:11:53,852 AM [new-server-%d804630] [DEBUG] RaftStorage - new-server: deleted snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:53.844551370Z, file=/tmp/junit-11929070120360375623/new-server/snapshot-0000000069A240D9-3256D4CA.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:53,852 AM [new-server-%d804630] [DEBUG] RaftStorage - new-server: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:53.849105628Z, file=/tmp/junit-11929070120360375623/new-server/snapshot-0000000069A240D9-329C52DC.v1, size=86, entryCompress=NONE, stateCompress=NONE} 01:11:53,852 AM [new-server-%d804630] [DEBUG] RaftStorageCompleter - new-server: 1 completion(s) pending 01:11:53,852 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - new-server: running 1 completion(s) 01:11:53,852 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - new-server: persist complete JournaledLogEntry{index=2, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false} 01:11:53,852 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - new-server: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=2, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@4964e1c1} 01:11:53,852 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - new-server: synchronized callbacks after 3.576 ms [WARN] [02/28/2026 01:11:53.853] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/new-server131] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=new-server, initialSyncDone=true] 01:11:53,956 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - new-server (Follower): Commit index set to 2 01:11:53,957 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SyncStatusTracker - new-server: Lagging 0 entries behind leader leader and reached 2 (of expected 1) 01:11:53,957 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - new-server (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 2, context.getLastApplied(): 1, lastIndex(): 2 01:11:53,957 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - new-server (Follower): Setting last applied to 2 01:11:53,957 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - new-server: Moving last applied index from 1 to 2 01:11:53,957 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - new-server: Applying state for log index 2 data VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:53,990 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithNoExistingFollower ending 01:11:53,990 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower129] 01:11:53,992 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/new-serverCollector130#1970795851] 01:11:53,993 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/new-server131] 01:11:53,993 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EnabledRaftStorage - new-server: terminating thread VirtualThread[#286,new-server-writer-45]/waiting 01:11:53,993 AM [new-server-writer-45] [DEBUG] JournalWriteTask - new-server: received 1 commands after 169.6 ms 01:11:53,993 AM [new-server-writer-45] [DEBUG] JournalWriteTask - new-server: completed 1 commands in 34.73 μs 01:11:53,993 AM [new-server-writer-45] [DEBUG] JournalWriteTask - new-server: journal writer stopped 01:11:53,994 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - new-server: journal closed 01:11:53,994 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - new-server: journal closed 01:11:53,994 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:53,994 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:53,994 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader132] 01:11:53,994 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#287,leader-writer-46]/waiting 01:11:53,994 AM [leader-writer-46] [DEBUG] JournalWriteTask - leader: received 1 commands after 162.3 ms 01:11:53,994 AM [leader-writer-46] [DEBUG] JournalWriteTask - leader: completed 1 commands in 12.83 μs 01:11:53,994 AM [leader-writer-46] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:53,995 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:53,995 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - leader: journal closed 01:11:53,995 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:53,995 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:53,995 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leaderCollector133] 01:11:54,1 AM [main] [INFO] RaftActorVotingConfigSupportTest - testChangeToVotingWithNoLeaderAndForwardedToOtherNodeAfterElectionTimeout starting 01:11:54,4 AM [main] [DEBUG] PropertiesTermInfoStore - node1: Set currentTerm=1, votedFor=node1 01:11:54,5 AM [main] [DEBUG] EntryJournalV1 - node1: metadata journal open: replayFrom=1 applyTo=0 01:11:54,5 AM [main] [DEBUG] EntryJournalV1 - node1: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:54,9 AM [main] [DEBUG] EntryJournalV1 - node1: journal closed 01:11:54,11 AM [main] [DEBUG] PropertiesTermInfoStore - node2: Set currentTerm=1, votedFor=node1 01:11:54,11 AM [main] [DEBUG] EntryJournalV1 - node2: metadata journal open: replayFrom=1 applyTo=0 01:11:54,12 AM [main] [DEBUG] EntryJournalV1 - node2: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:54,16 AM [main] [DEBUG] EntryJournalV1 - node2: updated meta to JournalMeta[replayFrom=1, applyTo=2] 01:11:54,16 AM [main] [DEBUG] EntryJournalV1 - node2: journal closed 01:11:54,18 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupportTest$CollectingMockRaftActor - Actor created TestActor[pekko://test/user/node1] [WARN] [02/28/2026 01:11:54.018] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/node1]: org.opendaylight.controller.cluster.common.actor.Monitor@4000516 01:11:54,19 AM [test-pekko.actor.default-dispatcher-15] [INFO] RaftActor - node1: Starting recovery with journal batch size 1000 01:11:54,19 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node1: started executor 01:11:54,19 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node1: started executor 01:11:54,20 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - node1: metadata journal open: replayFrom=1 applyTo=0 01:11:54,21 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - node1: journal open: firstIndex=1 lastIndex=1 replayFrom=1 fileEntries=0 01:11:54,21 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - node1: journal open: applyTo=0 01:11:54,21 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - node1: starting journal recovery 01:11:54,21 AM [node1-writer-47] [DEBUG] JournalWriteTask - node1: journal writer started 01:11:54,21 AM [node1-writer-47] [DEBUG] JournalWriteTask - node1: waiting to receive commands 01:11:54,21 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - node1: Set currentTerm=1, votedFor=node1 01:11:54,22 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node1: skipping unrecognized file /tmp/junit-13181156292387079995/node1/TermInfo.properties 01:11:54,22 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node1: skipping unrecognized file /tmp/junit-13181156292387079995/node1/journal-v1-1.log 01:11:54,22 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node1: skipping unrecognized file /tmp/junit-13181156292387079995/node1/metadata-v1-1.log 01:11:54,22 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node1: no eligible files found 01:11:54,22 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - node1: Moving last applied index from -1 to -1 01:11:54,22 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] JournalRecovery - node1: applying entries up to 0 01:11:54,22 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] JournalRecovery - node1: recovered journal DefaultLogEntry[index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=false], ServerInfo[peerId=node2, isVoting=false]]}] 01:11:54,23 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PeerInfos - node1: Updated server config: isVoting: false, peers: [PeerInfo [id=node2, address=null, votingState=NON_VOTING]] 01:11:54,23 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - node1: Moving last applied index from -1 to -1 01:11:54,23 AM [test-pekko.actor.default-dispatcher-15] [INFO] Recovery - node1: Recovery completed in in 1.517 ms: last log index = 0, last log term = 1, napshot index = -1, snapshot term = -1, journal size = 1 01:11:54,23 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - node1: Recovery completed and cannot restore from snapshot 01:11:54,28 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupportTest$CollectingMockRaftActor - Actor created TestActor[pekko://test/user/node2] [WARN] [02/28/2026 01:11:54.029] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/node2]: org.opendaylight.controller.cluster.common.actor.Monitor@1c10df0f 01:11:54,29 AM [test-pekko.actor.default-dispatcher-15] [INFO] RaftActor - node2: Starting recovery with journal batch size 1000 01:11:54,29 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node2: started executor 01:11:54,29 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node2: started executor 01:11:54,30 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - node2: metadata journal open: replayFrom=1 applyTo=2 01:11:54,30 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - node2: journal open: firstIndex=1 lastIndex=2 replayFrom=1 fileEntries=0 01:11:54,30 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - node2: journal open: applyTo=2 01:11:54,30 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - node2: starting journal recovery 01:11:54,30 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - node2: Set currentTerm=1, votedFor=node1 01:11:54,30 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node2: skipping unrecognized file /tmp/junit-13181156292387079995/node2/TermInfo.properties 01:11:54,30 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node2: skipping unrecognized file /tmp/junit-13181156292387079995/node2/journal-v1-1.log 01:11:54,30 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node2: skipping unrecognized file /tmp/junit-13181156292387079995/node2/metadata-v1-1.log 01:11:54,30 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - node2: no eligible files found 01:11:54,30 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - node2: Moving last applied index from -1 to -1 01:11:54,30 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] JournalRecovery - node2: applying entries up to 2 01:11:54,31 AM [node2-writer-48] [DEBUG] JournalWriteTask - node2: journal writer started 01:11:54,31 AM [node2-writer-48] [DEBUG] JournalWriteTask - node2: waiting to receive commands 01:11:54,31 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] JournalRecovery - node2: recovered journal DefaultLogEntry[index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=false], ServerInfo[peerId=node2, isVoting=false]]}] 01:11:54,31 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PeerInfos - node2: Updated server config: isVoting: false, peers: [PeerInfo [id=node1, address=null, votingState=NON_VOTING]] 01:11:54,31 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] JournalRecovery - node2: recovered journal DefaultLogEntry[index=1, term=1, command=2] 01:11:54,31 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - node2: Moving last applied index from -1 to 1 01:11:54,31 AM [test-pekko.actor.default-dispatcher-15] [INFO] Recovery - node2: Recovery completed in in 922.3 μs: last log index = 1, last log term = 1, napshot index = -1, snapshot term = -1, journal size = 2 01:11:54,31 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - node2: Recovery completed and cannot restore from snapshot 01:11:54,32 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupport - node1: onChangeServersVotingStatus: ChangeServersVotingStatus [serverVotingStatusMap={node1=true, node2=true}, serversVisited=[]], state: Idle 01:11:54,33 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupport - Initiating ChangeServersVotingStatusState 01:11:54,33 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupport - node1: Sending local ElectionTimeout to start leader election 01:11:54,33 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PeerInfos - node1: Updated server config: isVoting: true, peers: [PeerInfo [id=node2, address=null, votingState=VOTING]] 01:11:54,33 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - node1 (Follower): Received TimeoutNow - switching to Candidate 01:11:54,33 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Candidate - node1 (Candidate): Election: Candidate has following voting peers: [node2] 01:11:54,43 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - node1: Set currentTerm=2, votedFor=node1 01:11:54,43 AM [test-pekko.actor.default-dispatcher-15] [INFO] Candidate - node1 (Candidate): Starting new election term 2 01:11:54,43 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Candidate - node1 (Candidate): Sending RequestVote{term=2, candidateId=node1, lastLogIndex=0, lastLogTerm=1} to peer node2 01:11:54,43 AM [test-pekko.actor.default-dispatcher-15] [INFO] RaftActorBehavior - node1 (Follower) :- Switching from behavior Follower to Candidate, election term: 2 01:11:54,43 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - node2 (Follower): Found higher term in RequestVote rpc, verifying whether it's safe to update term. 01:11:54,44 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - node2 (Follower): Cluster state: [] 01:11:54,44 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - node2 (Follower): Candidate in requestVote:RequestVote{term=2, candidateId=node1, lastLogIndex=0, lastLogTerm=1} with higher term appears reachable, updating term. 01:11:54,44 AM [test-pekko.actor.default-dispatcher-15] [INFO] Follower - node2 (Follower): Term 2 in "RequestVote{term=2, candidateId=node1, lastLogIndex=0, lastLogTerm=1}" message is greater than follower's term 1 - updating term 01:11:54,46 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - node2: Set currentTerm=2, votedFor=null 01:11:54,46 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - node2 (Follower): In requestVote: RequestVote{term=2, candidateId=node1, lastLogIndex=0, lastLogTerm=1} - currentTerm: 2, votedFor: null, lastIndex: 1, lastTerm: 1 01:11:54,46 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - node2 (Follower): requestVote returning: RequestVoteReply{term=2, voteGranted=false} 01:11:54,46 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Candidate - node1 (Candidate): RaftRPC message received RequestVoteReply{term=2, voteGranted=false}, my term is 2 01:11:54,46 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Candidate - node1 (Candidate): handleRequestVoteReply: RequestVoteReply{term=2, voteGranted=false}, current voteCount: 1 01:11:54,346 AM [test-pekko.actor.default-dispatcher-5] [WARN] RaftActorVotingConfigSupport - node1: Leader election timed out - cannot apply operation ChangeServersVotingStatus [serverVotingStatusMap={node1=true, node2=true}, serversVisited=[]] 01:11:54,346 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PeerInfos - node1: Updated server config: isVoting: false, peers: [PeerInfo [id=node2, address=pekko://test/user/node2, votingState=NON_VOTING]] 01:11:54,347 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - node1: tryToForwardOperationToAnotherServer - servers already visited [] 01:11:54,347 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - node1: Found server ActorSelection[Anchor(pekko://test/), Path(/user/node2)] to forward to 01:11:54,348 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - node2: onChangeServersVotingStatus: ChangeServersVotingStatus [serverVotingStatusMap={node1=true, node2=true}, serversVisited=[node1]], state: Idle 01:11:54,348 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - Initiating ChangeServersVotingStatusState 01:11:54,348 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - node2: Sending local ElectionTimeout to start leader election 01:11:54,348 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PeerInfos - node2: Updated server config: isVoting: true, peers: [PeerInfo [id=node1, address=null, votingState=VOTING]] 01:11:54,348 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - node2 (Follower): Received TimeoutNow - switching to Candidate 01:11:54,348 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Candidate - node2 (Candidate): Election: Candidate has following voting peers: [node1] 01:11:54,352 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - node2: Set currentTerm=3, votedFor=node2 01:11:54,352 AM [test-pekko.actor.default-dispatcher-5] [INFO] Candidate - node2 (Candidate): Starting new election term 3 01:11:54,352 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Candidate - node2 (Candidate): Sending RequestVote{term=3, candidateId=node2, lastLogIndex=1, lastLogTerm=1} to peer node1 01:11:54,352 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActorBehavior - node2 (Follower) :- Switching from behavior Follower to Candidate, election term: 3 01:11:54,352 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - node1 (Follower): Found higher term in RequestVote rpc, verifying whether it's safe to update term. 01:11:54,353 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - node1 (Follower): Cluster state: [] 01:11:54,353 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - node1 (Follower): Candidate in requestVote:RequestVote{term=3, candidateId=node2, lastLogIndex=1, lastLogTerm=1} with higher term appears reachable, updating term. 01:11:54,353 AM [test-pekko.actor.default-dispatcher-15] [INFO] Follower - node1 (Follower): Term 3 in "RequestVote{term=3, candidateId=node2, lastLogIndex=1, lastLogTerm=1}" message is greater than follower's term 2 - updating term 01:11:54,356 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - node1: Set currentTerm=3, votedFor=null 01:11:54,356 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - node1 (Follower): In requestVote: RequestVote{term=3, candidateId=node2, lastLogIndex=1, lastLogTerm=1} - currentTerm: 3, votedFor: null, lastIndex: 0, lastTerm: 1 01:11:54,358 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - node1: Set currentTerm=3, votedFor=node2 01:11:54,358 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - node1 (Follower): requestVote returning: RequestVoteReply{term=3, voteGranted=true} 01:11:54,359 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Candidate - node2 (Candidate): RaftRPC message received RequestVoteReply{term=3, voteGranted=true}, my term is 3 01:11:54,359 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Candidate - node2 (Candidate): handleRequestVoteReply: RequestVoteReply{term=3, voteGranted=true}, current voteCount: 1 01:11:54,359 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - node2 (Leader): Election: Leader has following peers: [node1] 01:11:54,359 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - node2 (Leader): Checking sendAppendEntries for follower node1: active: false, followerNextIndex: 1, leaderLastIndex: 1, leaderSnapShotIndex: -1 01:11:54,359 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - node1: Last sync leader does not match current leader node2, need to catch up to -1 [WARN] [02/28/2026 01:11:54.359] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/node1] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=node1, initialSyncDone=false] 01:11:54,360 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActorBehavior - node2 (Candidate) :- Switching from behavior Candidate to Leader, election term: 3 01:11:54,360 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - node2: New leader node2 elected 01:11:54,360 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - node2: New server configuration : [ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]] 01:11:54,360 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - node2: Persist data index=2 term=3 command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]} 01:11:54,360 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - node2: Append log entry and persist JournaledLogEntry{index=2, term=3, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]}, pending=true} 01:11:54,360 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - node2 (Leader): Replicate message: identifier: ServerOperationContextIdentifier{value=30e33d37-c4ca-4adb-b0ec-bd0120b1582a}, logIndex: 2, isSendImmediate: true 01:11:54,360 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - node2 (Leader): Checking sendAppendEntries for follower node1: active: false, followerNextIndex: 1, leaderLastIndex: 2, leaderSnapShotIndex: -1 01:11:54,360 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - node1: Lagging 0 entries behind leader node2 and reached -1 (of expected -1) [WARN] [02/28/2026 01:11:54.360] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/node1] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=node1, initialSyncDone=true] 01:11:54,360 AM [node2-writer-48] [DEBUG] JournalWriteTask - node2: received 1 commands after 329.5 ms 01:11:54,360 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - node2: Returning OK for operation ChangeServersVotingStatus [serverVotingStatusMap={node1=true, node2=true}, serversVisited=[node1]] 01:11:54,361 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - node2 (Leader): handleAppendEntriesReply - FollowerLogInformation for node1 updated: matchIndex: 0, nextIndex: 1 01:11:54,361 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - node2: fakeSnapshot purging log to 0 for term 3 01:11:54,361 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - node2 (Leader): Checking sendAppendEntries for follower node1: active: true, followerNextIndex: 1, leaderLastIndex: 2, leaderSnapShotIndex: 0 01:11:54,361 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - node2 (Leader): sendAppendEntries: 1 is present for follower node1 01:11:54,361 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - node2 (Leader): Sending AppendEntries to follower node1: AppendEntries{term=3, leaderId=node2, prevLogIndex=0, prevLogTerm=1, leaderCommit=1, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=1, term=1, command=2, pending=false}, JournaledLogEntry{index=2, term=3, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]}, pending=true}]} 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - node1 (Follower): handleAppendEntries: AppendEntries{term=3, leaderId=node2, prevLogIndex=0, prevLogTerm=1, leaderCommit=1, replicatedToAllIndex=0, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=1, term=1, command=2, pending=false}, JournaledLogEntry{index=2, term=3, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]}, pending=true}]} 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - node1 (Follower): Number of entries to be appended = 2 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - node1 (Follower): After cleanup, lastIndex: 0, entries to be added from: 0 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - node1 (Follower): Append entry to log 2 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - node1: Append log entry and persist JournaledLogEntry{index=1, term=1, command=2, pending=false} 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - node1 (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]} 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - node1: Append log entry and persist JournaledLogEntry{index=2, term=3, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]}, pending=true} 01:11:54,361 AM [node1-writer-47] [DEBUG] JournalWriteTask - node1: received 1 commands after 340.1 ms 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PeerInfos - node1: Updated server config: isVoting: true, peers: [PeerInfo [id=node2, address=pekko://test/user/node2, votingState=VOTING]] 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - node1 (Follower): Log size is now 3 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - node1 (Follower): Commit index set to 1 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - node1 (Follower): handleAppendEntries returning : AppendEntriesReply{term=3, success=true, followerId=node1, logLastIndex=2, logLastTerm=3, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - node1: Lagging 0 entries behind leader node2 and reached 1 (of expected -1) 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - node1 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 1, context.getLastApplied(): -1, lastIndex(): 2 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - node1 (Follower): Setting last applied to 0 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - node1: Moving last applied index from -1 to 0 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - node1: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=false], ServerInfo[peerId=node2, isVoting=false]]} 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - node1 (Follower): Setting last applied to 1 01:11:54,361 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - node1: Moving last applied index from 0 to 1 01:11:54,362 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - node1: Applying state for log index 1 data 2 01:11:54,362 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - node1: applyState called: 2 01:11:54,362 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - node1: fakeSnapshot purging log to 0 for term 3 01:11:54,362 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - node1: awaiting more completions to resolve 2 synchronized callback(s) 01:11:54,362 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - node2 (Leader): sendAppendEntries: 1 is present for follower node1 01:11:54,362 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - node2 (Leader): handleAppendEntriesReply - FollowerLogInformation for node1 updated: matchIndex: 2, nextIndex: 3 01:11:54,362 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - node2 (Leader): Checking sendAppendEntries for follower node1: active: true, followerNextIndex: 3, leaderLastIndex: 2, leaderSnapShotIndex: 0 01:11:54,365 AM [node2-writer-48] [DEBUG] RaftStorageCompleter - node2: 1 completion(s) pending 01:11:54,365 AM [node2-writer-48] [DEBUG] JournalWriteTask - node2: completed 1 commands in 4.440 ms 01:11:54,365 AM [node2-writer-48] [DEBUG] JournalWriteTask - node2: waiting to receive commands 01:11:54,365 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - node2: running 1 completion(s) 01:11:54,365 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] ReplicatedLogImpl - node2: persist complete JournaledLogEntry{index=2, term=3, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]}, pending=true} 01:11:54,365 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - node2 (Leader): Applying to log - commitIndex: 2, lastAppliedIndex: 1 01:11:54,365 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorBehavior - node2 (Leader): Setting last applied to 2 01:11:54,365 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractReplicatedLog - node2: Moving last applied index from 1 to 2 01:11:54,365 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActor - node2: Applying state for log index 2 data VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]} 01:11:54,365 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SnapshotManager - node2: fakeSnapshot purging log to 1 for term 3 01:11:54,366 AM [node2-writer-48] [DEBUG] JournalWriteTask - node2: received 1 commands after 589.6 μs 01:11:54,366 AM [test-pekko.actor.default-dispatcher-13] [INFO] RaftActorVotingConfigSupport - node2: VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]} has been successfully replicated to a majority of followers 01:11:54,366 AM [node2-writer-48] [DEBUG] EntryJournalV1 - node2: updated meta to JournalMeta[replayFrom=1, applyTo=3] 01:11:54,366 AM [node1-writer-47] [DEBUG] RaftStorageCompleter - node1: 1 completion(s) pending 01:11:54,366 AM [node2-writer-48] [DEBUG] RaftStorageCompleter - node2: 1 completion(s) pending 01:11:54,366 AM [node2-writer-48] [DEBUG] JournalWriteTask - node2: completed 1 commands in 258.8 μs 01:11:54,366 AM [node2-writer-48] [DEBUG] JournalWriteTask - node2: waiting to receive commands 01:11:54,366 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - node2: running 1 completion(s) 01:11:54,366 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - node1: running 1 completion(s) 01:11:54,366 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - node1: persist complete JournaledLogEntry{index=1, term=1, command=2, pending=false} 01:11:54,366 AM [node1-writer-47] [DEBUG] JournalWriteTask - node1: completed 1 commands in 4.520 ms 01:11:54,366 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - node1: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=1, term=1, command=2, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@141ffd1c} 01:11:54,366 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - node1: awaiting more completions to resolve 1 synchronized callback(s) 01:11:54,366 AM [node1-writer-47] [DEBUG] JournalWriteTask - node1: received 2 commands after 11.06 μs 01:11:54,372 AM [node1-writer-47] [DEBUG] EntryJournalV1 - node1: updated meta to JournalMeta[replayFrom=1, applyTo=2] 01:11:54,372 AM [node1-writer-47] [DEBUG] RaftStorageCompleter - node1: 2 completion(s) pending 01:11:54,372 AM [node1-writer-47] [DEBUG] JournalWriteTask - node1: completed 2 commands in 5.856 ms 01:11:54,372 AM [node1-writer-47] [DEBUG] JournalWriteTask - node1: waiting to receive commands 01:11:54,372 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - node1: running 2 completion(s) 01:11:54,372 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - node1: persist complete JournaledLogEntry{index=2, term=3, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]}, pending=false} 01:11:54,372 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - node1: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=2, term=3, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@141ffd1c} 01:11:54,372 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - node1: synchronized callbacks after 10.57 ms 01:11:54,477 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - node1 (Follower): Commit index set to 2 01:11:54,477 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - node1: Lagging 0 entries behind leader node2 and reached 2 (of expected -1) 01:11:54,477 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - node1 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 2, context.getLastApplied(): 1, lastIndex(): 2 01:11:54,477 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - node1 (Follower): Setting last applied to 2 01:11:54,477 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - node1: Moving last applied index from 1 to 2 01:11:54,477 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - node1: Applying state for log index 2 data VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=true], ServerInfo[peerId=node2, isVoting=true]]} 01:11:54,477 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - node1: fakeSnapshot purging log to 1 for term 3 01:11:54,477 AM [node1-writer-47] [DEBUG] JournalWriteTask - node1: received 1 commands after 105.5 ms 01:11:54,478 AM [node1-writer-47] [DEBUG] EntryJournalV1 - node1: updated meta to JournalMeta[replayFrom=1, applyTo=3] 01:11:54,478 AM [node1-writer-47] [DEBUG] RaftStorageCompleter - node1: 1 completion(s) pending 01:11:54,478 AM [node1-writer-47] [DEBUG] JournalWriteTask - node1: completed 1 commands in 327.8 μs 01:11:54,478 AM [node1-writer-47] [DEBUG] JournalWriteTask - node1: waiting to receive commands 01:11:54,478 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - node1: running 1 completion(s) 01:11:54,565 AM [main] [INFO] RaftActorVotingConfigSupportTest - testChangeToVotingWithNoLeaderAndForwardedToOtherNodeAfterElectionTimeout ending 01:11:54,565 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower134] 01:11:54,577 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/collector135#-1549244733] 01:11:54,578 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/node1] 01:11:54,578 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EnabledRaftStorage - node1: terminating thread VirtualThread[#293,node1-writer-47]/waiting 01:11:54,578 AM [node1-writer-47] [DEBUG] JournalWriteTask - node1: received 1 commands after 100.2 ms 01:11:54,578 AM [node1-writer-47] [DEBUG] JournalWriteTask - node1: completed 1 commands in 25.10 μs 01:11:54,578 AM [node1-writer-47] [DEBUG] JournalWriteTask - node1: journal writer stopped 01:11:54,579 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EntryJournalV1 - node1: journal closed 01:11:54,579 AM [test-pekko.actor.default-dispatcher-13] [INFO] EnabledRaftStorage - node1: journal closed 01:11:54,579 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - node1: stopped executor with 0 remaining tasks 01:11:54,579 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - node1: stopped executor with 0 remaining tasks 01:11:54,579 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/collector136#-716973963] 01:11:54,579 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/node2] 01:11:54,580 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EnabledRaftStorage - node2: terminating thread VirtualThread[#294,node2-writer-48]/waiting 01:11:54,580 AM [node2-writer-48] [DEBUG] JournalWriteTask - node2: received 1 commands after 214.0 ms 01:11:54,580 AM [node2-writer-48] [DEBUG] JournalWriteTask - node2: completed 1 commands in 19.72 μs 01:11:54,580 AM [node2-writer-48] [DEBUG] JournalWriteTask - node2: journal writer stopped 01:11:54,580 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EntryJournalV1 - node2: journal closed 01:11:54,580 AM [test-pekko.actor.default-dispatcher-13] [INFO] EnabledRaftStorage - node2: journal closed 01:11:54,580 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - node2: stopped executor with 0 remaining tasks 01:11:54,580 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - node2: stopped executor with 0 remaining tasks 01:11:54,588 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithNoConsensusReached starting 01:11:54,590 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorVotingConfigSupportTest$MockNewFollowerRaftActor - Actor created TestActor[pekko://test/user/new-server139] [WARN] [02/28/2026 01:11:54.590] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/new-server139]: org.opendaylight.controller.cluster.common.actor.Monitor@5cdef8d2 01:11:54,591 AM [test-pekko.actor.default-dispatcher-13] [INFO] RaftActor - new-server: Starting recovery with journal batch size 1000 01:11:54,591 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - new-server: started executor 01:11:54,591 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - new-server: started executor 01:11:54,592 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EntryJournalV1 - new-server: metadata journal open: replayFrom=1 applyTo=0 01:11:54,592 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EntryJournalV1 - new-server: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:54,592 AM [test-pekko.actor.default-dispatcher-13] [INFO] EnabledRaftStorage - new-server: journal open: applyTo=0 01:11:54,592 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActor - new-server: recovering to non-persistent 01:11:54,593 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - /tmp/junit-18344974592258603717/new-server/TermInfo.properties does not exist 01:11:54,593 AM [new-server-writer-49] [DEBUG] JournalWriteTask - new-server: journal writer started 01:11:54,593 AM [new-server-writer-49] [DEBUG] JournalWriteTask - new-server: waiting to receive commands 01:11:54,610 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=0, votedFor=null 01:11:54,610 AM [test-pekko.actor.default-dispatcher-13] [INFO] Recovery - new-server: Local TermInfo store seeded with TermInfo{term=0} 01:11:54,610 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-18344974592258603717/new-server/TermInfo.properties 01:11:54,610 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-18344974592258603717/new-server/journal-v1-1.log 01:11:54,610 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-18344974592258603717/new-server/metadata-v1-1.log 01:11:54,610 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - new-server: no eligible files found 01:11:54,610 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractReplicatedLog - new-server: Moving last applied index from -1 to -1 01:11:54,610 AM [test-pekko.actor.default-dispatcher-13] [INFO] Recovery - new-server: Recovery completed in in 17.54 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:54,610 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActor - new-server: Recovery completed and can restore from snapshot 01:11:54,612 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorVotingConfigSupportTest$MockLeaderRaftActor - Actor created TestActor[pekko://test/user/leader140] [WARN] [02/28/2026 01:11:54.612] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader140]: org.opendaylight.controller.cluster.common.actor.Monitor@c89c273 01:11:54,613 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:54,613 AM [test-pekko.actor.default-dispatcher-13] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:54,613 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: started executor 01:11:54,613 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: started executor 01:11:54,614 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:54,614 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:54,614 AM [test-pekko.actor.default-dispatcher-13] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:54,615 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:54,615 AM [leader-writer-50] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:54,615 AM [leader-writer-50] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:54,615 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - /tmp/junit-18344974592258603717/leader/TermInfo.properties does not exist 01:11:54,619 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:54,619 AM [test-pekko.actor.default-dispatcher-13] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=1, votedFor=} 01:11:54,619 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-18344974592258603717/leader/TermInfo.properties 01:11:54,619 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-18344974592258603717/leader/journal-v1-1.log 01:11:54,619 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-18344974592258603717/leader/metadata-v1-1.log 01:11:54,619 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: no eligible files found 01:11:54,619 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:54,619 AM [test-pekko.actor.default-dispatcher-13] [INFO] Recovery - leader: Recovery completed in in 4.347 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:54,619 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:54,619 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): Election: Leader has following peers: [] 01:11:54,622 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorVotingConfigSupport - leader: onAddServer: AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server139, votingMember=true], state: Idle 01:11:54,622 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server139, votingMember=true] 01:11:54,622 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractReplicatedLog - leader: Capturing Snapshot : lastLogEntry is null. Using snapshot values lastAppliedIndex -1 and lastAppliedTerm -1 instead. 01:11:54,622 AM [test-pekko.actor.default-dispatcher-13] [INFO] SnapshotManager - leader: 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 new-server 01:11:54,622 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SnapshotManager - leader: last applied journal index prior to capture: 0 01:11:54,622 AM [test-pekko.actor.default-dispatcher-13] [INFO] MockRaftActor - leader: support() called 01:11:54,622 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating capture snapshot for new server new-server 01:11:54,623 AM [leader-%d307002] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:54,623 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:54,623 AM [test-pekko.actor.default-dispatcher-13] [INFO] SnapshotManager - leader: Persising snapshot at EntryInfo[index=-1, term=-1]/EntryInfo[index=-1, term=-1] 01:11:54,623 AM [test-pekko.actor.default-dispatcher-13] [INFO] MockRaftActor - leader: support() called 01:11:54,623 AM [test-pekko.actor.default-dispatcher-13] [INFO] SnapshotManager - leader: Removed in-memory snapshotted entries, adjusted snapshotIndex: -1 and term: -1 01:11:54,623 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): sendInstallSnapshot 01:11:54,623 AM [leader-%d307003] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-18344974592258603717/leader/snapshot-0000000069A240DA-2529532A.tmp 01:11:54,623 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] LeaderInstallSnapshotState - leader (Leader): Snapshot 157 bytes, total chunks to send: 1 01:11:54,623 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] LeaderInstallSnapshotState - leader (Leader): Next chunk: total length=157, offset=0, size=157, hashCode=1546036366 01:11:54,623 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): next snapshot chunk size for follower new-server: 157 01:11:54,623 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): InstallSnapshot sent to follower Vector(user, new-server139), Chunk: 1/1 01:11:54,623 AM [test-pekko.actor.default-dispatcher-13] [INFO] Follower - new-server (Follower): Term 1 in "InstallSnapshot{term=1, leaderId=leader, lastIncludedIndex=-1, lastIncludedTerm=-1, datasize=157, chunk=1/1, lastChunkHashCode=OptionalInt[-1]}" message is greater than follower's term 0 - updating term 01:11:54,625 AM [leader-%d307003] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-18344974592258603717/leader/snapshot-0000000069A240DA-2529532A.v1 01:11:54,626 AM [leader-%d307003] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-18344974592258603717/leader/snapshot-0000000069A240DA-2529532A.v1 01:11:54,626 AM [leader-%d307003] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-18344974592258603717/leader/TermInfo.properties 01:11:54,626 AM [leader-%d307003] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-18344974592258603717/leader/journal-v1-1.log 01:11:54,626 AM [leader-%d307003] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-18344974592258603717/leader/metadata-v1-1.log 01:11:54,626 AM [leader-%d307003] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:54.623465258Z, file=/tmp/junit-18344974592258603717/leader/snapshot-0000000069A240DA-2529532A.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:54,626 AM [leader-%d307003] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:54,626 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:54,626 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - leader: snapshot is durable as of 2026-02-28T01:11:54.623465258Z 01:11:54,626 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - leader: Snapshot success, discarding journal entries up to 0 01:11:54,626 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorSnapshotMessageSupport - leader: SnapshotComplete received 01:11:54,627 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=1, votedFor=null 01:11:54,627 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - new-server (Follower): handleInstallSnapshot: InstallSnapshot{term=1, leaderId=leader, lastIncludedIndex=-1, lastIncludedTerm=-1, datasize=157, chunk=1/1, lastChunkHashCode=OptionalInt[-1]} 01:11:54,627 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SyncStatusTracker - new-server: Last sync leader does not match current leader leader, need to catch up to -1 01:11:54,627 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SnapshotTracker - new-server (Follower): addChunk: chunkIndex=1, lastChunkIndex=0, collectedChunks.size=0, lastChunkHashCode=-1 01:11:54,627 AM [test-pekko.actor.default-dispatcher-13] [INFO] Follower - new-server (Follower): Snapshot received from leader: leader 01:11:54,627 AM [test-pekko.actor.default-dispatcher-13] [INFO] SnapshotManager - new-server: Applying snapshot on follower: PlainSnapshotSource{io=MemoryStreamSource{size=157}} 01:11:54,627 AM [test-pekko.actor.default-dispatcher-13] [INFO] MockRaftActor - new-server: support() called [WARN] [02/28/2026 01:11:54.627] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/new-server139] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=new-server, initialSyncDone=false] 01:11:54,627 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SnapshotManager - new-server: Converted InstallSnapshot from leader: leader to state 01:11:54,627 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SnapshotManager - new-server: last applied journal index prior to persisting applied snapshot: 0 01:11:54,628 AM [test-pekko.actor.default-dispatcher-13] [INFO] MockRaftActor - new-server: support() called 01:11:54,628 AM [new-server-%d641576] [DEBUG] RaftStorage - new-server: starting snapshot writeout to /tmp/junit-18344974592258603717/new-server/snapshot-0000000069A240DA-25709922.tmp 01:11:54,633 AM [new-server-%d641576] [DEBUG] RaftStorage - new-server: finished snapshot writeout to /tmp/junit-18344974592258603717/new-server/snapshot-0000000069A240DA-25709922.v1 01:11:54,633 AM [new-server-%d641576] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-18344974592258603717/new-server/snapshot-0000000069A240DA-25709922.v1 01:11:54,633 AM [new-server-%d641576] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-18344974592258603717/new-server/TermInfo.properties 01:11:54,633 AM [new-server-%d641576] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-18344974592258603717/new-server/journal-v1-1.log 01:11:54,633 AM [new-server-%d641576] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-18344974592258603717/new-server/metadata-v1-1.log 01:11:54,633 AM [new-server-%d641576] [DEBUG] RaftStorage - new-server: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:54.628136226Z, file=/tmp/junit-18344974592258603717/new-server/snapshot-0000000069A240DA-25709922.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:54,633 AM [new-server-%d641576] [DEBUG] RaftStorageCompleter - new-server: 1 completion(s) pending 01:11:54,633 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - new-server: running 1 completion(s) 01:11:54,633 AM [test-pekko.actor.default-dispatcher-13] [INFO] SnapshotManager - new-server: snapshot is durable as of 2026-02-28T01:11:54.628136226Z 01:11:54,633 AM [test-pekko.actor.default-dispatcher-13] [INFO] MockRaftActor - new-server: support() called 01:11:54,633 AM [test-pekko.actor.default-dispatcher-13] [INFO] MockRaftActor - new-server: applySnapshot called 01:11:54,634 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - new-server (Follower): handleInstallSnapshot returning: InstallSnapshotReply{term=1, followerId=new-server, chunkIndex=1, success=true} 01:11:54,634 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SnapshotManager - new-server: Snapshot success, discarding journal entries up to 0 01:11:54,634 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorSnapshotMessageSupport - new-server: SnapshotComplete received 01:11:54,634 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): handleInstallSnapshotReply: InstallSnapshotReply{term=1, followerId=new-server, chunkIndex=1, success=true} 01:11:54,634 AM [test-pekko.actor.default-dispatcher-5] [INFO] AbstractLeader - leader (Leader): Snapshot successfully installed on follower new-server (last chunk 1) - matchIndex set to -1, nextIndex set to 0 01:11:54,634 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - Sent message UnInitializedFollowerSnapshotReply to self 01:11:54,672 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: onUnInitializedFollowerSnapshotReply: UnInitializedFollowerSnapshotReply [followerId=new-server] 01:11:54,672 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: New server configuration : [ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]] 01:11:54,672 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Persist data index=0 term=1 command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:54,673 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - leader: Append log entry and persist JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:54,673 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Replicate message: identifier: ServerOperationContextIdentifier{value=b39358f4-cbb8-4aa3-bb8f-2d1c52a96eed}, logIndex: 0, isSendImmediate: true 01:11:54,673 AM [leader-%d307004] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-18344974592258603717/leader/snapshot-0000000069A240DA-28210B3B.tmp 01:11:54,673 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server: active: true, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:54,673 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower new-server 01:11:54,673 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower new-server: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:54,674 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Returning OK for operation AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server139, votingMember=true] 01:11:54,675 AM [leader-%d307004] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-18344974592258603717/leader/snapshot-0000000069A240DA-28210B3B.v1 01:11:54,675 AM [leader-%d307004] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-18344974592258603717/leader/snapshot-0000000069A240DA-2529532A.v1 01:11:54,676 AM [leader-%d307004] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-18344974592258603717/leader/snapshot-0000000069A240DA-28210B3B.v1 01:11:54,676 AM [leader-%d307004] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-18344974592258603717/leader/TermInfo.properties 01:11:54,676 AM [leader-%d307004] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-18344974592258603717/leader/journal-v1-1.log 01:11:54,676 AM [leader-%d307004] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-18344974592258603717/leader/metadata-v1-1.log 01:11:54,676 AM [leader-%d307004] [DEBUG] RaftStorage - leader: deleted snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:54.623465258Z, file=/tmp/junit-18344974592258603717/leader/snapshot-0000000069A240DA-2529532A.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:54,676 AM [leader-%d307004] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:54.673254203Z, file=/tmp/junit-18344974592258603717/leader/snapshot-0000000069A240DA-28210B3B.v1, size=86, entryCompress=NONE, stateCompress=NONE} 01:11:54,676 AM [leader-%d307004] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:54,676 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:54,676 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - leader: persist complete JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:54,723 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: onAddServer: AddServer [newServerId=new-server2, newServerAddress=, votingMember=false], state: Persisting 01:11:54,723 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Server operation already in progress - queueing AddServer [newServerId=new-server2, newServerAddress=, votingMember=false] 01:11:54,736 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower new-server 01:11:54,856 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower new-server 01:11:54,856 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower new-server: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}]} 01:11:54,976 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower new-server 01:11:54,976 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower new-server: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}]} 01:11:55,96 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower new-server 01:11:55,96 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower new-server: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}]} 01:11:55,216 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower new-server 01:11:55,216 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower new-server: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}]} 01:11:55,336 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower new-server 01:11:55,336 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower new-server: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}]} 01:11:55,456 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower new-server 01:11:55,456 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower new-server: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}]} 01:11:55,576 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower new-server 01:11:55,576 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower new-server: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}]} 01:11:56,686 AM [test-pekko.actor.default-dispatcher-16] [WARN] RaftActorVotingConfigSupport - leader: Timeout occured while replicating the new server configuration for new-server 01:11:56,686 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: Returning PRIOR_REQUEST_CONSENSUS_TIMEOUT for operation AddServer [newServerId=new-server2, newServerAddress=, votingMember=false] 01:11:56,687 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: onAddServer: AddServer [newServerId=new-server2, newServerAddress=, votingMember=false], state: Persisting 01:11:56,687 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: Returning PRIOR_REQUEST_CONSENSUS_TIMEOUT for operation AddServer [newServerId=new-server2, newServerAddress=, votingMember=false] 01:11:56,688 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithNoConsensusReached ending 01:11:56,688 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower137] 01:11:56,701 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/new-serverCollector138#-309351573] 01:11:56,701 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/new-server139] 01:11:56,701 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EnabledRaftStorage - new-server: terminating thread VirtualThread[#297,new-server-writer-49]/waiting 01:11:56,702 AM [new-server-writer-49] [DEBUG] JournalWriteTask - new-server: received 1 commands after 2.109 s 01:11:56,702 AM [new-server-writer-49] [DEBUG] JournalWriteTask - new-server: completed 1 commands in 47.79 μs 01:11:56,702 AM [new-server-writer-49] [DEBUG] JournalWriteTask - new-server: journal writer stopped 01:11:56,702 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - new-server: journal closed 01:11:56,702 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - new-server: journal closed 01:11:56,702 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:56,702 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:56,703 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader140] 01:11:56,703 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#298,leader-writer-50]/waiting 01:11:56,703 AM [leader-writer-50] [DEBUG] JournalWriteTask - leader: received 1 commands after 2.088 s 01:11:56,703 AM [leader-writer-50] [DEBUG] JournalWriteTask - leader: completed 1 commands in 18.10 μs 01:11:56,703 AM [leader-writer-50] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:56,703 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:56,703 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - leader: journal closed 01:11:56,703 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:56,703 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:56,704 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leaderCollector141] 01:11:56,704 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/new-serverCollector142] 01:11:56,715 AM [main] [INFO] RaftActorVotingConfigSupportTest - testRemoveServerLeaderWithNoFollowers starting 01:11:56,716 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupportTest$MockLeaderRaftActor - Actor created TestActor[pekko://test/user/leader144] [WARN] [02/28/2026 01:11:56.716] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader144]: org.opendaylight.controller.cluster.common.actor.Monitor@170640c 01:11:56,717 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:56,717 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:56,717 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: started executor 01:11:56,717 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: started executor 01:11:56,718 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:56,718 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:56,718 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:56,719 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:56,719 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - /tmp/junit-207610845016678500/leader/TermInfo.properties does not exist 01:11:56,719 AM [leader-writer-51] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:56,719 AM [leader-writer-51] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:56,722 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:56,722 AM [test-pekko.actor.default-dispatcher-16] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=1, votedFor=} 01:11:56,722 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-207610845016678500/leader/TermInfo.properties 01:11:56,722 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-207610845016678500/leader/journal-v1-1.log 01:11:56,722 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-207610845016678500/leader/metadata-v1-1.log 01:11:56,722 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: no eligible files found 01:11:56,722 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:56,722 AM [test-pekko.actor.default-dispatcher-16] [INFO] Recovery - leader: Recovery completed in in 3.426 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:56,722 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:56,722 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Election: Leader has following peers: [] 01:11:56,733 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: onRemoveServer: RemoveServer{serverId='leader'}, state: Idle 01:11:56,735 AM [main] [INFO] RaftActorVotingConfigSupportTest - testRemoveServerLeaderWithNoFollowers ending 01:11:56,735 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower143] 01:11:56,747 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader144] 01:11:56,747 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#303,leader-writer-51]/waiting 01:11:56,748 AM [leader-writer-51] [DEBUG] JournalWriteTask - leader: received 1 commands after 28.54 ms 01:11:56,748 AM [leader-writer-51] [DEBUG] JournalWriteTask - leader: completed 1 commands in 48.58 μs 01:11:56,748 AM [leader-writer-51] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:56,748 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:56,748 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - leader: journal closed 01:11:56,748 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:56,748 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:56,753 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithLeaderChangeBeforePriorSnapshotComplete starting 01:11:56,755 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupportTest$MockNewFollowerRaftActor - Actor created TestActor[pekko://test/user/new-server147] [WARN] [02/28/2026 01:11:56.756] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/new-server147]: org.opendaylight.controller.cluster.common.actor.Monitor@5f51294b 01:11:56,756 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActor - new-server: Starting recovery with journal batch size 1000 01:11:56,757 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - new-server: started executor 01:11:56,757 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - new-server: started executor 01:11:56,758 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - new-server: metadata journal open: replayFrom=1 applyTo=0 01:11:56,759 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - new-server: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:56,759 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - new-server: journal open: applyTo=0 01:11:56,759 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - new-server: recovering to non-persistent 01:11:56,759 AM [new-server-writer-52] [DEBUG] JournalWriteTask - new-server: journal writer started 01:11:56,759 AM [new-server-writer-52] [DEBUG] JournalWriteTask - new-server: waiting to receive commands 01:11:56,759 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - /tmp/junit-5774868338548415518/new-server/TermInfo.properties does not exist 01:11:56,762 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=0, votedFor=null 01:11:56,762 AM [test-pekko.actor.default-dispatcher-16] [INFO] Recovery - new-server: Local TermInfo store seeded with TermInfo{term=0} 01:11:56,762 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-5774868338548415518/new-server/TermInfo.properties 01:11:56,762 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-5774868338548415518/new-server/journal-v1-1.log 01:11:56,762 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-5774868338548415518/new-server/metadata-v1-1.log 01:11:56,762 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - new-server: no eligible files found 01:11:56,762 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - new-server: Moving last applied index from -1 to -1 01:11:56,762 AM [test-pekko.actor.default-dispatcher-16] [INFO] Recovery - new-server: Recovery completed in in 3.407 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:56,762 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - new-server: Recovery completed and can restore from snapshot 01:11:56,763 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupportTest$MockLeaderRaftActor - Actor created TestActor[pekko://test/user/leader148] [WARN] [02/28/2026 01:11:56.764] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader148]: org.opendaylight.controller.cluster.common.actor.Monitor@a9bb09a 01:11:56,765 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:56,765 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:56,765 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: started executor 01:11:56,765 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: started executor 01:11:56,766 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:56,767 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:56,767 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:56,767 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:56,767 AM [leader-writer-53] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:56,767 AM [leader-writer-53] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:56,767 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - /tmp/junit-5774868338548415518/leader/TermInfo.properties does not exist 01:11:56,770 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:56,770 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=1, votedFor=} 01:11:56,770 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-5774868338548415518/leader/TermInfo.properties 01:11:56,770 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-5774868338548415518/leader/journal-v1-1.log 01:11:56,770 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-5774868338548415518/leader/metadata-v1-1.log 01:11:56,770 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: no eligible files found 01:11:56,770 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:56,770 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - leader: Recovery completed in in 3.104 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:56,771 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:56,771 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Election: Leader has following peers: [] 01:11:56,774 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Take a snapshot of current state. lastReplicatedLog is null and replicatedToAllIndex is -1 01:11:56,774 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - leader: Capturing Snapshot : lastLogEntry is null. Using snapshot values lastAppliedIndex -1 and lastAppliedTerm -1 instead. 01:11:56,774 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - leader: Initiating snapshot capture CaptureSnapshot [lastAppliedIndex=-1, lastAppliedTerm=-1, lastIndex=-1, lastTerm=-1, installSnapshotInitiated=, replicatedToAllIndex=-1, replicatedToAllTerm=-1, unAppliedEntries size=0, mandatoryTrim=true] 01:11:56,774 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - leader: captured snapshot at lastSequenceNumber: 0 01:11:56,774 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - leader: Persising snapshot at EntryInfo[index=-1, term=-1]/EntryInfo[index=-1, term=-1] 01:11:56,775 AM [test-pekko.actor.default-dispatcher-5] [INFO] MockRaftActor - leader: support() called 01:11:56,775 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - leader: user triggered or root overwrite snapshot encountered, trimming log up to last applied index -1 01:11:56,775 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - leader: Removed in-memory snapshotted entries, adjusted snapshotIndex: -1 and term: -1 01:11:56,775 AM [leader-%d557799] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-5774868338548415518/leader/snapshot-0000000069A240DC-2E3D667A.tmp 01:11:56,778 AM [leader-%d557799] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-5774868338548415518/leader/snapshot-0000000069A240DC-2E3D667A.v1 01:11:56,778 AM [leader-%d557799] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-5774868338548415518/leader/TermInfo.properties 01:11:56,778 AM [leader-%d557799] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-5774868338548415518/leader/journal-v1-1.log 01:11:56,778 AM [leader-%d557799] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-5774868338548415518/leader/snapshot-0000000069A240DC-2E3D667A.v1 01:11:56,778 AM [leader-%d557799] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-5774868338548415518/leader/metadata-v1-1.log 01:11:56,779 AM [leader-%d557799] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:56.775775866Z, file=/tmp/junit-5774868338548415518/leader/snapshot-0000000069A240DC-2E3D667A.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:56,779 AM [leader-%d557799] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:56,779 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:56,784 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: onAddServer: AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server147, votingMember=true], state: Idle 01:11:56,785 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server147, votingMember=true] 01:11:56,785 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - leader: captureToInstall should not be called in state PersistCapture[lastJournalIndex=0, request=CaptureSnapshot [lastAppliedIndex=-1, lastAppliedTerm=-1, lastIndex=-1, lastTerm=-1, installSnapshotInitiated=, replicatedToAllIndex=-1, replicatedToAllTerm=-1, unAppliedEntries size=0, mandatoryTrim=true]] 01:11:56,785 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Snapshot already in progress - waiting for completion 01:11:56,889 AM [main] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:56,889 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:56,889 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - leader: snapshot is durable as of 2026-02-28T01:11:56.775775866Z 01:11:56,889 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - leader: Snapshot success, discarding journal entries up to 0 01:11:56,889 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: onSnapshotComplete 01:11:56,889 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: No longer the leader 01:11:56,889 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorSnapshotMessageSupport - leader: SnapshotComplete received 01:11:56,889 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: handleInstallSnapshotTimeout for new server new-server 01:11:56,889 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Returning NO_LEADER for operation AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server147, votingMember=true] 01:11:56,890 AM [test-pekko.actor.default-dispatcher-5] [WARN] RaftActorVotingConfigSupport - leader: Timeout occured for new server new-server while waiting for prior snapshot to complete 01:11:56,890 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithLeaderChangeBeforePriorSnapshotComplete ending 01:11:56,890 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower145] 01:11:56,901 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/new-serverCollector146#-445579090] 01:11:56,902 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/new-server147] 01:11:56,902 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EnabledRaftStorage - new-server: terminating thread VirtualThread[#304,new-server-writer-52]/waiting 01:11:56,902 AM [new-server-writer-52] [DEBUG] JournalWriteTask - new-server: received 1 commands after 143.3 ms 01:11:56,903 AM [new-server-writer-52] [DEBUG] JournalWriteTask - new-server: completed 1 commands in 33.86 μs 01:11:56,903 AM [new-server-writer-52] [DEBUG] JournalWriteTask - new-server: journal writer stopped 01:11:56,903 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - new-server: journal closed 01:11:56,903 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - new-server: journal closed 01:11:56,903 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:56,903 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:56,903 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader148] 01:11:56,904 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#305,leader-writer-53]/waiting 01:11:56,904 AM [leader-writer-53] [DEBUG] JournalWriteTask - leader: received 1 commands after 136.4 ms 01:11:56,904 AM [leader-writer-53] [DEBUG] JournalWriteTask - leader: completed 1 commands in 17.71 μs 01:11:56,904 AM [leader-writer-53] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:56,904 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:56,904 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - leader: journal closed 01:11:56,904 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:56,904 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:56,909 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServersAsNonVoting starting 01:11:56,910 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupportTest$MockNewFollowerRaftActor - Actor created TestActor[pekko://test/user/new-server151] [WARN] [02/28/2026 01:11:56.910] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/new-server151]: org.opendaylight.controller.cluster.common.actor.Monitor@64973900 01:11:56,912 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActor - new-server: Starting recovery with journal batch size 1000 01:11:56,912 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: started executor 01:11:56,912 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: started executor 01:11:56,913 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - new-server: metadata journal open: replayFrom=1 applyTo=0 01:11:56,913 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - new-server: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:56,913 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - new-server: journal open: applyTo=0 01:11:56,914 AM [new-server-writer-54] [DEBUG] JournalWriteTask - new-server: journal writer started 01:11:56,914 AM [new-server-writer-54] [DEBUG] JournalWriteTask - new-server: waiting to receive commands 01:11:56,914 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - new-server: recovering to non-persistent 01:11:56,914 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - /tmp/junit-5223933294922933775/new-server/TermInfo.properties does not exist 01:11:56,917 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=0, votedFor=null 01:11:56,917 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - new-server: Local TermInfo store seeded with TermInfo{term=0} 01:11:56,917 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-5223933294922933775/new-server/TermInfo.properties 01:11:56,917 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-5223933294922933775/new-server/journal-v1-1.log 01:11:56,917 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-5223933294922933775/new-server/metadata-v1-1.log 01:11:56,917 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: no eligible files found 01:11:56,917 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - new-server: Moving last applied index from -1 to -1 01:11:56,917 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - new-server: Recovery completed in in 3.412 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:56,917 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - new-server: Recovery completed and can restore from snapshot 01:11:56,919 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorVotingConfigSupportTest$MockLeaderRaftActor - Actor created TestActor[pekko://test/user/leader152] 01:11:56,920 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:56,920 AM [test-pekko.actor.default-dispatcher-13] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:56,921 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: started executor 01:11:56,921 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: started executor [WARN] [02/28/2026 01:11:56.921] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader152]: org.opendaylight.controller.cluster.common.actor.Monitor@1d15c6fc 01:11:56,922 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:56,922 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:56,922 AM [test-pekko.actor.default-dispatcher-13] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:56,923 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:56,923 AM [leader-writer-55] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:56,923 AM [leader-writer-55] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:56,923 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - /tmp/junit-5223933294922933775/leader/TermInfo.properties does not exist 01:11:56,925 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:56,925 AM [test-pekko.actor.default-dispatcher-13] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=1, votedFor=} 01:11:56,926 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-5223933294922933775/leader/TermInfo.properties 01:11:56,926 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-5223933294922933775/leader/journal-v1-1.log 01:11:56,926 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-5223933294922933775/leader/metadata-v1-1.log 01:11:56,926 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: no eligible files found 01:11:56,926 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:56,926 AM [test-pekko.actor.default-dispatcher-13] [INFO] Recovery - leader: Recovery completed in in 3.242 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:56,926 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:56,926 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): Election: Leader has following peers: [] 01:11:56,938 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorVotingConfigSupport - leader: onAddServer: AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server151, votingMember=false], state: Idle 01:11:56,939 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server151, votingMember=false] 01:11:56,939 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorVotingConfigSupport - leader: New follower is non-voting - directly persisting new server configuration 01:11:56,939 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorVotingConfigSupport - leader: New server configuration : [ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=leader, isVoting=true]] 01:11:56,939 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActor - leader: Persist data index=0 term=1 command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:56,939 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] ReplicatedLogImpl - leader: Append log entry and persist JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:56,939 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): Replicate message: identifier: ServerOperationContextIdentifier{value=8459108a-f2e4-40e7-ad45-30efcb0439e6}, logIndex: 0, isSendImmediate: true 01:11:56,939 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorBehavior - leader (Leader): Setting last applied to 0 01:11:56,939 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to 0 01:11:56,939 AM [leader-%d825395] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-5223933294922933775/leader/snapshot-0000000069A240DC-3801F2BF.tmp 01:11:56,939 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActor - leader: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:56,940 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server: active: false, followerNextIndex: -1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:56,940 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorVotingConfigSupport - leader: Returning OK for operation AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server151, votingMember=false] 01:11:56,940 AM [test-pekko.actor.default-dispatcher-5] [INFO] Follower - new-server (Follower): Term 1 in "AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 0 - updating term 01:11:56,940 AM [test-pekko.actor.default-dispatcher-13] [INFO] RaftActorVotingConfigSupport - leader: VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} has been successfully replicated to a majority of followers 01:11:56,943 AM [leader-%d825395] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-5223933294922933775/leader/snapshot-0000000069A240DC-3801F2BF.v1 01:11:56,944 AM [leader-%d825395] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-5223933294922933775/leader/snapshot-0000000069A240DC-3801F2BF.v1 01:11:56,944 AM [leader-%d825395] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-5223933294922933775/leader/TermInfo.properties 01:11:56,944 AM [leader-%d825395] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-5223933294922933775/leader/journal-v1-1.log 01:11:56,944 AM [leader-%d825395] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-5223933294922933775/leader/metadata-v1-1.log 01:11:56,944 AM [leader-%d825395] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:56.939651775Z, file=/tmp/junit-5223933294922933775/leader/snapshot-0000000069A240DC-3801F2BF.v1, size=86, entryCompress=NONE, stateCompress=NONE} 01:11:56,944 AM [leader-%d825395] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:56,944 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:56,944 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] ReplicatedLogImpl - leader: persist complete JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:56,945 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=1, votedFor=null 01:11:56,945 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - new-server: Last sync leader does not match current leader leader, need to catch up to -1 01:11:56,945 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for new-server updated: matchIndex: -1, nextIndex: 0 01:11:56,945 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server: active: true, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:56,945 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower new-server 01:11:56,945 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower new-server: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}]} 01:11:56,945 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - new-server (Follower): handleAppendEntries: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}]} 01:11:56,946 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - new-server (Follower): Number of entries to be appended = 1 01:11:56,946 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - new-server (Follower): After cleanup, lastIndex: -1, entries to be added from: 0 01:11:56,946 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - new-server (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:56,946 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] ReplicatedLogImpl - new-server: Append log entry and persist JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false} 01:11:56,946 AM [new-server-%d513013] [DEBUG] RaftStorage - new-server: starting snapshot writeout to /tmp/junit-5223933294922933775/new-server/snapshot-0000000069A240DC-386847BD.tmp 01:11:56,946 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PeerInfos - new-server: Updated server config: isVoting: false, peers: [PeerInfo [id=leader, address=null, votingState=VOTING]] 01:11:56,946 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - new-server (Follower): Log size is now 1 01:11:56,946 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - new-server (Follower): Commit index set to 0 01:11:56,946 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - new-server (Follower): handleAppendEntries returning : AppendEntriesReply{term=1, success=true, followerId=new-server, logLastIndex=0, logLastTerm=1, forceInstallSnapshot=false, needsLeaderAddress=true, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:56,946 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SyncStatusTracker - new-server: Lagging 0 entries behind leader leader and reached 0 (of expected -1) [WARN] [02/28/2026 01:11:56.946] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/new-server151] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=new-server, initialSyncDone=false] 01:11:56,946 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - new-server (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 0, context.getLastApplied(): -1, lastIndex(): 0 01:11:56,946 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for new-server updated: matchIndex: 0, nextIndex: 1 01:11:56,946 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - new-server (Follower): Setting last applied to 0 01:11:56,946 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - new-server: Moving last applied index from -1 to 0 01:11:56,946 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server: active: true, followerNextIndex: 1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:56,946 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - new-server: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:56,947 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorageCompleter - new-server: awaiting more completions to resolve 1 synchronized callback(s) 01:11:56,948 AM [new-server-%d513013] [DEBUG] RaftStorage - new-server: finished snapshot writeout to /tmp/junit-5223933294922933775/new-server/snapshot-0000000069A240DC-386847BD.v1 01:11:56,948 AM [new-server-%d513013] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-5223933294922933775/new-server/snapshot-0000000069A240DC-386847BD.v1 01:11:56,949 AM [new-server-%d513013] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-5223933294922933775/new-server/TermInfo.properties 01:11:56,949 AM [new-server-%d513013] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-5223933294922933775/new-server/journal-v1-1.log 01:11:56,949 AM [new-server-%d513013] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-5223933294922933775/new-server/metadata-v1-1.log 01:11:56,949 AM [new-server-%d513013] [DEBUG] RaftStorage - new-server: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:56.946358205Z, file=/tmp/junit-5223933294922933775/new-server/snapshot-0000000069A240DC-386847BD.v1, size=86, entryCompress=NONE, stateCompress=NONE} 01:11:56,949 AM [new-server-%d513013] [DEBUG] RaftStorageCompleter - new-server: 1 completion(s) pending 01:11:56,949 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorageCompleter - new-server: running 1 completion(s) 01:11:56,949 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] ReplicatedLogImpl - new-server: persist complete JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false} 01:11:56,949 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorageCompleter - new-server: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@ab905b1} 01:11:56,949 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorageCompleter - new-server: synchronized callbacks after 2.356 ms [WARN] [02/28/2026 01:11:56.949] [test-pekko.actor.default-dispatcher-13] [pekko://test/user/new-server151] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=new-server, initialSyncDone=true] 01:11:57,57 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - new-server: Lagging 0 entries behind leader leader and reached 0 (of expected -1) 01:11:57,176 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SyncStatusTracker - new-server: Lagging 0 entries behind leader leader and reached 0 (of expected -1) 01:11:57,297 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SyncStatusTracker - new-server: Lagging 0 entries behind leader leader and reached 0 (of expected -1) 01:11:57,416 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SyncStatusTracker - new-server: Lagging 0 entries behind leader leader and reached 0 (of expected -1) 01:11:57,496 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: onAddServer: AddServer [newServerId=new-server2, newServerAddress=pekko://test/user/follower149, votingMember=false], state: Idle 01:11:57,496 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating AddServer [newServerId=new-server2, newServerAddress=pekko://test/user/follower149, votingMember=false] 01:11:57,496 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: New follower is non-voting - directly persisting new server configuration 01:11:57,496 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: New server configuration : [ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]] 01:11:57,496 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Persist data index=1 term=1 command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:57,496 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - leader: Append log entry and persist JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:57,497 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Replicate message: identifier: ServerOperationContextIdentifier{value=4d755f83-5974-47dc-a976-747300827c2a}, logIndex: 1, isSendImmediate: true 01:11:57,497 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - leader (Leader): Setting last applied to 1 01:11:57,497 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from 0 to 1 01:11:57,497 AM [leader-%d825396] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-5223933294922933775/leader/snapshot-0000000069A240DD-1D9E652A.tmp 01:11:57,497 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Applying state for log index 1 data VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:57,497 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server: active: true, followerNextIndex: 1, leaderLastIndex: 1, leaderSnapShotIndex: -1 01:11:57,497 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 1 is present for follower new-server 01:11:57,497 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower new-server: AppendEntries{term=1, leaderId=leader, prevLogIndex=0, prevLogTerm=1, leaderCommit=1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:57,497 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server2: active: false, followerNextIndex: 0, leaderLastIndex: 1, leaderSnapShotIndex: -1 01:11:57,497 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SyncStatusTracker - new-server2: Last sync leader does not match current leader leader, need to catch up to -1 01:11:57,497 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - new-server (Follower): handleAppendEntries: AppendEntries{term=1, leaderId=leader, prevLogIndex=0, prevLogTerm=1, leaderCommit=1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:57,498 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - new-server (Follower): Number of entries to be appended = 1 01:11:57,498 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - new-server (Follower): After cleanup, lastIndex: 0, entries to be added from: 0 01:11:57,498 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - new-server (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:57,498 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] ReplicatedLogImpl - new-server: Append log entry and persist JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:57,498 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Returning OK for operation AddServer [newServerId=new-server2, newServerAddress=pekko://test/user/follower149, votingMember=false] 01:11:57,498 AM [new-server-%d513014] [DEBUG] RaftStorage - new-server: starting snapshot writeout to /tmp/junit-5223933294922933775/new-server/snapshot-0000000069A240DD-1DB2C5F8.tmp 01:11:57,498 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PeerInfos - new-server: Updated server config: isVoting: false, peers: [PeerInfo [id=leader, address=null, votingState=VOTING], PeerInfo [id=new-server2, address=null, votingState=NON_VOTING]] 01:11:57,498 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - new-server (Follower): Log size is now 2 01:11:57,498 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - new-server (Follower): Commit index set to 1 01:11:57,498 AM [test-pekko.actor.default-dispatcher-16] [ERROR] OneForOneStrategy - Cannot invoke "org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.getReplicatedToAllIndex()" because "currentBehavior" is null java.lang.NullPointerException: Cannot invoke "org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.getReplicatedToAllIndex()" because "currentBehavior" is null at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.SnapshotManager.trimLog(SnapshotManager.java:663) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.performSnapshotWithoutCapture(RaftActorBehavior.java:438) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.Follower.handleAppendEntries(Follower.java:222) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.appendEntries(RaftActorBehavior.java:152) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.handleMessage(RaftActorBehavior.java:375) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.Follower.handleMessage(Follower.java:502) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.ForwardMessageToBehaviorActor.onReceive(ForwardMessageToBehaviorActor.java:25) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.UntypedAbstractActor$$anon$1.applyOrElse(AbstractActor.scala:341) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.Actor.aroundReceive(Actor.scala:547) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.Actor.aroundReceive$(Actor.scala:481) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.AbstractActor.aroundReceive(AbstractActor.scala:229) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.ActorCell.receiveMessage(ActorCell.scala:590) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.ActorCell.invoke(ActorCell.scala:557) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.dispatch.Mailbox.processMailbox(Mailbox.scala:273) [ERROR] [02/28/2026 01:11:57.498] [test-pekko.actor.internal-dispatcher-2] [pekko://test/user/follower149] Cannot invoke "org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.getReplicatedToAllIndex()" because "currentBehavior" is null java.lang.NullPointerException: Cannot invoke "org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.getReplicatedToAllIndex()" because "currentBehavior" is null at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.SnapshotManager.trimLog(SnapshotManager.java:663) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.performSnapshotWithoutCapture(RaftActorBehavior.java:438) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.Follower.handleAppendEntries(Follower.java:222) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.appendEntries(RaftActorBehavior.java:152) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.RaftActorBehavior.handleMessage(RaftActorBehavior.java:375) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.behaviors.Follower.handleMessage(Follower.java:502) at org.opendaylight.controller.cluster.raft@12.0.5-SNAPSHOT/org.opendaylight.controller.cluster.raft.ForwardMessageToBehaviorActor.onReceive(ForwardMessageToBehaviorActor.java:25) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.UntypedAbstractActor$$anon$1.applyOrElse(AbstractActor.scala:341) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.Actor.aroundReceive(Actor.scala:547) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.Actor.aroundReceive$(Actor.scala:481) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.AbstractActor.aroundReceive(AbstractActor.scala:229) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.ActorCell.receiveMessage(ActorCell.scala:590) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.actor.ActorCell.invoke(ActorCell.scala:557) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.dispatch.Mailbox.processMailbox(Mailbox.scala:273) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.dispatch.Mailbox.run(Mailbox.scala:234) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.dispatch.Mailbox.exec(Mailbox.scala:246) 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) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.dispatch.Mailbox.run(Mailbox.scala:234) at org.opendaylight.controller.repackaged.pekko@12.0.5-SNAPSHOT/org.apache.pekko.dispatch.Mailbox.exec(Mailbox.scala:246) 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) 01:11:57,499 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - new-server (Follower): handleAppendEntries returning : AppendEntriesReply{term=1, success=true, followerId=new-server, logLastIndex=1, logLastTerm=1, forceInstallSnapshot=false, needsLeaderAddress=true, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:57,499 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActorVotingConfigSupport - leader: VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} has been successfully replicated to a majority of followers 01:11:57,499 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SyncStatusTracker - new-server: Lagging 0 entries behind leader leader and reached 1 (of expected -1) 01:11:57,499 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - new-server (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 1, context.getLastApplied(): 0, lastIndex(): 1 01:11:57,499 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorBehavior - new-server (Follower): Setting last applied to 1 01:11:57,499 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractReplicatedLog - new-server: Moving last applied index from 0 to 1 01:11:57,499 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActor - new-server: Applying state for log index 1 data VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:57,499 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower new-server2 01:11:57,499 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - new-server: awaiting more completions to resolve 1 synchronized callback(s) 01:11:57,499 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower new-server2: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}, JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:57,499 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for new-server updated: matchIndex: 1, nextIndex: 2 01:11:57,499 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server: active: true, followerNextIndex: 2, leaderLastIndex: 1, leaderSnapShotIndex: -1 01:11:57,501 AM [leader-%d825396] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-5223933294922933775/leader/snapshot-0000000069A240DD-1D9E652A.v1 01:11:57,501 AM [leader-%d825396] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-5223933294922933775/leader/snapshot-0000000069A240DD-1D9E652A.v1 01:11:57,501 AM [leader-%d825396] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-5223933294922933775/leader/snapshot-0000000069A240DC-3801F2BF.v1 01:11:57,501 AM [leader-%d825396] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-5223933294922933775/leader/TermInfo.properties 01:11:57,502 AM [leader-%d825396] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-5223933294922933775/leader/journal-v1-1.log 01:11:57,502 AM [leader-%d825396] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-5223933294922933775/leader/metadata-v1-1.log 01:11:57,502 AM [leader-%d825396] [DEBUG] RaftStorage - leader: deleted snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:56.939651775Z, file=/tmp/junit-5223933294922933775/leader/snapshot-0000000069A240DC-3801F2BF.v1, size=86, entryCompress=NONE, stateCompress=NONE} 01:11:57,502 AM [leader-%d825396] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:57.496919850Z, file=/tmp/junit-5223933294922933775/leader/snapshot-0000000069A240DD-1D9E652A.v1, size=100, entryCompress=NONE, stateCompress=NONE} 01:11:57,502 AM [leader-%d825396] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:57,502 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:57,502 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - leader: persist complete JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:57,502 AM [new-server-%d513014] [DEBUG] RaftStorage - new-server: finished snapshot writeout to /tmp/junit-5223933294922933775/new-server/snapshot-0000000069A240DD-1DB2C5F8.v1 01:11:57,502 AM [new-server-%d513014] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-5223933294922933775/new-server/snapshot-0000000069A240DC-386847BD.v1 01:11:57,503 AM [new-server-%d513014] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-5223933294922933775/new-server/TermInfo.properties 01:11:57,503 AM [new-server-%d513014] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-5223933294922933775/new-server/journal-v1-1.log 01:11:57,503 AM [new-server-%d513014] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-5223933294922933775/new-server/metadata-v1-1.log 01:11:57,503 AM [new-server-%d513014] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-5223933294922933775/new-server/snapshot-0000000069A240DD-1DB2C5F8.v1 01:11:57,503 AM [new-server-%d513014] [DEBUG] RaftStorage - new-server: deleted snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:56.946358205Z, file=/tmp/junit-5223933294922933775/new-server/snapshot-0000000069A240DC-386847BD.v1, size=86, entryCompress=NONE, stateCompress=NONE} 01:11:57,503 AM [new-server-%d513014] [DEBUG] RaftStorage - new-server: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:57.498255352Z, file=/tmp/junit-5223933294922933775/new-server/snapshot-0000000069A240DD-1DB2C5F8.v1, size=100, entryCompress=NONE, stateCompress=NONE} 01:11:57,503 AM [new-server-%d513014] [DEBUG] RaftStorageCompleter - new-server: 1 completion(s) pending 01:11:57,503 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - new-server: running 1 completion(s) 01:11:57,503 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] ReplicatedLogImpl - new-server: persist complete JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false} 01:11:57,503 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - new-server: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=false], ServerInfo[peerId=new-server2, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@3202e0d5} 01:11:57,504 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - new-server: synchronized callbacks after 4.446 ms 01:11:57,549 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServersAsNonVoting ending 01:11:57,549 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower149] 01:11:57,552 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/new-serverCollector150#1424332047] 01:11:57,552 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/new-server151] 01:11:57,553 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EnabledRaftStorage - new-server: terminating thread VirtualThread[#308,new-server-writer-54]/waiting 01:11:57,554 AM [new-server-writer-54] [DEBUG] JournalWriteTask - new-server: received 1 commands after 639.9 ms 01:11:57,554 AM [new-server-writer-54] [DEBUG] JournalWriteTask - new-server: completed 1 commands in 33.78 μs 01:11:57,554 AM [new-server-writer-54] [DEBUG] JournalWriteTask - new-server: journal writer stopped 01:11:57,554 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EntryJournalV1 - new-server: journal closed 01:11:57,554 AM [test-pekko.actor.default-dispatcher-13] [INFO] EnabledRaftStorage - new-server: journal closed 01:11:57,554 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:57,554 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:57,555 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader152] 01:11:57,555 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#309,leader-writer-55]/waiting 01:11:57,555 AM [leader-writer-55] [DEBUG] JournalWriteTask - leader: received 1 commands after 632.6 ms 01:11:57,555 AM [leader-writer-55] [DEBUG] JournalWriteTask - leader: completed 1 commands in 20.71 μs 01:11:57,555 AM [leader-writer-55] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:57,555 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:57,555 AM [test-pekko.actor.default-dispatcher-13] [INFO] EnabledRaftStorage - leader: journal closed 01:11:57,556 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:57,556 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:57,556 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leaderCollector153] 01:11:57,563 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithPriorSnapshotInProgress starting 01:11:57,565 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorVotingConfigSupportTest$MockNewFollowerRaftActor - Actor created TestActor[pekko://test/user/new-server156] [WARN] [02/28/2026 01:11:57.565] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/new-server156]: org.opendaylight.controller.cluster.common.actor.Monitor@68c05db1 01:11:57,566 AM [test-pekko.actor.default-dispatcher-13] [INFO] RaftActor - new-server: Starting recovery with journal batch size 1000 01:11:57,566 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - new-server: started executor 01:11:57,566 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - new-server: started executor 01:11:57,566 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EntryJournalV1 - new-server: metadata journal open: replayFrom=1 applyTo=0 01:11:57,567 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] EntryJournalV1 - new-server: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:57,567 AM [test-pekko.actor.default-dispatcher-13] [INFO] EnabledRaftStorage - new-server: journal open: applyTo=0 01:11:57,567 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActor - new-server: recovering to non-persistent 01:11:57,567 AM [new-server-writer-56] [DEBUG] JournalWriteTask - new-server: journal writer started 01:11:57,567 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - /tmp/junit-530063823864470845/new-server/TermInfo.properties does not exist 01:11:57,567 AM [new-server-writer-56] [DEBUG] JournalWriteTask - new-server: waiting to receive commands 01:11:57,570 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=0, votedFor=null 01:11:57,570 AM [test-pekko.actor.default-dispatcher-13] [INFO] Recovery - new-server: Local TermInfo store seeded with TermInfo{term=0} 01:11:57,570 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-530063823864470845/new-server/TermInfo.properties 01:11:57,570 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-530063823864470845/new-server/journal-v1-1.log 01:11:57,570 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-530063823864470845/new-server/metadata-v1-1.log 01:11:57,571 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorage - new-server: no eligible files found 01:11:57,571 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractReplicatedLog - new-server: Moving last applied index from -1 to -1 01:11:57,571 AM [test-pekko.actor.default-dispatcher-13] [INFO] Recovery - new-server: Recovery completed in in 3.394 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:57,571 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActor - new-server: Recovery completed and can restore from snapshot 01:11:57,572 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupportTest$MockLeaderRaftActor - Actor created TestActor[pekko://test/user/leader157] [WARN] [02/28/2026 01:11:57.572] [test-pekko.actor.default-dispatcher-13] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader157]: org.opendaylight.controller.cluster.common.actor.Monitor@974742c 01:11:57,573 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:57,573 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:57,573 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: started executor 01:11:57,574 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: started executor 01:11:57,574 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:57,575 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:57,575 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:57,575 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:57,575 AM [leader-writer-57] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:57,575 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - /tmp/junit-530063823864470845/leader/TermInfo.properties does not exist 01:11:57,575 AM [leader-writer-57] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:57,578 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:57,578 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=1, votedFor=} 01:11:57,579 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-530063823864470845/leader/TermInfo.properties 01:11:57,579 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-530063823864470845/leader/journal-v1-1.log 01:11:57,579 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-530063823864470845/leader/metadata-v1-1.log 01:11:57,579 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: no eligible files found 01:11:57,579 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:57,579 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - leader: Recovery completed in in 3.687 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:57,579 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:57,579 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Election: Leader has following peers: [] 01:11:57,581 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Take a snapshot of current state. lastReplicatedLog is null and replicatedToAllIndex is -1 01:11:57,581 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - leader: Capturing Snapshot : lastLogEntry is null. Using snapshot values lastAppliedIndex -1 and lastAppliedTerm -1 instead. 01:11:57,581 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - leader: Initiating snapshot capture CaptureSnapshot [lastAppliedIndex=-1, lastAppliedTerm=-1, lastIndex=-1, lastTerm=-1, installSnapshotInitiated=, replicatedToAllIndex=-1, replicatedToAllTerm=-1, unAppliedEntries size=0, mandatoryTrim=true] 01:11:57,581 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - leader: captured snapshot at lastSequenceNumber: 0 01:11:57,581 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - leader: Persising snapshot at EntryInfo[index=-1, term=-1]/EntryInfo[index=-1, term=-1] 01:11:57,581 AM [test-pekko.actor.default-dispatcher-5] [INFO] MockRaftActor - leader: support() called 01:11:57,581 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - leader: user triggered or root overwrite snapshot encountered, trimming log up to last applied index -1 01:11:57,581 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - leader: Removed in-memory snapshotted entries, adjusted snapshotIndex: -1 and term: -1 01:11:57,581 AM [leader-%d334887] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-530063823864470845/leader/snapshot-0000000069A240DD-22A923BF.tmp 01:11:57,583 AM [leader-%d334887] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-530063823864470845/leader/snapshot-0000000069A240DD-22A923BF.v1 01:11:57,584 AM [leader-%d334887] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-530063823864470845/leader/snapshot-0000000069A240DD-22A923BF.v1 01:11:57,584 AM [leader-%d334887] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-530063823864470845/leader/TermInfo.properties 01:11:57,584 AM [leader-%d334887] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-530063823864470845/leader/journal-v1-1.log 01:11:57,584 AM [leader-%d334887] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-530063823864470845/leader/metadata-v1-1.log 01:11:57,584 AM [leader-%d334887] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:57.581510079Z, file=/tmp/junit-530063823864470845/leader/snapshot-0000000069A240DD-22A923BF.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:57,584 AM [leader-%d334887] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:57,584 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:57,684 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: onAddServer: AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server156, votingMember=true], state: Idle 01:11:57,684 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server156, votingMember=true] 01:11:57,684 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - leader: captureToInstall should not be called in state PersistCapture[lastJournalIndex=0, request=CaptureSnapshot [lastAppliedIndex=-1, lastAppliedTerm=-1, lastIndex=-1, lastTerm=-1, installSnapshotInitiated=, replicatedToAllIndex=-1, replicatedToAllTerm=-1, unAppliedEntries size=0, mandatoryTrim=true]] 01:11:57,684 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Snapshot already in progress - waiting for completion 01:11:57,684 AM [main] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:57,684 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:57,685 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - leader: snapshot is durable as of 2026-02-28T01:11:57.581510079Z 01:11:57,685 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - leader: Snapshot success, discarding journal entries up to 0 01:11:57,685 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: onSnapshotComplete 01:11:57,685 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - leader: Capturing Snapshot : lastLogEntry is null. Using snapshot values lastAppliedIndex -1 and lastAppliedTerm -1 instead. 01:11:57,685 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - leader: 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 new-server 01:11:57,685 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - leader: last applied journal index prior to capture: 0 01:11:57,685 AM [test-pekko.actor.default-dispatcher-5] [INFO] MockRaftActor - leader: support() called 01:11:57,686 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating capture snapshot for new server new-server 01:11:57,686 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorSnapshotMessageSupport - leader: SnapshotComplete received 01:11:57,686 AM [leader-%d334888] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:57,686 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:57,686 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - leader: Persising snapshot at EntryInfo[index=-1, term=-1]/EntryInfo[index=-1, term=-1] 01:11:57,686 AM [test-pekko.actor.default-dispatcher-5] [INFO] MockRaftActor - leader: support() called 01:11:57,687 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - leader: Removed in-memory snapshotted entries, adjusted snapshotIndex: -1 and term: -1 01:11:57,687 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): sendInstallSnapshot 01:11:57,687 AM [leader-%d334889] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-530063823864470845/leader/snapshot-0000000069A240DD-28F3B725.tmp 01:11:57,687 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] LeaderInstallSnapshotState - leader (Leader): Snapshot 157 bytes, total chunks to send: 1 01:11:57,687 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] LeaderInstallSnapshotState - leader (Leader): Next chunk: total length=157, offset=0, size=157, hashCode=1546036366 01:11:57,687 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): next snapshot chunk size for follower new-server: 157 01:11:57,687 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): InstallSnapshot sent to follower Vector(user, new-server156), Chunk: 1/1 01:11:57,687 AM [test-pekko.actor.default-dispatcher-16] [INFO] Follower - new-server (Follower): Term 1 in "InstallSnapshot{term=1, leaderId=leader, lastIncludedIndex=-1, lastIncludedTerm=-1, datasize=157, chunk=1/1, lastChunkHashCode=OptionalInt[-1]}" message is greater than follower's term 0 - updating term 01:11:57,690 AM [leader-%d334889] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-530063823864470845/leader/snapshot-0000000069A240DD-28F3B725.v1 01:11:57,691 AM [leader-%d334889] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-530063823864470845/leader/snapshot-0000000069A240DD-22A923BF.v1 01:11:57,691 AM [leader-%d334889] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-530063823864470845/leader/snapshot-0000000069A240DD-28F3B725.v1 01:11:57,691 AM [leader-%d334889] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-530063823864470845/leader/TermInfo.properties 01:11:57,691 AM [leader-%d334889] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-530063823864470845/leader/journal-v1-1.log 01:11:57,691 AM [leader-%d334889] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-530063823864470845/leader/metadata-v1-1.log 01:11:57,691 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=1, votedFor=null 01:11:57,691 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - new-server (Follower): handleInstallSnapshot: InstallSnapshot{term=1, leaderId=leader, lastIncludedIndex=-1, lastIncludedTerm=-1, datasize=157, chunk=1/1, lastChunkHashCode=OptionalInt[-1]} 01:11:57,692 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - new-server: Last sync leader does not match current leader leader, need to catch up to -1 01:11:57,692 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotTracker - new-server (Follower): addChunk: chunkIndex=1, lastChunkIndex=0, collectedChunks.size=0, lastChunkHashCode=-1 01:11:57,692 AM [test-pekko.actor.default-dispatcher-16] [INFO] Follower - new-server (Follower): Snapshot received from leader: leader 01:11:57,692 AM [test-pekko.actor.default-dispatcher-16] [INFO] SnapshotManager - new-server: Applying snapshot on follower: PlainSnapshotSource{io=MemoryStreamSource{size=157}} 01:11:57,692 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - new-server: support() called 01:11:57,691 AM [leader-%d334889] [DEBUG] RaftStorage - leader: deleted snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:57.581510079Z, file=/tmp/junit-530063823864470845/leader/snapshot-0000000069A240DD-22A923BF.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:57,692 AM [leader-%d334889] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:57.687060773Z, file=/tmp/junit-530063823864470845/leader/snapshot-0000000069A240DD-28F3B725.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:57,692 AM [leader-%d334889] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending [WARN] [02/28/2026 01:11:57.692] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/new-server156] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=new-server, initialSyncDone=false] 01:11:57,692 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:57,692 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - leader: snapshot is durable as of 2026-02-28T01:11:57.687060773Z 01:11:57,692 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - leader: Snapshot success, discarding journal entries up to 0 01:11:57,693 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorSnapshotMessageSupport - leader: SnapshotComplete received 01:11:57,693 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - new-server: Converted InstallSnapshot from leader: leader to state 01:11:57,693 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - new-server: last applied journal index prior to persisting applied snapshot: 0 01:11:57,693 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - new-server: support() called 01:11:57,693 AM [new-server-%d396933] [DEBUG] RaftStorage - new-server: starting snapshot writeout to /tmp/junit-530063823864470845/new-server/snapshot-0000000069A240DD-29581AD2.tmp 01:11:57,695 AM [new-server-%d396933] [DEBUG] RaftStorage - new-server: finished snapshot writeout to /tmp/junit-530063823864470845/new-server/snapshot-0000000069A240DD-29581AD2.v1 01:11:57,696 AM [new-server-%d396933] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-530063823864470845/new-server/snapshot-0000000069A240DD-29581AD2.v1 01:11:57,696 AM [new-server-%d396933] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-530063823864470845/new-server/TermInfo.properties 01:11:57,696 AM [new-server-%d396933] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-530063823864470845/new-server/journal-v1-1.log 01:11:57,696 AM [new-server-%d396933] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-530063823864470845/new-server/metadata-v1-1.log 01:11:57,696 AM [new-server-%d396933] [DEBUG] RaftStorage - new-server: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:57.693639890Z, file=/tmp/junit-530063823864470845/new-server/snapshot-0000000069A240DD-29581AD2.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:57,696 AM [new-server-%d396933] [DEBUG] RaftStorageCompleter - new-server: 1 completion(s) pending 01:11:57,696 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - new-server: running 1 completion(s) 01:11:57,696 AM [test-pekko.actor.default-dispatcher-5] [INFO] SnapshotManager - new-server: snapshot is durable as of 2026-02-28T01:11:57.693639890Z 01:11:57,696 AM [test-pekko.actor.default-dispatcher-5] [INFO] MockRaftActor - new-server: support() called 01:11:57,696 AM [test-pekko.actor.default-dispatcher-5] [INFO] MockRaftActor - new-server: applySnapshot called 01:11:57,697 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - new-server (Follower): handleInstallSnapshot returning: InstallSnapshotReply{term=1, followerId=new-server, chunkIndex=1, success=true} 01:11:57,697 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SnapshotManager - new-server: Snapshot success, discarding journal entries up to 0 01:11:57,697 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorSnapshotMessageSupport - new-server: SnapshotComplete received 01:11:57,697 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): handleInstallSnapshotReply: InstallSnapshotReply{term=1, followerId=new-server, chunkIndex=1, success=true} 01:11:57,697 AM [test-pekko.actor.default-dispatcher-16] [INFO] AbstractLeader - leader (Leader): Snapshot successfully installed on follower new-server (last chunk 1) - matchIndex set to -1, nextIndex set to 0 01:11:57,697 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - Sent message UnInitializedFollowerSnapshotReply to self 01:11:57,697 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: onUnInitializedFollowerSnapshotReply: UnInitializedFollowerSnapshotReply [followerId=new-server] 01:11:57,697 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: New server configuration : [ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]] 01:11:57,698 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader: Persist data index=0 term=1 command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:57,698 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - leader: Append log entry and persist JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:57,698 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Replicate message: identifier: ServerOperationContextIdentifier{value=bdcd4136-e970-40c3-90f3-9d17647074d9}, logIndex: 0, isSendImmediate: true 01:11:57,698 AM [leader-%d334890] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-530063823864470845/leader/snapshot-0000000069A240DD-299D70FF.tmp 01:11:57,698 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server: active: true, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:57,698 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower new-server 01:11:57,698 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower new-server: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:57,698 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: Returning OK for operation AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server156, votingMember=true] 01:11:57,698 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - new-server (Follower): handleAppendEntries: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:57,698 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - new-server (Follower): Number of entries to be appended = 1 01:11:57,698 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - new-server (Follower): After cleanup, lastIndex: -1, entries to be added from: 0 01:11:57,698 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - new-server (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:57,698 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - new-server: Append log entry and persist JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:57,699 AM [new-server-%d396934] [DEBUG] RaftStorage - new-server: starting snapshot writeout to /tmp/junit-530063823864470845/new-server/snapshot-0000000069A240DD-29AA593B.tmp 01:11:57,699 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PeerInfos - new-server: Updated server config: isVoting: true, peers: [PeerInfo [id=leader, address=null, votingState=VOTING]] 01:11:57,699 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - new-server (Follower): Log size is now 1 01:11:57,699 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Follower - new-server (Follower): handleAppendEntries returning : AppendEntriesReply{term=1, success=true, followerId=new-server, logLastIndex=0, logLastTerm=1, forceInstallSnapshot=false, needsLeaderAddress=true, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:57,699 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for new-server updated: matchIndex: 0, nextIndex: 1 01:11:57,700 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server: active: true, followerNextIndex: 1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:57,700 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - new-server: Lagging 0 entries behind leader leader and reached -1 (of expected -1) 01:11:57,700 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - new-server: awaiting more completions to resolve 1 synchronized callback(s) 01:11:57,701 AM [leader-%d334890] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-530063823864470845/leader/snapshot-0000000069A240DD-299D70FF.v1 01:11:57,701 AM [leader-%d334890] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-530063823864470845/leader/snapshot-0000000069A240DD-299D70FF.v1 01:11:57,701 AM [leader-%d334890] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-530063823864470845/leader/snapshot-0000000069A240DD-28F3B725.v1 01:11:57,701 AM [leader-%d334890] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-530063823864470845/leader/TermInfo.properties 01:11:57,701 AM [leader-%d334890] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-530063823864470845/leader/journal-v1-1.log 01:11:57,701 AM [leader-%d334890] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-530063823864470845/leader/metadata-v1-1.log 01:11:57,701 AM [leader-%d334890] [DEBUG] RaftStorage - leader: deleted snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:57.687060773Z, file=/tmp/junit-530063823864470845/leader/snapshot-0000000069A240DD-28F3B725.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:57,701 AM [leader-%d334890] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:57.698183935Z, file=/tmp/junit-530063823864470845/leader/snapshot-0000000069A240DD-299D70FF.v1, size=86, entryCompress=NONE, stateCompress=NONE} 01:11:57,702 AM [leader-%d334890] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:57,702 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:57,702 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] ReplicatedLogImpl - leader: persist complete JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:57,702 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractLeader - leader (Leader): Applying to log - commitIndex: 0, lastAppliedIndex: -1 01:11:57,702 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - leader (Leader): Setting last applied to 0 01:11:57,702 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to 0 01:11:57,702 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - leader: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:57,702 AM [test-pekko.actor.default-dispatcher-15] [INFO] RaftActorVotingConfigSupport - leader: VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} has been successfully replicated to a majority of followers 01:11:57,702 AM [new-server-%d396934] [DEBUG] RaftStorage - new-server: finished snapshot writeout to /tmp/junit-530063823864470845/new-server/snapshot-0000000069A240DD-29AA593B.v1 01:11:57,702 AM [new-server-%d396934] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-530063823864470845/new-server/snapshot-0000000069A240DD-29AA593B.v1 01:11:57,702 AM [new-server-%d396934] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-530063823864470845/new-server/snapshot-0000000069A240DD-29581AD2.v1 01:11:57,702 AM [new-server-%d396934] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-530063823864470845/new-server/TermInfo.properties 01:11:57,702 AM [new-server-%d396934] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-530063823864470845/new-server/journal-v1-1.log 01:11:57,702 AM [new-server-%d396934] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-530063823864470845/new-server/metadata-v1-1.log 01:11:57,702 AM [new-server-%d396934] [DEBUG] RaftStorage - new-server: deleted snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:57.693639890Z, file=/tmp/junit-530063823864470845/new-server/snapshot-0000000069A240DD-29581AD2.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:57,702 AM [new-server-%d396934] [DEBUG] RaftStorage - new-server: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:57.699029819Z, file=/tmp/junit-530063823864470845/new-server/snapshot-0000000069A240DD-29AA593B.v1, size=86, entryCompress=NONE, stateCompress=NONE} 01:11:57,702 AM [new-server-%d396934] [DEBUG] RaftStorageCompleter - new-server: 1 completion(s) pending 01:11:57,702 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - new-server: running 1 completion(s) 01:11:57,703 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - new-server: persist complete JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false} 01:11:57,703 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - new-server: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@163bd67c} 01:11:57,703 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - new-server: synchronized callbacks after 2.709 ms [WARN] [02/28/2026 01:11:57.703] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/new-server156] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=new-server, initialSyncDone=true] 01:11:57,750 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithPriorSnapshotInProgress ending 01:11:57,751 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower154] 01:11:57,762 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/new-serverCollector155#1248904631] 01:11:57,763 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/new-server156] 01:11:57,763 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EnabledRaftStorage - new-server: terminating thread VirtualThread[#314,new-server-writer-56]/waiting 01:11:57,763 AM [new-server-writer-56] [DEBUG] JournalWriteTask - new-server: received 1 commands after 195.8 ms 01:11:57,763 AM [new-server-writer-56] [DEBUG] JournalWriteTask - new-server: completed 1 commands in 28.36 μs 01:11:57,763 AM [new-server-writer-56] [DEBUG] JournalWriteTask - new-server: journal writer stopped 01:11:57,764 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - new-server: journal closed 01:11:57,764 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - new-server: journal closed 01:11:57,764 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:57,764 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:57,764 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader157] 01:11:57,764 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#315,leader-writer-57]/waiting 01:11:57,764 AM [leader-writer-57] [DEBUG] JournalWriteTask - leader: received 1 commands after 189.2 ms 01:11:57,764 AM [leader-writer-57] [DEBUG] JournalWriteTask - leader: completed 1 commands in 17.88 μs 01:11:57,764 AM [leader-writer-57] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:57,765 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:57,765 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - leader: journal closed 01:11:57,765 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:57,765 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:57,765 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leaderCollector158] 01:11:57,771 AM [main] [INFO] RaftActorVotingConfigSupportTest - testChangeLeaderToNonVotingInSingleNode starting 01:11:57,771 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupportTest$MockLeaderRaftActor - Actor created TestActor[pekko://test/user/leader160] [WARN] [02/28/2026 01:11:57.772] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader160]: org.opendaylight.controller.cluster.common.actor.Monitor@6749fbcf 01:11:57,772 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:57,773 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:57,773 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: started executor 01:11:57,773 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: started executor 01:11:57,773 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:57,774 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:57,774 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:57,774 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:57,774 AM [leader-writer-58] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:57,774 AM [leader-writer-58] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:57,774 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - /tmp/junit-1138843974512599827/leader/TermInfo.properties does not exist 01:11:57,778 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:57,778 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=1, votedFor=} 01:11:57,778 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-1138843974512599827/leader/TermInfo.properties 01:11:57,778 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-1138843974512599827/leader/journal-v1-1.log 01:11:57,778 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-1138843974512599827/leader/metadata-v1-1.log 01:11:57,778 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: no eligible files found 01:11:57,778 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:57,779 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - leader: Recovery completed in in 4.369 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:57,779 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:57,779 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Election: Leader has following peers: [] 01:11:57,790 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: onChangeServersVotingStatus: ChangeServersVotingStatus [serverVotingStatusMap={leader=false}, serversVisited=[]], state: Idle 01:11:57,790 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - Initiating ChangeServersVotingStatusState 01:11:57,790 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Returning INVALID_REQUEST for operation ChangeServersVotingStatus [serverVotingStatusMap={leader=false}, serversVisited=[]] 01:11:57,790 AM [main] [INFO] RaftActorVotingConfigSupportTest - testChangeLeaderToNonVotingInSingleNode ending 01:11:57,791 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower159] 01:11:57,802 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader160] 01:11:57,802 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#323,leader-writer-58]/waiting 01:11:57,802 AM [leader-writer-58] [DEBUG] JournalWriteTask - leader: received 1 commands after 27.97 ms 01:11:57,802 AM [leader-writer-58] [DEBUG] JournalWriteTask - leader: completed 1 commands in 56.13 μs 01:11:57,802 AM [leader-writer-58] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:57,803 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:57,803 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - leader: journal closed 01:11:57,803 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:57,803 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:57,807 AM [main] [INFO] RaftActorVotingConfigSupportTest - testChangeLeaderToNonVoting starting 01:11:57,807 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupportTest$MockLeaderRaftActor - Actor created TestActor[pekko://test/user/leader164] [WARN] [02/28/2026 01:11:57.807] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader164]: org.opendaylight.controller.cluster.common.actor.Monitor@5beff82a 01:11:57,809 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:57,809 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:57,809 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: started executor 01:11:57,809 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: started executor 01:11:57,810 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:57,811 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:57,811 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:57,811 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:57,811 AM [leader-writer-59] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:57,811 AM [leader-writer-59] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:57,812 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - /tmp/junit-8209743510650800325/leader/TermInfo.properties does not exist 01:11:57,814 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:57,814 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=1, votedFor=} 01:11:57,814 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-8209743510650800325/leader/TermInfo.properties 01:11:57,814 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-8209743510650800325/leader/journal-v1-1.log 01:11:57,814 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-8209743510650800325/leader/metadata-v1-1.log 01:11:57,815 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: no eligible files found 01:11:57,815 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:57,815 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - leader: Recovery completed in in 3.102 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:57,815 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:57,815 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Election: Leader has following peers: [follower2, follower] 01:11:57,815 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower2: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 [WARN] [02/28/2026 01:11:57.815] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/follower2163] received dead letter from TestActor[pekko://test/user/leader164]: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]} 01:11:57,815 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 [WARN] [02/28/2026 01:11:57.816] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/follower162] received dead letter from TestActor[pekko://test/user/leader164]: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]} 01:11:57,818 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupportTest$CollectingMockRaftActor - Actor created TestActor[pekko://test/user/follower162] [WARN] [02/28/2026 01:11:57.818] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/follower162]: org.opendaylight.controller.cluster.common.actor.Monitor@6d47d66b 01:11:57,819 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActor - follower: Starting recovery with journal batch size 1000 01:11:57,819 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower: started executor 01:11:57,819 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower: started executor 01:11:57,819 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - follower: metadata journal open: replayFrom=1 applyTo=0 01:11:57,820 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - follower: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:57,820 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - follower: journal open: applyTo=0 01:11:57,820 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - follower: recovering to non-persistent 01:11:57,820 AM [follower-writer-60] [DEBUG] JournalWriteTask - follower: journal writer started 01:11:57,820 AM [follower-writer-60] [DEBUG] JournalWriteTask - follower: waiting to receive commands 01:11:57,820 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - /tmp/junit-8209743510650800325/follower/TermInfo.properties does not exist 01:11:57,823 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower: Set currentTerm=0, votedFor=null 01:11:57,823 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - follower: Local TermInfo store seeded with TermInfo{term=0} 01:11:57,823 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-8209743510650800325/follower/TermInfo.properties 01:11:57,823 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-8209743510650800325/follower/journal-v1-1.log 01:11:57,823 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-8209743510650800325/follower/metadata-v1-1.log 01:11:57,823 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower: no eligible files found 01:11:57,823 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - follower: Moving last applied index from -1 to -1 01:11:57,823 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - follower: Recovery completed in in 2.802 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:57,823 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - follower: Recovery completed and can restore from snapshot 01:11:57,824 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupportTest$CollectingMockRaftActor - Actor created TestActor[pekko://test/user/follower2163] [WARN] [02/28/2026 01:11:57.824] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/follower2163]: org.opendaylight.controller.cluster.common.actor.Monitor@1743c3b7 01:11:57,825 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActor - follower2: Starting recovery with journal batch size 1000 01:11:57,825 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower2: started executor 01:11:57,825 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower2: started executor 01:11:57,825 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - follower2: metadata journal open: replayFrom=1 applyTo=0 01:11:57,826 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - follower2: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:57,826 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - follower2: journal open: applyTo=0 01:11:57,826 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - follower2: recovering to non-persistent 01:11:57,826 AM [follower2-writer-61] [DEBUG] JournalWriteTask - follower2: journal writer started 01:11:57,826 AM [follower2-writer-61] [DEBUG] JournalWriteTask - follower2: waiting to receive commands 01:11:57,826 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - /tmp/junit-8209743510650800325/follower2/TermInfo.properties does not exist 01:11:57,828 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower2: Set currentTerm=0, votedFor=null 01:11:57,828 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - follower2: Local TermInfo store seeded with TermInfo{term=0} 01:11:57,828 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-8209743510650800325/follower2/TermInfo.properties 01:11:57,828 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-8209743510650800325/follower2/journal-v1-1.log 01:11:57,828 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-8209743510650800325/follower2/metadata-v1-1.log 01:11:57,828 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower2: no eligible files found 01:11:57,828 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - follower2: Moving last applied index from -1 to -1 01:11:57,828 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - follower2: Recovery completed in in 2.386 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:57,828 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - follower2: Recovery completed and can restore from snapshot 01:11:57,839 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: onChangeServersVotingStatus: ChangeServersVotingStatus [serverVotingStatusMap={leader=false}, serversVisited=[]], state: Idle 01:11:57,839 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - Initiating ChangeServersVotingStatusState 01:11:57,839 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PeerInfos - leader: Updated server config: isVoting: false, peers: [PeerInfo [id=follower2, address=pekko://test/user/follower2163, votingState=VOTING], PeerInfo [id=follower, address=pekko://test/user/follower162, votingState=VOTING]] 01:11:57,839 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: New server configuration : [ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]] 01:11:57,839 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Persist data index=0 term=1 command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]} 01:11:57,839 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - leader: Append log entry and persist JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]}, pending=true} 01:11:57,839 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Replicate message: identifier: ServerOperationContextIdentifier{value=b11479c4-d0b3-492e-b055-34ff587caa64}, logIndex: 0, isSendImmediate: true 01:11:57,840 AM [leader-%d88797] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-8209743510650800325/leader/snapshot-0000000069A240DD-320EF863.tmp 01:11:57,840 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower2: active: false, followerNextIndex: -1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:57,840 AM [test-pekko.actor.default-dispatcher-15] [INFO] Follower - follower2 (Follower): Term 1 in "AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 0 - updating term 01:11:57,840 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: false, followerNextIndex: -1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:57,840 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Returning OK for operation ChangeServersVotingStatus [serverVotingStatusMap={leader=false}, serversVisited=[]] 01:11:57,840 AM [test-pekko.actor.default-dispatcher-16] [INFO] Follower - follower (Follower): Term 1 in "AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 0 - updating term 01:11:57,845 AM [leader-%d88797] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-8209743510650800325/leader/snapshot-0000000069A240DD-320EF863.v1 01:11:57,845 AM [leader-%d88797] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-8209743510650800325/leader/snapshot-0000000069A240DD-320EF863.v1 01:11:57,845 AM [leader-%d88797] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-8209743510650800325/leader/TermInfo.properties 01:11:57,845 AM [leader-%d88797] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-8209743510650800325/leader/journal-v1-1.log 01:11:57,845 AM [leader-%d88797] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-8209743510650800325/leader/metadata-v1-1.log 01:11:57,845 AM [leader-%d88797] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:57.839841891Z, file=/tmp/junit-8209743510650800325/leader/snapshot-0000000069A240DD-320EF863.v1, size=96, entryCompress=NONE, stateCompress=NONE} 01:11:57,845 AM [leader-%d88797] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:57,846 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - follower2: Set currentTerm=1, votedFor=null 01:11:57,846 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:57,846 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - follower: Set currentTerm=1, votedFor=null 01:11:57,846 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SyncStatusTracker - follower2: Last sync leader does not match current leader leader, need to catch up to -1 01:11:57,846 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - leader: persist complete JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]}, pending=true} 01:11:57,846 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower: Last sync leader does not match current leader leader, need to catch up to -1 [WARN] [02/28/2026 01:11:57.846] [test-pekko.actor.default-dispatcher-13] [pekko://test/user/follower2163] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=follower2, initialSyncDone=false] [WARN] [02/28/2026 01:11:57.846] [test-pekko.actor.default-dispatcher-13] [pekko://test/user/follower162] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=follower, initialSyncDone=false] 01:11:57,846 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for follower2 updated: matchIndex: -1, nextIndex: 0 01:11:57,846 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower2: active: true, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:57,846 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower follower2 01:11:57,846 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower follower2: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]}, pending=false}]} 01:11:57,847 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower2 (Follower): handleAppendEntries: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]}, pending=false}]} 01:11:57,847 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower2 (Follower): Number of entries to be appended = 1 01:11:57,847 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower2 (Follower): After cleanup, lastIndex: -1, entries to be added from: 0 01:11:57,847 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower2 (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]} 01:11:57,847 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] ReplicatedLogImpl - follower2: Append log entry and persist JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]}, pending=false} 01:11:57,847 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PeerInfos - follower2: Updated server config: isVoting: true, peers: [PeerInfo [id=leader, address=pekko://test/user/leader164, votingState=NON_VOTING], PeerInfo [id=follower, address=pekko://test/user/follower162, votingState=VOTING]] 01:11:57,847 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower2 (Follower): Log size is now 1 01:11:57,847 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower2 (Follower): handleAppendEntries returning : AppendEntriesReply{term=1, success=true, followerId=follower2, logLastIndex=0, logLastTerm=1, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:57,847 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SyncStatusTracker - follower2: Lagging 0 entries behind leader leader and reached -1 (of expected -1) 01:11:57,847 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - follower2: awaiting more completions to resolve 1 synchronized callback(s) 01:11:57,847 AM [follower2-%d98499] [DEBUG] RaftStorage - follower2: starting snapshot writeout to /tmp/junit-8209743510650800325/follower2/snapshot-0000000069A240DD-32812FEE.tmp 01:11:57,847 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for follower updated: matchIndex: -1, nextIndex: 0 01:11:57,847 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: true, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:57,847 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower follower 01:11:57,847 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower follower: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]}, pending=false}]} 01:11:57,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): handleAppendEntries: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]}, pending=false}]} 01:11:57,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): Number of entries to be appended = 1 01:11:57,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): After cleanup, lastIndex: -1, entries to be added from: 0 01:11:57,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]} 01:11:57,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower: Append log entry and persist JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]}, pending=false} 01:11:57,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PeerInfos - follower: Updated server config: isVoting: true, peers: [PeerInfo [id=leader, address=pekko://test/user/leader164, votingState=NON_VOTING], PeerInfo [id=follower2, address=pekko://test/user/follower2163, votingState=VOTING]] 01:11:57,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): Log size is now 1 01:11:57,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): handleAppendEntries returning : AppendEntriesReply{term=1, success=true, followerId=follower, logLastIndex=0, logLastTerm=1, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:57,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower: Lagging 0 entries behind leader leader and reached -1 (of expected -1) 01:11:57,848 AM [follower-%d793653] [DEBUG] RaftStorage - follower: starting snapshot writeout to /tmp/junit-8209743510650800325/follower/snapshot-0000000069A240DD-32928486.tmp 01:11:57,848 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - follower: awaiting more completions to resolve 1 synchronized callback(s) 01:11:57,848 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for follower2 updated: matchIndex: 0, nextIndex: 1 01:11:57,849 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Applying to log - commitIndex: 0, lastAppliedIndex: -1 01:11:57,849 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - leader (Leader): Setting last applied to 0 01:11:57,849 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to 0 01:11:57,849 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]} 01:11:57,849 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower2: active: true, followerNextIndex: 1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:57,849 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for follower updated: matchIndex: 0, nextIndex: 1 01:11:57,849 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: true, followerNextIndex: 1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:57,849 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActorVotingConfigSupport - leader: VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]} has been successfully replicated to a majority of followers 01:11:57,849 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - Leader changed to non-voting - trying leadership transfer 01:11:57,849 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Initiating leader transfer 01:11:57,850 AM [follower2-%d98499] [DEBUG] RaftStorage - follower2: finished snapshot writeout to /tmp/junit-8209743510650800325/follower2/snapshot-0000000069A240DD-32812FEE.v1 01:11:57,850 AM [follower2-%d98499] [DEBUG] RaftStorage - follower2: selected SNAPSHOT_V1 to handle file /tmp/junit-8209743510650800325/follower2/snapshot-0000000069A240DD-32812FEE.v1 01:11:57,850 AM [follower2-%d98499] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-8209743510650800325/follower2/TermInfo.properties 01:11:57,850 AM [follower2-%d98499] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-8209743510650800325/follower2/journal-v1-1.log 01:11:57,850 AM [follower2-%d98499] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-8209743510650800325/follower2/metadata-v1-1.log 01:11:57,850 AM [follower2-%d98499] [DEBUG] RaftStorage - follower2: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:57.847327214Z, file=/tmp/junit-8209743510650800325/follower2/snapshot-0000000069A240DD-32812FEE.v1, size=96, entryCompress=NONE, stateCompress=NONE} 01:11:57,850 AM [follower2-%d98499] [DEBUG] RaftStorageCompleter - follower2: 1 completion(s) pending 01:11:57,850 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - follower2: running 1 completion(s) 01:11:57,850 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] ReplicatedLogImpl - follower2: persist complete JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]}, pending=false} 01:11:57,850 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - follower2: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@26273eef} 01:11:57,850 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - follower2: synchronized callbacks after 3.399 ms 01:11:57,851 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower2 (Follower): Commit index set to 0 01:11:57,851 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SyncStatusTracker - follower2: Lagging 0 entries behind leader leader and reached 0 (of expected -1) 01:11:57,851 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower2 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 0, context.getLastApplied(): -1, lastIndex(): 0 01:11:57,851 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorBehavior - follower2 (Follower): Setting last applied to 0 01:11:57,851 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractReplicatedLog - follower2: Moving last applied index from -1 to 0 01:11:57,851 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActor - follower2: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]} [WARN] [02/28/2026 01:11:57.851] [test-pekko.actor.default-dispatcher-13] [pekko://test/user/follower2163] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=follower2, initialSyncDone=true] 01:11:57,851 AM [follower-%d793653] [DEBUG] RaftStorage - follower: finished snapshot writeout to /tmp/junit-8209743510650800325/follower/snapshot-0000000069A240DD-32928486.v1 01:11:57,851 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - follower2: onLeaderTransitioning: LeaderTransitioning [leaderId=leader] 01:11:57,851 AM [follower-%d793653] [DEBUG] RaftStorage - follower: selected SNAPSHOT_V1 to handle file /tmp/junit-8209743510650800325/follower/snapshot-0000000069A240DD-32928486.v1 01:11:57,851 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorLeadershipTransferCohort - leader: pauseLeader successfully completed - doing transfer 01:11:57,851 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Leader - leader (Leader): Attempting to transfer leadership 01:11:57,851 AM [follower-%d793653] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-8209743510650800325/follower/TermInfo.properties 01:11:57,851 AM [follower-%d793653] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-8209743510650800325/follower/journal-v1-1.log 01:11:57,851 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower2: active: true, followerNextIndex: 1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:57,852 AM [follower-%d793653] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-8209743510650800325/follower/metadata-v1-1.log 01:11:57,852 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: true, followerNextIndex: 1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:57,852 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SyncStatusTracker - follower2: Lagging 0 entries behind leader leader and reached 0 (of expected -1) 01:11:57,852 AM [follower-%d793653] [DEBUG] RaftStorage - follower: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:57.848462982Z, file=/tmp/junit-8209743510650800325/follower/snapshot-0000000069A240DD-32928486.v1, size=96, entryCompress=NONE, stateCompress=NONE} 01:11:57,852 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Leader - leader (Leader): tryToCompleteLeadershipTransfer: followerId: follower2, matchIndex: 0, lastIndex: 0, isVoting: true 01:11:57,852 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Leader - leader (Leader): Follower's log matches - sending ElectionTimeout 01:11:57,852 AM [follower-%d793653] [DEBUG] RaftStorageCompleter - follower: 1 completion(s) pending 01:11:57,852 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower2: active: true, followerNextIndex: 1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:57,852 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - follower: running 1 completion(s) 01:11:57,852 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower: persist complete JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]}, pending=false} 01:11:57,852 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - follower: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@1b8557d2} 01:11:57,852 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - follower: synchronized callbacks after 3.725 ms 01:11:57,852 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): Commit index set to 0 01:11:57,852 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower: Lagging 0 entries behind leader leader and reached 0 (of expected -1) 01:11:57,852 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 0, context.getLastApplied(): -1, lastIndex(): 0 01:11:57,852 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - follower (Follower): Setting last applied to 0 01:11:57,852 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - follower: Moving last applied index from -1 to 0 01:11:57,852 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=false]]} 01:11:57,852 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower: Lagging 0 entries behind leader leader and reached 0 (of expected -1) 01:11:57,852 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower: onLeaderTransitioning: LeaderTransitioning [leaderId=leader] [WARN] [02/28/2026 01:11:57.852] [test-pekko.actor.default-dispatcher-14] [pekko://test/user/follower162] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=follower, initialSyncDone=true] 01:11:57,852 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: true, followerNextIndex: 1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:57,853 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SyncStatusTracker - follower2: Lagging 0 entries behind leader leader and reached 0 (of expected -1) 01:11:57,853 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Leader - leader (Leader): Leader transfer complete 01:11:57,853 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorLeadershipTransferCohort - leader: leader transfer complete - waiting for new leader 01:11:57,853 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower2 (Follower): Received TimeoutNow - switching to Candidate 01:11:57,853 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SyncStatusTracker - follower: Lagging 0 entries behind leader leader and reached 0 (of expected -1) 01:11:57,853 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Candidate - follower2 (Candidate): Election: Candidate has following voting peers: [follower] 01:11:57,855 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - follower2: Set currentTerm=2, votedFor=follower2 01:11:57,855 AM [test-pekko.actor.default-dispatcher-13] [INFO] Candidate - follower2 (Candidate): Starting new election term 2 01:11:57,855 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Candidate - follower2 (Candidate): Sending RequestVote{term=2, candidateId=follower2, lastLogIndex=0, lastLogTerm=1} to peer follower 01:11:57,855 AM [test-pekko.actor.default-dispatcher-13] [INFO] RaftActorBehavior - follower2 (Follower) :- Switching from behavior Follower to Candidate, election term: 2 01:11:57,855 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - follower (Follower): Found higher term in RequestVote rpc, verifying whether it's safe to update term. 01:11:57,855 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - follower (Follower): Cluster state: [] 01:11:57,855 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - follower (Follower): Candidate in requestVote:RequestVote{term=2, candidateId=follower2, lastLogIndex=0, lastLogTerm=1} with higher term appears reachable, updating term. 01:11:57,855 AM [test-pekko.actor.default-dispatcher-5] [INFO] Follower - follower (Follower): Term 2 in "RequestVote{term=2, candidateId=follower2, lastLogIndex=0, lastLogTerm=1}" message is greater than follower's term 1 - updating term 01:11:57,857 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower: Set currentTerm=2, votedFor=null 01:11:57,857 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - follower (Follower): In requestVote: RequestVote{term=2, candidateId=follower2, lastLogIndex=0, lastLogTerm=1} - currentTerm: 2, votedFor: null, lastIndex: 0, lastTerm: 1 01:11:57,859 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower: Set currentTerm=2, votedFor=follower2 01:11:57,859 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorBehavior - follower (Follower): requestVote returning: RequestVoteReply{term=2, voteGranted=true} 01:11:57,859 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Candidate - follower2 (Candidate): RaftRPC message received RequestVoteReply{term=2, voteGranted=true}, my term is 2 01:11:57,859 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] Candidate - follower2 (Candidate): handleRequestVoteReply: RequestVoteReply{term=2, voteGranted=true}, current voteCount: 1 01:11:57,859 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - follower2 (Leader): Election: Leader has following peers: [leader, follower] 01:11:57,859 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - follower2 (Leader): Checking sendAppendEntries for follower leader: active: false, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:57,859 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - follower2 (Leader): Checking sendAppendEntries for follower follower: active: false, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:57,859 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower: Last sync leader does not match current leader follower2, need to catch up to -1 01:11:57,860 AM [test-pekko.actor.default-dispatcher-13] [INFO] AbstractLeader - leader (Leader): Term 2 in "AppendEntries{term=2, leaderId=follower2, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than leader's term 1 - switching to Follower [WARN] [02/28/2026 01:11:57.860] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/follower162] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=follower, initialSyncDone=false] 01:11:57,860 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActorBehavior - follower2 (Candidate) :- Switching from behavior Candidate to Leader, election term: 2 01:11:57,860 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - follower2 (Leader): handleAppendEntriesReply - FollowerLogInformation for follower updated: matchIndex: 0, nextIndex: 1 01:11:57,860 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - follower2 (Leader): Checking sendAppendEntries for follower follower: active: true, followerNextIndex: 1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:57,860 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SyncStatusTracker - follower: Lagging 0 entries behind leader follower2 and reached 0 (of expected -1) [WARN] [02/28/2026 01:11:57.860] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/follower162] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=follower, initialSyncDone=true] 01:11:57,862 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=2, votedFor=null 01:11:57,862 AM [test-pekko.actor.default-dispatcher-13] [INFO] RaftActorBehavior - leader (Leader) :- Switching from behavior Leader to Follower, election term: 2 01:11:58,377 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - leader: Last sync leader does not match current leader follower2, need to catch up to -1 01:11:58,377 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - follower2 (Leader): handleAppendEntriesReply - FollowerLogInformation for leader updated: matchIndex: 0, nextIndex: 1 01:11:58,377 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorLeadershipTransferCohort - leader: leader changed to follower2 01:11:58,377 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - follower2 (Leader): Checking sendAppendEntries for follower leader: active: true, followerNextIndex: 1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:58,377 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActorLeadershipTransferCohort - leader: Successfully transferred leadership to follower2 in 527.0 ms 01:11:58,377 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SyncStatusTracker - follower: Lagging 0 entries behind leader follower2 and reached 0 (of expected -1) 01:11:58,377 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: leader transfer succeeded after change to non-voting 01:11:58,377 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - leader: Lagging 0 entries behind leader follower2 and reached 0 (of expected -1) [WARN] [02/28/2026 01:11:58.377] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/leader164] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=leader, initialSyncDone=false] [WARN] [02/28/2026 01:11:58.378] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/leader164] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=leader, initialSyncDone=true] 01:11:58,394 AM [main] [INFO] RaftActorVotingConfigSupportTest - testChangeLeaderToNonVoting ending 01:11:58,394 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower161] 01:11:58,406 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader164] 01:11:58,406 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#324,leader-writer-59]/waiting 01:11:58,406 AM [leader-writer-59] [DEBUG] JournalWriteTask - leader: received 1 commands after 594.7 ms 01:11:58,406 AM [leader-writer-59] [DEBUG] JournalWriteTask - leader: completed 1 commands in 109.7 μs 01:11:58,407 AM [leader-writer-59] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:58,407 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:58,407 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - leader: journal closed 01:11:58,407 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:58,407 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:58,407 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leaderCollector165] 01:11:58,408 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/collector166#-877585167] 01:11:58,409 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower162] 01:11:58,409 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EnabledRaftStorage - follower: terminating thread VirtualThread[#325,follower-writer-60]/waiting 01:11:58,409 AM [follower-writer-60] [DEBUG] JournalWriteTask - follower: received 1 commands after 589.5 ms 01:11:58,410 AM [follower-writer-60] [DEBUG] JournalWriteTask - follower: completed 1 commands in 172.1 μs 01:11:58,410 AM [follower-writer-60] [DEBUG] JournalWriteTask - follower: journal writer stopped 01:11:58,410 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - follower: journal closed 01:11:58,410 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - follower: journal closed 01:11:58,410 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower: stopped executor with 0 remaining tasks 01:11:58,410 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower: stopped executor with 0 remaining tasks 01:11:58,411 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/collector167#-1238371180] 01:11:58,411 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower2163] 01:11:58,411 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EnabledRaftStorage - follower2: terminating thread VirtualThread[#326,follower2-writer-61]/waiting 01:11:58,411 AM [follower2-writer-61] [DEBUG] JournalWriteTask - follower2: received 1 commands after 585.8 ms 01:11:58,412 AM [follower2-writer-61] [DEBUG] JournalWriteTask - follower2: completed 1 commands in 31.29 μs 01:11:58,412 AM [follower2-writer-61] [DEBUG] JournalWriteTask - follower2: journal writer stopped 01:11:58,412 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - follower2: journal closed 01:11:58,412 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - follower2: journal closed 01:11:58,412 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower2: stopped executor with 0 remaining tasks 01:11:58,412 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower2: stopped executor with 0 remaining tasks 01:11:58,420 AM [main] [INFO] RaftActorVotingConfigSupportTest - testOnApplyState starting 01:11:58,420 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] MockRaftActor - Actor created TestActor[pekko://test/user/leader169] [WARN] [02/28/2026 01:11:58.420] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader169]: org.opendaylight.controller.cluster.common.actor.Monitor@20eece8 01:11:58,421 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:58,422 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: started executor 01:11:58,422 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: started executor 01:11:58,422 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:58,423 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:58,423 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:58,423 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:58,423 AM [leader-writer-62] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:58,423 AM [leader-writer-62] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:58,423 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - /tmp/junit-827867964690555047/leader/TermInfo.properties does not exist 01:11:58,430 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=0, votedFor=null 01:11:58,430 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=0} 01:11:58,430 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-827867964690555047/leader/TermInfo.properties 01:11:58,430 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-827867964690555047/leader/journal-v1-1.log 01:11:58,430 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-827867964690555047/leader/metadata-v1-1.log 01:11:58,430 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: no eligible files found 01:11:58,430 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:58,431 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - leader: Recovery completed in in 7.250 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:58,431 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:58,431 AM [main] [INFO] RaftActorVotingConfigSupportTest - testOnApplyState ending 01:11:58,431 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower168] 01:11:58,432 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader169] 01:11:58,432 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#330,leader-writer-62]/waiting 01:11:58,432 AM [leader-writer-62] [DEBUG] JournalWriteTask - leader: received 1 commands after 9.178 ms 01:11:58,432 AM [leader-writer-62] [DEBUG] JournalWriteTask - leader: completed 1 commands in 22.59 μs 01:11:58,433 AM [leader-writer-62] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:58,433 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:58,433 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - leader: journal closed 01:11:58,433 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:58,433 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:58,437 AM [main] [INFO] RaftActorVotingConfigSupportTest - testRemoveServer starting 01:11:58,438 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupportTest$MockLeaderRaftActor - Actor created TestActor[pekko://test/user/leader173] [WARN] [02/28/2026 01:11:58.438] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader173]: org.opendaylight.controller.cluster.common.actor.Monitor@601744f4 01:11:58,439 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:58,439 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:58,439 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: started executor 01:11:58,439 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: started executor 01:11:58,440 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:58,441 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:58,441 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:58,441 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:58,441 AM [leader-writer-63] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:58,441 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - /tmp/junit-18273718707389402359/leader/TermInfo.properties does not exist 01:11:58,441 AM [leader-writer-63] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:58,444 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:58,444 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=1, votedFor=} 01:11:58,444 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-18273718707389402359/leader/TermInfo.properties 01:11:58,444 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-18273718707389402359/leader/journal-v1-1.log 01:11:58,444 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-18273718707389402359/leader/metadata-v1-1.log 01:11:58,444 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: no eligible files found 01:11:58,444 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:58,444 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - leader: Recovery completed in in 2.821 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:58,444 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:58,444 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Election: Leader has following peers: [follower2, follower, downNode] 01:11:58,444 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower2: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 [WARN] [02/28/2026 01:11:58.444] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/follower2172] received dead letter from TestActor[pekko://test/user/leader173]: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]} 01:11:58,444 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 [WARN] [02/28/2026 01:11:58.444] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/follower171] received dead letter from TestActor[pekko://test/user/leader173]: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]} 01:11:58,445 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower downNode: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 [WARN] [02/28/2026 01:11:58.445] [test-pekko.actor.default-dispatcher-16] [pekko://test/] unhandled message from TestActor[pekko://test/user/leader173]: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]} 01:11:58,446 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupportTest$CollectingMockRaftActor - Actor created TestActor[pekko://test/user/follower171] [WARN] [02/28/2026 01:11:58.447] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/follower171]: org.opendaylight.controller.cluster.common.actor.Monitor@1bf6447e 01:11:58,448 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActor - follower: Starting recovery with journal batch size 1000 01:11:58,448 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower: started executor 01:11:58,448 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower: started executor 01:11:58,449 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - follower: metadata journal open: replayFrom=1 applyTo=0 01:11:58,450 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - follower: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:58,450 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - follower: journal open: applyTo=0 01:11:58,450 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - follower: recovering to non-persistent 01:11:58,450 AM [follower-writer-64] [DEBUG] JournalWriteTask - follower: journal writer started 01:11:58,450 AM [follower-writer-64] [DEBUG] JournalWriteTask - follower: waiting to receive commands 01:11:58,450 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - /tmp/junit-18273718707389402359/follower/TermInfo.properties does not exist 01:11:58,457 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower: Set currentTerm=0, votedFor=null 01:11:58,458 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - follower: Local TermInfo store seeded with TermInfo{term=0} 01:11:58,458 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-18273718707389402359/follower/TermInfo.properties 01:11:58,458 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-18273718707389402359/follower/journal-v1-1.log 01:11:58,458 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-18273718707389402359/follower/metadata-v1-1.log 01:11:58,458 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower: no eligible files found 01:11:58,458 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - follower: Moving last applied index from -1 to -1 01:11:58,458 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - follower: Recovery completed in in 7.410 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:58,458 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - follower: Recovery completed and can restore from snapshot 01:11:58,459 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupportTest$CollectingMockRaftActor - Actor created TestActor[pekko://test/user/follower2172] [WARN] [02/28/2026 01:11:58.460] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/follower2172]: org.opendaylight.controller.cluster.common.actor.Monitor@48512de5 01:11:58,460 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActor - follower2: Starting recovery with journal batch size 1000 01:11:58,460 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower2: started executor 01:11:58,460 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower2: started executor 01:11:58,461 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - follower2: metadata journal open: replayFrom=1 applyTo=0 01:11:58,461 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - follower2: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:58,461 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - follower2: journal open: applyTo=0 01:11:58,461 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - follower2: recovering to non-persistent 01:11:58,461 AM [follower2-writer-65] [DEBUG] JournalWriteTask - follower2: journal writer started 01:11:58,461 AM [follower2-writer-65] [DEBUG] JournalWriteTask - follower2: waiting to receive commands 01:11:58,462 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - /tmp/junit-18273718707389402359/follower2/TermInfo.properties does not exist 01:11:58,464 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower2: Set currentTerm=0, votedFor=null 01:11:58,464 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - follower2: Local TermInfo store seeded with TermInfo{term=0} 01:11:58,464 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-18273718707389402359/follower2/TermInfo.properties 01:11:58,464 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-18273718707389402359/follower2/journal-v1-1.log 01:11:58,464 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-18273718707389402359/follower2/metadata-v1-1.log 01:11:58,464 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower2: no eligible files found 01:11:58,464 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - follower2: Moving last applied index from -1 to -1 01:11:58,464 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - follower2: Recovery completed in in 2.733 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:58,464 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - follower2: Recovery completed and can restore from snapshot 01:11:58,466 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: onRemoveServer: RemoveServer{serverId='follower'}, state: Idle 01:11:58,466 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: New server configuration : [ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=downNode, isVoting=true], ServerInfo[peerId=leader, isVoting=true]] 01:11:58,466 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - leader: Persist data index=0 term=1 command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=downNode, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,466 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] ReplicatedLogImpl - leader: Append log entry and persist JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=downNode, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:58,466 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Replicate message: identifier: ServerOperationContextIdentifier{value=1fac60b7-7683-4c00-8e0b-854939e4229c}, logIndex: 0, isSendImmediate: true 01:11:58,466 AM [leader-%d245599] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-18273718707389402359/leader/snapshot-0000000069A240DE-1BCF8DDC.tmp 01:11:58,466 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower2: active: false, followerNextIndex: -1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:58,466 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower downNode: active: false, followerNextIndex: -1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:58,467 AM [test-pekko.actor.default-dispatcher-15] [INFO] Follower - follower2 (Follower): Term 1 in "AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 0 - updating term 01:11:58,467 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupport - leader: Returning OK for operation RemoveServer{serverId='follower'} [WARN] [02/28/2026 01:11:58.467] [test-pekko.actor.default-dispatcher-16] [pekko://test/] unhandled message from TestActor[pekko://test/user/leader173]: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]} 01:11:58,469 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - follower2: Set currentTerm=1, votedFor=null 01:11:58,469 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SyncStatusTracker - follower2: Last sync leader does not match current leader leader, need to catch up to -1 01:11:58,469 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for follower2 updated: matchIndex: -1, nextIndex: 0 01:11:58,469 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower2: active: true, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:58,469 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower follower2 01:11:58,469 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower follower2: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=downNode, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:58,470 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower2 (Follower): handleAppendEntries: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=downNode, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} [WARN] [02/28/2026 01:11:58.470] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/follower2172] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=follower2, initialSyncDone=false] 01:11:58,470 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower2 (Follower): Number of entries to be appended = 1 01:11:58,470 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower2 (Follower): After cleanup, lastIndex: -1, entries to be added from: 0 01:11:58,470 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower2 (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=downNode, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,470 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] ReplicatedLogImpl - follower2: Append log entry and persist JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=downNode, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:58,470 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] PeerInfos - follower2: Updated server config: isVoting: true, peers: [PeerInfo [id=leader, address=pekko://test/user/leader173, votingState=VOTING], PeerInfo [id=downNode, address=, votingState=VOTING]] 01:11:58,470 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower2 (Follower): Log size is now 1 01:11:58,470 AM [leader-%d245599] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-18273718707389402359/leader/snapshot-0000000069A240DE-1BCF8DDC.v1 01:11:58,470 AM [follower2-%d800389] [DEBUG] RaftStorage - follower2: starting snapshot writeout to /tmp/junit-18273718707389402359/follower2/snapshot-0000000069A240DE-1C07FF64.tmp 01:11:58,470 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower2 (Follower): handleAppendEntries returning : AppendEntriesReply{term=1, success=true, followerId=follower2, logLastIndex=0, logLastTerm=1, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:58,470 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SyncStatusTracker - follower2: Lagging 0 entries behind leader leader and reached -1 (of expected -1) 01:11:58,470 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - follower2: awaiting more completions to resolve 1 synchronized callback(s) 01:11:58,470 AM [leader-%d245599] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-18273718707389402359/leader/snapshot-0000000069A240DE-1BCF8DDC.v1 01:11:58,470 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for follower2 updated: matchIndex: 0, nextIndex: 1 01:11:58,470 AM [leader-%d245599] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-18273718707389402359/leader/TermInfo.properties 01:11:58,470 AM [leader-%d245599] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-18273718707389402359/leader/journal-v1-1.log 01:11:58,470 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower2: active: true, followerNextIndex: 1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:58,471 AM [leader-%d245599] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-18273718707389402359/leader/metadata-v1-1.log 01:11:58,471 AM [leader-%d245599] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.466587100Z, file=/tmp/junit-18273718707389402359/leader/snapshot-0000000069A240DE-1BCF8DDC.v1, size=96, entryCompress=NONE, stateCompress=NONE} 01:11:58,471 AM [leader-%d245599] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:58,471 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:58,471 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] ReplicatedLogImpl - leader: persist complete JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=downNode, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:58,471 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractLeader - leader (Leader): Applying to log - commitIndex: 0, lastAppliedIndex: -1 01:11:58,471 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - leader (Leader): Setting last applied to 0 01:11:58,471 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to 0 01:11:58,471 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - leader: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=downNode, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,471 AM [test-pekko.actor.default-dispatcher-15] [INFO] RaftActorVotingConfigSupport - leader: VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=downNode, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} has been successfully replicated to a majority of followers [WARN] [02/28/2026 01:11:58.471] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/follower171] unhandled message from TestActor[pekko://test/user/leader173]: ServerRemoved [serverId=follower] 01:11:58,472 AM [follower2-%d800389] [DEBUG] RaftStorage - follower2: finished snapshot writeout to /tmp/junit-18273718707389402359/follower2/snapshot-0000000069A240DE-1C07FF64.v1 01:11:58,472 AM [follower2-%d800389] [DEBUG] RaftStorage - follower2: selected SNAPSHOT_V1 to handle file /tmp/junit-18273718707389402359/follower2/snapshot-0000000069A240DE-1C07FF64.v1 01:11:58,472 AM [follower2-%d800389] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-18273718707389402359/follower2/TermInfo.properties 01:11:58,472 AM [follower2-%d800389] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-18273718707389402359/follower2/journal-v1-1.log 01:11:58,472 AM [follower2-%d800389] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-18273718707389402359/follower2/metadata-v1-1.log 01:11:58,472 AM [follower2-%d800389] [DEBUG] RaftStorage - follower2: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.470286180Z, file=/tmp/junit-18273718707389402359/follower2/snapshot-0000000069A240DE-1C07FF64.v1, size=96, entryCompress=NONE, stateCompress=NONE} 01:11:58,473 AM [follower2-%d800389] [DEBUG] RaftStorageCompleter - follower2: 1 completion(s) pending 01:11:58,473 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - follower2: running 1 completion(s) 01:11:58,473 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] ReplicatedLogImpl - follower2: persist complete JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=downNode, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false} 01:11:58,473 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - follower2: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=downNode, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@383d049a} 01:11:58,473 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftStorageCompleter - follower2: synchronized callbacks after 2.669 ms [WARN] [02/28/2026 01:11:58.473] [test-pekko.actor.default-dispatcher-13] [pekko://test/user/follower2172] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=follower2, initialSyncDone=true] [WARN] [02/28/2026 01:11:58.556] [test-pekko.actor.default-dispatcher-5] [pekko://test/] unhandled message from TestActor[pekko://test/user/leader173]: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]} 01:11:58,676 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower2 (Follower): Commit index set to 0 01:11:58,677 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] SyncStatusTracker - follower2: Lagging 0 entries behind leader leader and reached 0 (of expected -1) 01:11:58,677 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] Follower - follower2 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 0, context.getLastApplied(): -1, lastIndex(): 0 01:11:58,677 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActorBehavior - follower2 (Follower): Setting last applied to 0 01:11:58,677 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] AbstractReplicatedLog - follower2: Moving last applied index from -1 to 0 01:11:58,677 AM [test-pekko.actor.default-dispatcher-13] [DEBUG] RaftActor - follower2: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=true], ServerInfo[peerId=downNode, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} [WARN] [02/28/2026 01:11:58.677] [test-pekko.actor.default-dispatcher-5] [pekko://test/] unhandled message from TestActor[pekko://test/user/leader173]: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]} 01:11:58,719 AM [main] [INFO] RaftActorVotingConfigSupportTest - testRemoveServer ending 01:11:58,719 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower170] 01:11:58,731 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader173] 01:11:58,731 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#331,leader-writer-63]/waiting 01:11:58,732 AM [leader-writer-63] [DEBUG] JournalWriteTask - leader: received 1 commands after 290.6 ms 01:11:58,732 AM [leader-writer-63] [DEBUG] JournalWriteTask - leader: completed 1 commands in 49.45 μs 01:11:58,732 AM [leader-writer-63] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:58,732 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:58,732 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - leader: journal closed 01:11:58,732 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:58,732 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:58,733 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leaderCollector174] 01:11:58,734 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/collector175#-697977159] 01:11:58,734 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower171] 01:11:58,734 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EnabledRaftStorage - follower: terminating thread VirtualThread[#332,follower-writer-64]/waiting 01:11:58,734 AM [follower-writer-64] [DEBUG] JournalWriteTask - follower: received 1 commands after 283.8 ms 01:11:58,734 AM [follower-writer-64] [DEBUG] JournalWriteTask - follower: completed 1 commands in 18.72 μs 01:11:58,734 AM [follower-writer-64] [DEBUG] JournalWriteTask - follower: journal writer stopped 01:11:58,734 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - follower: journal closed 01:11:58,734 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - follower: journal closed 01:11:58,734 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower: stopped executor with 0 remaining tasks 01:11:58,735 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower: stopped executor with 0 remaining tasks 01:11:58,735 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/collector176#-510070935] 01:11:58,735 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower2172] 01:11:58,735 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EnabledRaftStorage - follower2: terminating thread VirtualThread[#333,follower2-writer-65]/waiting 01:11:58,735 AM [follower2-writer-65] [DEBUG] JournalWriteTask - follower2: received 1 commands after 273.9 ms 01:11:58,735 AM [follower2-writer-65] [DEBUG] JournalWriteTask - follower2: completed 1 commands in 18.22 μs 01:11:58,736 AM [follower2-writer-65] [DEBUG] JournalWriteTask - follower2: journal writer stopped 01:11:58,736 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - follower2: journal closed 01:11:58,736 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - follower2: journal closed 01:11:58,736 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower2: stopped executor with 0 remaining tasks 01:11:58,736 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - follower2: stopped executor with 0 remaining tasks 01:11:58,742 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithNoLeader starting 01:11:58,744 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActorVotingConfigSupportTest$MockNewFollowerRaftActor - Actor created TestActor[pekko://test/user/new-server179] [WARN] [02/28/2026 01:11:58.744] [test-pekko.actor.default-dispatcher-14] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/new-server179]: org.opendaylight.controller.cluster.common.actor.Monitor@44ab50b 01:11:58,745 AM [test-pekko.actor.default-dispatcher-5] [INFO] RaftActor - new-server: Starting recovery with journal batch size 1000 01:11:58,745 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: started executor 01:11:58,745 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: started executor 01:11:58,746 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - new-server: metadata journal open: replayFrom=1 applyTo=0 01:11:58,746 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] EntryJournalV1 - new-server: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:58,746 AM [test-pekko.actor.default-dispatcher-5] [INFO] EnabledRaftStorage - new-server: journal open: applyTo=0 01:11:58,746 AM [new-server-writer-66] [DEBUG] JournalWriteTask - new-server: journal writer started 01:11:58,746 AM [new-server-writer-66] [DEBUG] JournalWriteTask - new-server: waiting to receive commands 01:11:58,747 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - new-server: recovering to non-persistent 01:11:58,747 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - /tmp/junit-14365542442946776895/new-server/TermInfo.properties does not exist 01:11:58,750 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=0, votedFor=null 01:11:58,750 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - new-server: Local TermInfo store seeded with TermInfo{term=0} 01:11:58,750 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-14365542442946776895/new-server/TermInfo.properties 01:11:58,750 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-14365542442946776895/new-server/journal-v1-1.log 01:11:58,750 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-14365542442946776895/new-server/metadata-v1-1.log 01:11:58,750 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftStorage - new-server: no eligible files found 01:11:58,750 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] AbstractReplicatedLog - new-server: Moving last applied index from -1 to -1 01:11:58,750 AM [test-pekko.actor.default-dispatcher-5] [INFO] Recovery - new-server: Recovery completed in in 3.679 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:58,750 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] RaftActor - new-server: Recovery completed and can restore from snapshot 01:11:58,751 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] MockRaftActor - Actor created TestActor[pekko://test/user/leader180] [WARN] [02/28/2026 01:11:58.751] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader180]: org.opendaylight.controller.cluster.common.actor.Monitor@3f158df8 01:11:58,752 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:58,753 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: started executor 01:11:58,753 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: started executor 01:11:58,754 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:58,754 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:58,754 AM [test-pekko.actor.default-dispatcher-14] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:58,754 AM [leader-writer-67] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:58,754 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:58,754 AM [leader-writer-67] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:58,755 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - /tmp/junit-14365542442946776895/leader/TermInfo.properties does not exist 01:11:58,757 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=0, votedFor=null 01:11:58,757 AM [test-pekko.actor.default-dispatcher-14] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=0} 01:11:58,757 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-14365542442946776895/leader/TermInfo.properties 01:11:58,757 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-14365542442946776895/leader/journal-v1-1.log 01:11:58,757 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-14365542442946776895/leader/metadata-v1-1.log 01:11:58,757 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: no eligible files found 01:11:58,757 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:58,758 AM [test-pekko.actor.default-dispatcher-14] [INFO] Recovery - leader: Recovery completed in in 2.969 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:58,758 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:58,769 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - leader: onAddServer: AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server179, votingMember=true], state: Idle 01:11:58,769 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - leader: No leader - returning NO_LEADER reply 01:11:58,769 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithNoLeader ending 01:11:58,770 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower177] 01:11:58,781 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/new-serverCollector178#265927668] 01:11:58,781 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/new-server179] 01:11:58,781 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EnabledRaftStorage - new-server: terminating thread VirtualThread[#336,new-server-writer-66]/waiting 01:11:58,782 AM [new-server-writer-66] [DEBUG] JournalWriteTask - new-server: received 1 commands after 35.12 ms 01:11:58,782 AM [new-server-writer-66] [DEBUG] JournalWriteTask - new-server: completed 1 commands in 32.89 μs 01:11:58,782 AM [new-server-writer-66] [DEBUG] JournalWriteTask - new-server: journal writer stopped 01:11:58,782 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EntryJournalV1 - new-server: journal closed 01:11:58,782 AM [test-pekko.actor.default-dispatcher-14] [INFO] EnabledRaftStorage - new-server: journal closed 01:11:58,782 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:58,782 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:58,783 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader180] 01:11:58,783 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#337,leader-writer-67]/waiting 01:11:58,783 AM [leader-writer-67] [DEBUG] JournalWriteTask - leader: received 1 commands after 28.35 ms 01:11:58,783 AM [leader-writer-67] [DEBUG] JournalWriteTask - leader: completed 1 commands in 16.76 μs 01:11:58,783 AM [leader-writer-67] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:58,783 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:58,783 AM [test-pekko.actor.default-dispatcher-14] [INFO] EnabledRaftStorage - leader: journal closed 01:11:58,783 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:58,783 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:58,790 AM [main] [INFO] RaftActorVotingConfigSupportTest - testChangeServersVotingStatus starting 01:11:58,791 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupportTest$MockLeaderRaftActor - Actor created TestActor[pekko://test/user/leader184] [WARN] [02/28/2026 01:11:58.792] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader184]: org.opendaylight.controller.cluster.common.actor.Monitor@7495f1dc 01:11:58,793 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:58,793 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:58,793 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: started executor 01:11:58,793 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: started executor 01:11:58,794 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:58,794 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:58,794 AM [test-pekko.actor.default-dispatcher-14] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:58,794 AM [leader-writer-68] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:58,794 AM [leader-writer-68] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:58,794 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:58,794 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - /tmp/junit-4318202186784824719/leader/TermInfo.properties does not exist 01:11:58,797 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:58,797 AM [test-pekko.actor.default-dispatcher-14] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=1, votedFor=} 01:11:58,797 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-4318202186784824719/leader/TermInfo.properties 01:11:58,797 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-4318202186784824719/leader/journal-v1-1.log 01:11:58,797 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-4318202186784824719/leader/metadata-v1-1.log 01:11:58,797 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: no eligible files found 01:11:58,797 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:58,798 AM [test-pekko.actor.default-dispatcher-14] [INFO] Recovery - leader: Recovery completed in in 3.130 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:58,798 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:58,798 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader (Leader): Election: Leader has following peers: [follower2, follower] 01:11:58,798 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower2: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 [WARN] [02/28/2026 01:11:58.798] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/follower2183] received dead letter from TestActor[pekko://test/user/leader184]: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]} 01:11:58,798 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 [WARN] [02/28/2026 01:11:58.798] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/follower182] received dead letter from TestActor[pekko://test/user/leader184]: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]} 01:11:58,802 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupportTest$CollectingMockRaftActor - Actor created TestActor[pekko://test/user/follower182] [WARN] [02/28/2026 01:11:58.803] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/follower182]: org.opendaylight.controller.cluster.common.actor.Monitor@121d1a1c 01:11:58,803 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActor - follower: Starting recovery with journal batch size 1000 01:11:58,803 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - follower: started executor 01:11:58,803 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - follower: started executor 01:11:58,804 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EntryJournalV1 - follower: metadata journal open: replayFrom=1 applyTo=0 01:11:58,804 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EntryJournalV1 - follower: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:58,804 AM [test-pekko.actor.default-dispatcher-14] [INFO] EnabledRaftStorage - follower: journal open: applyTo=0 01:11:58,804 AM [follower-writer-69] [DEBUG] JournalWriteTask - follower: journal writer started 01:11:58,804 AM [follower-writer-69] [DEBUG] JournalWriteTask - follower: waiting to receive commands 01:11:58,804 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - follower: recovering to non-persistent 01:11:58,804 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - /tmp/junit-4318202186784824719/follower/TermInfo.properties does not exist 01:11:58,812 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - follower: Set currentTerm=0, votedFor=null 01:11:58,812 AM [test-pekko.actor.default-dispatcher-14] [INFO] Recovery - follower: Local TermInfo store seeded with TermInfo{term=0} 01:11:58,812 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-4318202186784824719/follower/TermInfo.properties 01:11:58,812 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-4318202186784824719/follower/journal-v1-1.log 01:11:58,812 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-4318202186784824719/follower/metadata-v1-1.log 01:11:58,812 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - follower: no eligible files found 01:11:58,812 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractReplicatedLog - follower: Moving last applied index from -1 to -1 01:11:58,812 AM [test-pekko.actor.default-dispatcher-14] [INFO] Recovery - follower: Recovery completed in in 7.821 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:58,812 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - follower: Recovery completed and can restore from snapshot 01:11:58,815 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupportTest$CollectingMockRaftActor - Actor created TestActor[pekko://test/user/follower2183] [WARN] [02/28/2026 01:11:58.816] [test-pekko.actor.default-dispatcher-5] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/follower2183]: org.opendaylight.controller.cluster.common.actor.Monitor@7c18f517 01:11:58,817 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActor - follower2: Starting recovery with journal batch size 1000 01:11:58,817 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - follower2: started executor 01:11:58,817 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - follower2: started executor 01:11:58,817 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EntryJournalV1 - follower2: metadata journal open: replayFrom=1 applyTo=0 01:11:58,818 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EntryJournalV1 - follower2: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:58,818 AM [test-pekko.actor.default-dispatcher-14] [INFO] EnabledRaftStorage - follower2: journal open: applyTo=0 01:11:58,818 AM [follower2-writer-70] [DEBUG] JournalWriteTask - follower2: journal writer started 01:11:58,818 AM [follower2-writer-70] [DEBUG] JournalWriteTask - follower2: waiting to receive commands 01:11:58,819 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - follower2: recovering to non-persistent 01:11:58,819 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - /tmp/junit-4318202186784824719/follower2/TermInfo.properties does not exist 01:11:58,821 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - follower2: Set currentTerm=0, votedFor=null 01:11:58,821 AM [test-pekko.actor.default-dispatcher-14] [INFO] Recovery - follower2: Local TermInfo store seeded with TermInfo{term=0} 01:11:58,821 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-4318202186784824719/follower2/TermInfo.properties 01:11:58,821 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-4318202186784824719/follower2/journal-v1-1.log 01:11:58,821 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-4318202186784824719/follower2/metadata-v1-1.log 01:11:58,821 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - follower2: no eligible files found 01:11:58,821 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractReplicatedLog - follower2: Moving last applied index from -1 to -1 01:11:58,821 AM [test-pekko.actor.default-dispatcher-14] [INFO] Recovery - follower2: Recovery completed in in 2.788 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:58,821 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - follower2: Recovery completed and can restore from snapshot 01:11:58,823 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - leader: onChangeServersVotingStatus: ChangeServersVotingStatus [serverVotingStatusMap={follower2=false, follower=false}, serversVisited=[]], state: Idle 01:11:58,823 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - Initiating ChangeServersVotingStatusState 01:11:58,823 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PeerInfos - leader: Updated server config: isVoting: true, peers: [PeerInfo [id=follower2, address=pekko://test/user/follower2183, votingState=NON_VOTING], PeerInfo [id=follower, address=pekko://test/user/follower182, votingState=NON_VOTING]] 01:11:58,823 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - leader: New server configuration : [ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]] 01:11:58,823 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader: Persist data index=0 term=1 command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,823 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - leader: Append log entry and persist JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:58,823 AM [leader-%d940014] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-4318202186784824719/leader/snapshot-0000000069A240DE-3119B374.tmp 01:11:58,824 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader (Leader): Replicate message: identifier: ServerOperationContextIdentifier{value=cb316c02-5224-4a58-ae63-fb9776afcbc4}, logIndex: 0, isSendImmediate: true 01:11:58,824 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorBehavior - leader (Leader): Setting last applied to 0 01:11:58,824 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to 0 01:11:58,824 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,824 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower2: active: false, followerNextIndex: -1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:58,824 AM [test-pekko.actor.default-dispatcher-5] [INFO] Follower - follower2 (Follower): Term 1 in "AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 0 - updating term 01:11:58,824 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: false, followerNextIndex: -1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:58,825 AM [test-pekko.actor.default-dispatcher-15] [INFO] Follower - follower (Follower): Term 1 in "AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 0 - updating term 01:11:58,825 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - leader: Returning OK for operation ChangeServersVotingStatus [serverVotingStatusMap={follower2=false, follower=false}, serversVisited=[]] 01:11:58,825 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActorVotingConfigSupport - leader: VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} has been successfully replicated to a majority of followers 01:11:58,826 AM [leader-%d940014] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-4318202186784824719/leader/snapshot-0000000069A240DE-3119B374.v1 01:11:58,826 AM [leader-%d940014] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-4318202186784824719/leader/snapshot-0000000069A240DE-3119B374.v1 01:11:58,826 AM [leader-%d940014] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-4318202186784824719/leader/TermInfo.properties 01:11:58,826 AM [leader-%d940014] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-4318202186784824719/leader/journal-v1-1.log 01:11:58,826 AM [leader-%d940014] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-4318202186784824719/leader/metadata-v1-1.log 01:11:58,826 AM [leader-%d940014] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.823767924Z, file=/tmp/junit-4318202186784824719/leader/snapshot-0000000069A240DE-3119B374.v1, size=96, entryCompress=NONE, stateCompress=NONE} 01:11:58,827 AM [leader-%d940014] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:58,827 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:58,827 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - leader: persist complete JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:58,827 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - follower: Set currentTerm=1, votedFor=null 01:11:58,827 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SyncStatusTracker - follower: Last sync leader does not match current leader leader, need to catch up to -1 01:11:58,827 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for follower updated: matchIndex: -1, nextIndex: 0 01:11:58,827 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: true, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:58,827 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower follower 01:11:58,827 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower follower: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}]} 01:11:58,827 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] PropertiesTermInfoStore - follower2: Set currentTerm=1, votedFor=null 01:11:58,828 AM [test-pekko.actor.default-dispatcher-5] [DEBUG] SyncStatusTracker - follower2: Last sync leader does not match current leader leader, need to catch up to -1 [WARN] [02/28/2026 01:11:58.827] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/follower182] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=follower, initialSyncDone=false] [WARN] [02/28/2026 01:11:58.828] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/follower2183] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=follower2, initialSyncDone=false] 01:11:58,828 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for follower2 updated: matchIndex: -1, nextIndex: 0 01:11:58,828 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower2: active: true, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:58,828 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 0 is present for follower follower2 01:11:58,828 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower follower2: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}]} 01:11:58,828 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower (Follower): handleAppendEntries: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}]} 01:11:58,828 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower (Follower): Number of entries to be appended = 1 01:11:58,828 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - follower2 (Follower): handleAppendEntries: AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}]} 01:11:58,828 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower (Follower): After cleanup, lastIndex: -1, entries to be added from: 0 01:11:58,828 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - follower2 (Follower): Number of entries to be appended = 1 01:11:58,828 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,828 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - follower2 (Follower): After cleanup, lastIndex: -1, entries to be added from: 0 01:11:58,828 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - follower: Append log entry and persist JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false} 01:11:58,828 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - follower2 (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,828 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] ReplicatedLogImpl - follower2: Append log entry and persist JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false} 01:11:58,828 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PeerInfos - follower2: Updated server config: isVoting: false, peers: [PeerInfo [id=leader, address=pekko://test/user/leader184, votingState=VOTING], PeerInfo [id=follower, address=pekko://test/user/follower182, votingState=NON_VOTING]] 01:11:58,829 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - follower2 (Follower): Log size is now 1 01:11:58,829 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - follower2 (Follower): Commit index set to 0 01:11:58,829 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - follower2 (Follower): handleAppendEntries returning : AppendEntriesReply{term=1, success=true, followerId=follower2, logLastIndex=0, logLastTerm=1, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:58,829 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SyncStatusTracker - follower2: Lagging 0 entries behind leader leader and reached 0 (of expected -1) 01:11:58,829 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] Follower - follower2 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 0, context.getLastApplied(): -1, lastIndex(): 0 01:11:58,829 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorBehavior - follower2 (Follower): Setting last applied to 0 01:11:58,829 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - follower2: Moving last applied index from -1 to 0 01:11:58,829 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for follower2 updated: matchIndex: 0, nextIndex: 1 01:11:58,829 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - follower2: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,829 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower2: active: true, followerNextIndex: 1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:58,829 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorageCompleter - follower2: awaiting more completions to resolve 1 synchronized callback(s) 01:11:58,829 AM [follower2-%d421999] [DEBUG] RaftStorage - follower2: starting snapshot writeout to /tmp/junit-4318202186784824719/follower2/snapshot-0000000069A240DE-316854EC.tmp 01:11:58,829 AM [follower-%d718471] [DEBUG] RaftStorage - follower: starting snapshot writeout to /tmp/junit-4318202186784824719/follower/snapshot-0000000069A240DE-316D2950.tmp 01:11:58,830 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PeerInfos - follower: Updated server config: isVoting: false, peers: [PeerInfo [id=leader, address=pekko://test/user/leader184, votingState=VOTING], PeerInfo [id=follower2, address=pekko://test/user/follower2183, votingState=NON_VOTING]] 01:11:58,830 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower (Follower): Log size is now 1 01:11:58,830 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower (Follower): Commit index set to 0 01:11:58,830 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower (Follower): handleAppendEntries returning : AppendEntriesReply{term=1, success=true, followerId=follower, logLastIndex=0, logLastTerm=1, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:58,830 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SyncStatusTracker - follower: Lagging 0 entries behind leader leader and reached 0 (of expected -1) 01:11:58,830 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 0, context.getLastApplied(): -1, lastIndex(): 0 01:11:58,830 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorBehavior - follower (Follower): Setting last applied to 0 01:11:58,830 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractReplicatedLog - follower: Moving last applied index from -1 to 0 01:11:58,830 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - follower: Applying state for log index 0 data VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,830 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for follower updated: matchIndex: 0, nextIndex: 1 01:11:58,830 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: true, followerNextIndex: 1, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:11:58,830 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - follower: awaiting more completions to resolve 1 synchronized callback(s) 01:11:58,831 AM [follower2-%d421999] [DEBUG] RaftStorage - follower2: finished snapshot writeout to /tmp/junit-4318202186784824719/follower2/snapshot-0000000069A240DE-316854EC.v1 01:11:58,831 AM [follower2-%d421999] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-4318202186784824719/follower2/TermInfo.properties 01:11:58,832 AM [follower2-%d421999] [DEBUG] RaftStorage - follower2: selected SNAPSHOT_V1 to handle file /tmp/junit-4318202186784824719/follower2/snapshot-0000000069A240DE-316854EC.v1 01:11:58,832 AM [follower2-%d421999] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-4318202186784824719/follower2/journal-v1-1.log 01:11:58,832 AM [follower2-%d421999] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-4318202186784824719/follower2/metadata-v1-1.log 01:11:58,832 AM [follower2-%d421999] [DEBUG] RaftStorage - follower2: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.828921068Z, file=/tmp/junit-4318202186784824719/follower2/snapshot-0000000069A240DE-316854EC.v1, size=96, entryCompress=NONE, stateCompress=NONE} 01:11:58,832 AM [follower2-%d421999] [DEBUG] RaftStorageCompleter - follower2: 1 completion(s) pending 01:11:58,832 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorageCompleter - follower2: running 1 completion(s) 01:11:58,832 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] ReplicatedLogImpl - follower2: persist complete JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false} 01:11:58,832 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorageCompleter - follower2: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@4a686628} 01:11:58,832 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorageCompleter - follower2: synchronized callbacks after 3.148 ms 01:11:58,832 AM [follower-%d718471] [DEBUG] RaftStorage - follower: finished snapshot writeout to /tmp/junit-4318202186784824719/follower/snapshot-0000000069A240DE-316D2950.v1 [WARN] [02/28/2026 01:11:58.832] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/follower2183] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=follower2, initialSyncDone=true] 01:11:58,833 AM [follower-%d718471] [DEBUG] RaftStorage - follower: selected SNAPSHOT_V1 to handle file /tmp/junit-4318202186784824719/follower/snapshot-0000000069A240DE-316D2950.v1 01:11:58,833 AM [follower-%d718471] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-4318202186784824719/follower/TermInfo.properties 01:11:58,833 AM [follower-%d718471] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-4318202186784824719/follower/journal-v1-1.log 01:11:58,833 AM [follower-%d718471] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-4318202186784824719/follower/metadata-v1-1.log 01:11:58,833 AM [follower-%d718471] [DEBUG] RaftStorage - follower: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.829237584Z, file=/tmp/junit-4318202186784824719/follower/snapshot-0000000069A240DE-316D2950.v1, size=96, entryCompress=NONE, stateCompress=NONE} 01:11:58,833 AM [follower-%d718471] [DEBUG] RaftStorageCompleter - follower: 1 completion(s) pending 01:11:58,833 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - follower: running 1 completion(s) 01:11:58,833 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - follower: persist complete JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false} 01:11:58,833 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - follower: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=false], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@134e93b0} 01:11:58,833 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - follower: synchronized callbacks after 2.693 ms [WARN] [02/28/2026 01:11:58.834] [test-pekko.actor.default-dispatcher-14] [pekko://test/user/follower182] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=follower, initialSyncDone=true] 01:11:58,876 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorVotingConfigSupport - leader: onChangeServersVotingStatus: ChangeServersVotingStatus [serverVotingStatusMap={follower=true}, serversVisited=[]], state: Idle 01:11:58,877 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorVotingConfigSupport - Initiating ChangeServersVotingStatusState 01:11:58,877 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] PeerInfos - leader: Updated server config: isVoting: true, peers: [PeerInfo [id=follower2, address=pekko://test/user/follower2183, votingState=NON_VOTING], PeerInfo [id=follower, address=pekko://test/user/follower182, votingState=VOTING]] 01:11:58,877 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorVotingConfigSupport - leader: New server configuration : [ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]] 01:11:58,877 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActor - leader: Persist data index=1 term=1 command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,877 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] ReplicatedLogImpl - leader: Append log entry and persist JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:58,877 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractLeader - leader (Leader): Replicate message: identifier: ServerOperationContextIdentifier{value=411d6bf8-a173-44f5-a374-a03799ba54e9}, logIndex: 1, isSendImmediate: true 01:11:58,877 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorBehavior - leader (Leader): Setting last applied to 1 01:11:58,877 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from 0 to 1 01:11:58,877 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActor - leader: Applying state for log index 1 data VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,877 AM [leader-%d940015] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-4318202186784824719/leader/snapshot-0000000069A240DE-344AF322.tmp 01:11:58,877 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower2: active: true, followerNextIndex: 1, leaderLastIndex: 1, leaderSnapShotIndex: -1 01:11:58,877 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 1 is present for follower follower2 01:11:58,877 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower follower2: AppendEntries{term=1, leaderId=leader, prevLogIndex=0, prevLogTerm=1, leaderCommit=1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:58,877 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: true, followerNextIndex: 1, leaderLastIndex: 1, leaderSnapShotIndex: -1 01:11:58,877 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 1 is present for follower follower 01:11:58,877 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower follower: AppendEntries{term=1, leaderId=leader, prevLogIndex=0, prevLogTerm=1, leaderCommit=1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:58,878 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorVotingConfigSupport - leader: Returning OK for operation ChangeServersVotingStatus [serverVotingStatusMap={follower=true}, serversVisited=[]] 01:11:58,878 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower2 (Follower): handleAppendEntries: AppendEntries{term=1, leaderId=leader, prevLogIndex=0, prevLogTerm=1, leaderCommit=1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:58,878 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower2 (Follower): Number of entries to be appended = 1 01:11:58,878 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower2 (Follower): After cleanup, lastIndex: 0, entries to be added from: 0 01:11:58,878 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): handleAppendEntries: AppendEntries{term=1, leaderId=leader, prevLogIndex=0, prevLogTerm=1, leaderCommit=1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:58,878 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower2 (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,878 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - follower2: Append log entry and persist JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:58,878 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): Number of entries to be appended = 1 01:11:58,878 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): After cleanup, lastIndex: 0, entries to be added from: 0 01:11:58,878 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,878 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower: Append log entry and persist JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:58,878 AM [test-pekko.actor.default-dispatcher-6] [INFO] RaftActorVotingConfigSupport - leader: VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} has been successfully replicated to a majority of followers 01:11:58,878 AM [follower2-%d422000] [DEBUG] RaftStorage - follower2: starting snapshot writeout to /tmp/junit-4318202186784824719/follower2/snapshot-0000000069A240DE-345AB06A.tmp 01:11:58,878 AM [follower-%d718472] [DEBUG] RaftStorage - follower: starting snapshot writeout to /tmp/junit-4318202186784824719/follower/snapshot-0000000069A240DE-345DEAD5.tmp 01:11:58,878 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PeerInfos - follower: Updated server config: isVoting: true, peers: [PeerInfo [id=leader, address=pekko://test/user/leader184, votingState=VOTING], PeerInfo [id=follower2, address=pekko://test/user/follower2183, votingState=NON_VOTING]] 01:11:58,878 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): Log size is now 2 01:11:58,878 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): Commit index set to 1 01:11:58,878 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PeerInfos - follower2: Updated server config: isVoting: false, peers: [PeerInfo [id=leader, address=pekko://test/user/leader184, votingState=VOTING], PeerInfo [id=follower, address=pekko://test/user/follower182, votingState=VOTING]] 01:11:58,878 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): handleAppendEntries returning : AppendEntriesReply{term=1, success=true, followerId=follower, logLastIndex=1, logLastTerm=1, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:58,878 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower2 (Follower): Log size is now 2 01:11:58,878 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower2 (Follower): Commit index set to 1 01:11:58,878 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower: Lagging 0 entries behind leader leader and reached 1 (of expected -1) 01:11:58,878 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower2 (Follower): handleAppendEntries returning : AppendEntriesReply{term=1, success=true, followerId=follower2, logLastIndex=1, logLastTerm=1, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:58,878 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 1, context.getLastApplied(): 0, lastIndex(): 1 01:11:58,878 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SyncStatusTracker - follower2: Lagging 0 entries behind leader leader and reached 1 (of expected -1) 01:11:58,878 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - follower (Follower): Setting last applied to 1 01:11:58,878 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower2 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 1, context.getLastApplied(): 0, lastIndex(): 1 01:11:58,878 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - follower: Moving last applied index from 0 to 1 01:11:58,878 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorBehavior - follower2 (Follower): Setting last applied to 1 01:11:58,878 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractReplicatedLog - follower2: Moving last applied index from 0 to 1 01:11:58,878 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower: Applying state for log index 1 data VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,879 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for follower updated: matchIndex: 1, nextIndex: 2 01:11:58,879 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - follower2: Applying state for log index 1 data VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,879 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] SnapshotManager - leader: fakeSnapshot purging log to 0 for term 1 01:11:58,879 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: true, followerNextIndex: 2, leaderLastIndex: 1, leaderSnapShotIndex: 0 01:11:58,879 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - follower2: awaiting more completions to resolve 1 synchronized callback(s) 01:11:58,879 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - follower: awaiting more completions to resolve 1 synchronized callback(s) 01:11:58,879 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for follower2 updated: matchIndex: 1, nextIndex: 2 01:11:58,879 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower2: active: true, followerNextIndex: 2, leaderLastIndex: 1, leaderSnapShotIndex: 0 01:11:58,880 AM [leader-%d940015] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-4318202186784824719/leader/snapshot-0000000069A240DE-344AF322.v1 01:11:58,880 AM [follower2-%d422000] [DEBUG] RaftStorage - follower2: finished snapshot writeout to /tmp/junit-4318202186784824719/follower2/snapshot-0000000069A240DE-345AB06A.v1 01:11:58,880 AM [leader-%d940015] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-4318202186784824719/leader/snapshot-0000000069A240DE-3119B374.v1 01:11:58,880 AM [follower2-%d422000] [DEBUG] RaftStorage - follower2: selected SNAPSHOT_V1 to handle file /tmp/junit-4318202186784824719/follower2/snapshot-0000000069A240DE-345AB06A.v1 01:11:58,881 AM [leader-%d940015] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-4318202186784824719/leader/snapshot-0000000069A240DE-344AF322.v1 01:11:58,881 AM [leader-%d940015] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-4318202186784824719/leader/TermInfo.properties 01:11:58,881 AM [follower2-%d422000] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-4318202186784824719/follower2/TermInfo.properties 01:11:58,881 AM [leader-%d940015] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-4318202186784824719/leader/journal-v1-1.log 01:11:58,881 AM [follower2-%d422000] [DEBUG] RaftStorage - follower2: selected SNAPSHOT_V1 to handle file /tmp/junit-4318202186784824719/follower2/snapshot-0000000069A240DE-316854EC.v1 01:11:58,881 AM [leader-%d940015] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-4318202186784824719/leader/metadata-v1-1.log 01:11:58,881 AM [leader-%d940015] [DEBUG] RaftStorage - leader: deleted snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.823767924Z, file=/tmp/junit-4318202186784824719/leader/snapshot-0000000069A240DE-3119B374.v1, size=96, entryCompress=NONE, stateCompress=NONE} 01:11:58,881 AM [leader-%d940015] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.877327138Z, file=/tmp/junit-4318202186784824719/leader/snapshot-0000000069A240DE-344AF322.v1, size=96, entryCompress=NONE, stateCompress=NONE} 01:11:58,881 AM [leader-%d940015] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:58,881 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:58,881 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] ReplicatedLogImpl - leader: persist complete JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:58,881 AM [follower-%d718472] [DEBUG] RaftStorage - follower: finished snapshot writeout to /tmp/junit-4318202186784824719/follower/snapshot-0000000069A240DE-345DEAD5.v1 01:11:58,881 AM [follower-%d718472] [DEBUG] RaftStorage - follower: selected SNAPSHOT_V1 to handle file /tmp/junit-4318202186784824719/follower/snapshot-0000000069A240DE-316D2950.v1 01:11:58,881 AM [follower-%d718472] [DEBUG] RaftStorage - follower: selected SNAPSHOT_V1 to handle file /tmp/junit-4318202186784824719/follower/snapshot-0000000069A240DE-345DEAD5.v1 01:11:58,881 AM [follower-%d718472] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-4318202186784824719/follower/TermInfo.properties 01:11:58,881 AM [follower-%d718472] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-4318202186784824719/follower/journal-v1-1.log 01:11:58,881 AM [follower-%d718472] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-4318202186784824719/follower/metadata-v1-1.log 01:11:58,882 AM [follower-%d718472] [DEBUG] RaftStorage - follower: deleted snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.829237584Z, file=/tmp/junit-4318202186784824719/follower/snapshot-0000000069A240DE-316D2950.v1, size=96, entryCompress=NONE, stateCompress=NONE} 01:11:58,882 AM [follower-%d718472] [DEBUG] RaftStorage - follower: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.878570197Z, file=/tmp/junit-4318202186784824719/follower/snapshot-0000000069A240DE-345DEAD5.v1, size=96, entryCompress=NONE, stateCompress=NONE} 01:11:58,882 AM [follower-%d718472] [DEBUG] RaftStorageCompleter - follower: 1 completion(s) pending 01:11:58,881 AM [follower2-%d422000] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-4318202186784824719/follower2/journal-v1-1.log 01:11:58,882 AM [follower2-%d422000] [DEBUG] RaftStorage - follower2: skipping unrecognized file /tmp/junit-4318202186784824719/follower2/metadata-v1-1.log 01:11:58,882 AM [follower2-%d422000] [DEBUG] RaftStorage - follower2: deleted snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.828921068Z, file=/tmp/junit-4318202186784824719/follower2/snapshot-0000000069A240DE-316854EC.v1, size=96, entryCompress=NONE, stateCompress=NONE} 01:11:58,882 AM [follower2-%d422000] [DEBUG] RaftStorage - follower2: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.878358634Z, file=/tmp/junit-4318202186784824719/follower2/snapshot-0000000069A240DE-345AB06A.v1, size=96, entryCompress=NONE, stateCompress=NONE} 01:11:58,882 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - follower: running 1 completion(s) 01:11:58,882 AM [follower2-%d422000] [DEBUG] RaftStorageCompleter - follower2: 1 completion(s) pending 01:11:58,882 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - follower: persist complete JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false} 01:11:58,882 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - follower2: running 1 completion(s) 01:11:58,882 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - follower: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@738f477a} 01:11:58,882 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - follower2: persist complete JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false} 01:11:58,882 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - follower2: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=1, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower2, isVoting=false], ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@35bd92a7} 01:11:58,882 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorageCompleter - follower: synchronized callbacks after 3.274 ms 01:11:58,882 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - follower2: synchronized callbacks after 3.394 ms 01:11:58,930 AM [main] [INFO] RaftActorVotingConfigSupportTest - testChangeServersVotingStatus ending 01:11:58,930 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower181] 01:11:58,941 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader184] 01:11:58,942 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#338,leader-writer-68]/waiting 01:11:58,942 AM [leader-writer-68] [DEBUG] JournalWriteTask - leader: received 1 commands after 147.6 ms 01:11:58,942 AM [leader-writer-68] [DEBUG] JournalWriteTask - leader: completed 1 commands in 48.43 μs 01:11:58,942 AM [leader-writer-68] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:58,942 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:58,942 AM [test-pekko.actor.default-dispatcher-6] [INFO] EnabledRaftStorage - leader: journal closed 01:11:58,943 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:58,943 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:58,943 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leaderCollector185] 01:11:58,944 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/collector186#-79677703] 01:11:58,944 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower182] 01:11:58,944 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] EnabledRaftStorage - follower: terminating thread VirtualThread[#339,follower-writer-69]/waiting 01:11:58,944 AM [follower-writer-69] [DEBUG] JournalWriteTask - follower: received 1 commands after 140.1 ms 01:11:58,944 AM [follower-writer-69] [DEBUG] JournalWriteTask - follower: completed 1 commands in 19.43 μs 01:11:58,944 AM [follower-writer-69] [DEBUG] JournalWriteTask - follower: journal writer stopped 01:11:58,944 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] EntryJournalV1 - follower: journal closed 01:11:58,944 AM [test-pekko.actor.default-dispatcher-6] [INFO] EnabledRaftStorage - follower: journal closed 01:11:58,944 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - follower: stopped executor with 0 remaining tasks 01:11:58,944 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - follower: stopped executor with 0 remaining tasks 01:11:58,945 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/collector187#1709118209] 01:11:58,945 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower2183] 01:11:58,945 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] EnabledRaftStorage - follower2: terminating thread VirtualThread[#340,follower2-writer-70]/waiting 01:11:58,945 AM [follower2-writer-70] [DEBUG] JournalWriteTask - follower2: received 1 commands after 127.2 ms 01:11:58,945 AM [follower2-writer-70] [DEBUG] JournalWriteTask - follower2: completed 1 commands in 21.71 μs 01:11:58,945 AM [follower2-writer-70] [DEBUG] JournalWriteTask - follower2: journal writer stopped 01:11:58,946 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] EntryJournalV1 - follower2: journal closed 01:11:58,946 AM [test-pekko.actor.default-dispatcher-6] [INFO] EnabledRaftStorage - follower2: journal closed 01:11:58,946 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - follower2: stopped executor with 0 remaining tasks 01:11:58,946 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - follower2: stopped executor with 0 remaining tasks 01:11:58,951 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithExistingFollower starting 01:11:58,952 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorVotingConfigSupportTest$MockNewFollowerRaftActor - Actor created TestActor[pekko://test/user/new-server190] [WARN] [02/28/2026 01:11:58.953] [test-pekko.actor.default-dispatcher-14] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/new-server190]: org.opendaylight.controller.cluster.common.actor.Monitor@2224212f 01:11:58,953 AM [test-pekko.actor.default-dispatcher-6] [INFO] RaftActor - new-server: Starting recovery with journal batch size 1000 01:11:58,954 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - new-server: started executor 01:11:58,954 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - new-server: started executor 01:11:58,954 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] EntryJournalV1 - new-server: metadata journal open: replayFrom=1 applyTo=0 01:11:58,955 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] EntryJournalV1 - new-server: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:58,955 AM [test-pekko.actor.default-dispatcher-6] [INFO] EnabledRaftStorage - new-server: journal open: applyTo=0 01:11:58,955 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActor - new-server: recovering to non-persistent 01:11:58,955 AM [new-server-writer-71] [DEBUG] JournalWriteTask - new-server: journal writer started 01:11:58,955 AM [new-server-writer-71] [DEBUG] JournalWriteTask - new-server: waiting to receive commands 01:11:58,955 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] PropertiesTermInfoStore - /tmp/junit-15793356145164304984/new-server/TermInfo.properties does not exist 01:11:58,959 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=0, votedFor=null 01:11:58,959 AM [test-pekko.actor.default-dispatcher-6] [INFO] Recovery - new-server: Local TermInfo store seeded with TermInfo{term=0} 01:11:58,959 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-15793356145164304984/new-server/TermInfo.properties 01:11:58,959 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-15793356145164304984/new-server/journal-v1-1.log 01:11:58,959 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-15793356145164304984/new-server/metadata-v1-1.log 01:11:58,959 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - new-server: no eligible files found 01:11:58,959 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractReplicatedLog - new-server: Moving last applied index from -1 to -1 01:11:58,959 AM [test-pekko.actor.default-dispatcher-6] [INFO] Recovery - new-server: Recovery completed in in 3.868 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:58,959 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActor - new-server: Recovery completed and can restore from snapshot 01:11:58,960 AM [main] [DEBUG] AbstractReplicatedLog - follower: Moving last applied index from -1 to 2 01:11:58,960 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorVotingConfigSupportTest$MockLeaderRaftActor - Actor created TestActor[pekko://test/user/leader191] [WARN] [02/28/2026 01:11:58.961] [test-pekko.actor.default-dispatcher-14] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader191]: org.opendaylight.controller.cluster.common.actor.Monitor@2ee1c5d2 01:11:58,961 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor=leader 01:11:58,961 AM [test-pekko.actor.default-dispatcher-6] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:58,961 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - leader: started executor 01:11:58,961 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - leader: started executor 01:11:58,962 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:58,962 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:58,962 AM [test-pekko.actor.default-dispatcher-6] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:58,962 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:58,962 AM [leader-writer-72] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:58,962 AM [leader-writer-72] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:58,962 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] PropertiesTermInfoStore - /tmp/junit-15793356145164304984/leader/TermInfo.properties does not exist 01:11:58,968 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor=leader 01:11:58,968 AM [test-pekko.actor.default-dispatcher-6] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=1, votedFor=leader} 01:11:58,968 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-15793356145164304984/leader/TermInfo.properties 01:11:58,968 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-15793356145164304984/leader/journal-v1-1.log 01:11:58,968 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-15793356145164304984/leader/metadata-v1-1.log 01:11:58,968 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorage - leader: no eligible files found 01:11:58,968 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:58,968 AM [test-pekko.actor.default-dispatcher-6] [INFO] Recovery - leader: Recovery completed in in 5.827 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:58,968 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:58,969 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractLeader - leader (Leader): Election: Leader has following peers: [follower] 01:11:58,969 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: false, followerNextIndex: 2, leaderLastIndex: 2, leaderSnapShotIndex: -1 01:11:58,969 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SyncStatusTracker - follower: Last sync leader does not match current leader leader, need to catch up to -1 01:11:58,969 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for follower updated: matchIndex: 2, nextIndex: 3 01:11:58,969 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SnapshotManager - leader: fakeSnapshot purging log to 1 for term 1 01:11:58,969 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: true, followerNextIndex: 3, leaderLastIndex: 2, leaderSnapShotIndex: 1 01:11:58,969 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower: Lagging 0 entries behind leader leader and reached 2 (of expected -1) 01:11:58,969 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - follower: fakeSnapshot purging log to 1 for term 1 01:11:58,981 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - leader: onAddServer: AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server190, votingMember=true], state: Idle 01:11:58,981 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server190, votingMember=true] 01:11:58,981 AM [test-pekko.actor.default-dispatcher-14] [INFO] SnapshotManager - leader: Initiating snapshot capture CaptureSnapshot [lastAppliedIndex=2, lastAppliedTerm=1, lastIndex=2, lastTerm=1, installSnapshotInitiated=, replicatedToAllIndex=-1, replicatedToAllTerm=-1, unAppliedEntries size=0, mandatoryTrim=false] to install on new-server 01:11:58,981 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SnapshotManager - leader: last applied journal index prior to capture: 3 01:11:58,981 AM [test-pekko.actor.default-dispatcher-14] [INFO] MockRaftActor - leader: support() called 01:11:58,982 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating capture snapshot for new server new-server 01:11:58,982 AM [leader-%d484183] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:58,982 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:58,982 AM [test-pekko.actor.default-dispatcher-14] [INFO] SnapshotManager - leader: Persising snapshot at EntryInfo[index=2, term=1]/EntryInfo[index=2, term=1] 01:11:58,982 AM [test-pekko.actor.default-dispatcher-14] [INFO] MockRaftActor - leader: support() called 01:11:58,982 AM [test-pekko.actor.default-dispatcher-14] [INFO] SnapshotManager - leader: Removed in-memory snapshotted entries, adjusted snapshotIndex: 1 and term: 1 01:11:58,982 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader (Leader): sendInstallSnapshot 01:11:58,982 AM [leader-%d484184] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-15793356145164304984/leader/snapshot-0000000069A240DE-3A9403B7.tmp 01:11:58,983 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] LeaderInstallSnapshotState - leader (Leader): Snapshot 157 bytes, total chunks to send: 1 01:11:58,983 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] LeaderInstallSnapshotState - leader (Leader): Next chunk: total length=157, offset=0, size=157, hashCode=1546036366 01:11:58,983 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader (Leader): next snapshot chunk size for follower new-server: 157 01:11:58,983 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader (Leader): InstallSnapshot sent to follower Vector(user, new-server190), Chunk: 1/1 01:11:58,983 AM [test-pekko.actor.default-dispatcher-16] [INFO] Follower - new-server (Follower): Term 1 in "InstallSnapshot{term=1, leaderId=leader, lastIncludedIndex=2, lastIncludedTerm=1, datasize=157, chunk=1/1, lastChunkHashCode=OptionalInt[-1]}" message is greater than follower's term 0 - updating term 01:11:58,985 AM [leader-%d484184] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-15793356145164304984/leader/snapshot-0000000069A240DE-3A9403B7.v1 01:11:58,985 AM [leader-%d484184] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-15793356145164304984/leader/snapshot-0000000069A240DE-3A9403B7.v1 01:11:58,986 AM [leader-%d484184] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-15793356145164304984/leader/TermInfo.properties 01:11:58,986 AM [leader-%d484184] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-15793356145164304984/leader/journal-v1-1.log 01:11:58,986 AM [leader-%d484184] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-15793356145164304984/leader/metadata-v1-1.log 01:11:58,986 AM [leader-%d484184] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.982778807Z, file=/tmp/junit-15793356145164304984/leader/snapshot-0000000069A240DE-3A9403B7.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:58,986 AM [leader-%d484184] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:58,986 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:58,986 AM [test-pekko.actor.default-dispatcher-14] [INFO] SnapshotManager - leader: snapshot is durable as of 2026-02-28T01:11:58.982778807Z 01:11:58,986 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SnapshotManager - leader: Snapshot success, discarding journal entries up to 3 01:11:58,986 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorSnapshotMessageSupport - leader: SnapshotComplete received 01:11:58,986 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=1, votedFor=null 01:11:58,986 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - new-server (Follower): handleInstallSnapshot: InstallSnapshot{term=1, leaderId=leader, lastIncludedIndex=2, lastIncludedTerm=1, datasize=157, chunk=1/1, lastChunkHashCode=OptionalInt[-1]} 01:11:58,986 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - new-server: Last sync leader does not match current leader leader, need to catch up to 2 01:11:58,986 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotTracker - new-server (Follower): addChunk: chunkIndex=1, lastChunkIndex=0, collectedChunks.size=0, lastChunkHashCode=-1 01:11:58,986 AM [test-pekko.actor.default-dispatcher-16] [INFO] Follower - new-server (Follower): Snapshot received from leader: leader 01:11:58,987 AM [test-pekko.actor.default-dispatcher-16] [INFO] SnapshotManager - new-server: Applying snapshot on follower: PlainSnapshotSource{io=MemoryStreamSource{size=157}} 01:11:58,987 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - new-server: support() called [WARN] [02/28/2026 01:11:58.987] [test-pekko.actor.default-dispatcher-14] [pekko://test/user/new-server190] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=new-server, initialSyncDone=false] 01:11:58,987 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - new-server: Converted InstallSnapshot from leader: leader to state 01:11:58,987 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - new-server: last applied journal index prior to persisting applied snapshot: 0 01:11:58,987 AM [test-pekko.actor.default-dispatcher-16] [INFO] MockRaftActor - new-server: support() called 01:11:58,988 AM [new-server-%d793177] [DEBUG] RaftStorage - new-server: starting snapshot writeout to /tmp/junit-15793356145164304984/new-server/snapshot-0000000069A240DE-3AE3944A.tmp 01:11:58,994 AM [new-server-%d793177] [DEBUG] RaftStorage - new-server: finished snapshot writeout to /tmp/junit-15793356145164304984/new-server/snapshot-0000000069A240DE-3AE3944A.v1 01:11:58,994 AM [new-server-%d793177] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-15793356145164304984/new-server/snapshot-0000000069A240DE-3AE3944A.v1 01:11:58,994 AM [new-server-%d793177] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-15793356145164304984/new-server/TermInfo.properties 01:11:58,994 AM [new-server-%d793177] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-15793356145164304984/new-server/journal-v1-1.log 01:11:58,994 AM [new-server-%d793177] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-15793356145164304984/new-server/metadata-v1-1.log 01:11:58,994 AM [new-server-%d793177] [DEBUG] RaftStorage - new-server: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.987993162Z, file=/tmp/junit-15793356145164304984/new-server/snapshot-0000000069A240DE-3AE3944A.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:58,994 AM [new-server-%d793177] [DEBUG] RaftStorageCompleter - new-server: 1 completion(s) pending 01:11:58,994 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - new-server: running 1 completion(s) 01:11:58,994 AM [test-pekko.actor.default-dispatcher-14] [INFO] SnapshotManager - new-server: snapshot is durable as of 2026-02-28T01:11:58.987993162Z 01:11:58,994 AM [test-pekko.actor.default-dispatcher-14] [INFO] MockRaftActor - new-server: support() called 01:11:58,995 AM [test-pekko.actor.default-dispatcher-14] [INFO] MockRaftActor - new-server: applySnapshot called 01:11:58,995 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - new-server (Follower): handleInstallSnapshot returning: InstallSnapshotReply{term=1, followerId=new-server, chunkIndex=1, success=true} 01:11:58,995 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SnapshotManager - new-server: Snapshot success, discarding journal entries up to 0 01:11:58,995 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorSnapshotMessageSupport - new-server: SnapshotComplete received 01:11:58,995 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): handleInstallSnapshotReply: InstallSnapshotReply{term=1, followerId=new-server, chunkIndex=1, success=true} 01:11:58,995 AM [test-pekko.actor.default-dispatcher-16] [INFO] AbstractLeader - leader (Leader): Snapshot successfully installed on follower new-server (last chunk 1) - matchIndex set to 2, nextIndex set to 3 01:11:58,995 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - Sent message UnInitializedFollowerSnapshotReply to self 01:11:58,995 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: onUnInitializedFollowerSnapshotReply: UnInitializedFollowerSnapshotReply [followerId=new-server] 01:11:58,995 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: New server configuration : [ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]] 01:11:58,995 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader: Persist data index=3 term=1 command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,995 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] ReplicatedLogImpl - leader: Append log entry and persist JournaledLogEntry{index=3, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:58,996 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Replicate message: identifier: ServerOperationContextIdentifier{value=fd95e00b-c7d3-4189-bef8-3b3ce15f0015}, logIndex: 3, isSendImmediate: true 01:11:58,996 AM [leader-%d484185] [DEBUG] RaftStorage - leader: starting snapshot writeout to /tmp/junit-15793356145164304984/leader/snapshot-0000000069A240DE-3B60C9A0.tmp 01:11:58,996 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: true, followerNextIndex: 3, leaderLastIndex: 3, leaderSnapShotIndex: 1 01:11:58,996 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 3 is present for follower follower 01:11:58,996 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower follower: AppendEntries{term=1, leaderId=leader, prevLogIndex=2, prevLogTerm=1, leaderCommit=2, replicatedToAllIndex=1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=3, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:58,996 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server: active: true, followerNextIndex: 3, leaderLastIndex: 3, leaderSnapShotIndex: 1 01:11:58,996 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): sendAppendEntries: 3 is present for follower new-server 01:11:58,996 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Sending AppendEntries to follower new-server: AppendEntries{term=1, leaderId=leader, prevLogIndex=2, prevLogTerm=1, leaderCommit=2, replicatedToAllIndex=1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[JournaledLogEntry{index=3, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:58,996 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower (Follower): handleAppendEntries: AppendEntries{term=1, leaderId=leader, prevLogIndex=2, prevLogTerm=1, leaderCommit=2, replicatedToAllIndex=1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=3, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:58,996 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower (Follower): Number of entries to be appended = 1 01:11:58,996 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower (Follower): After cleanup, lastIndex: 2, entries to be added from: 0 01:11:58,996 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,996 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: Returning OK for operation AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server190, votingMember=true] 01:11:58,996 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - follower: Append log entry and persist JournaledLogEntry{index=3, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:58,997 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - test: 1 completion(s) pending 01:11:58,997 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - test: running 1 completion(s) 01:11:58,996 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): handleAppendEntries: AppendEntries{term=1, leaderId=leader, prevLogIndex=2, prevLogTerm=1, leaderCommit=2, replicatedToAllIndex=1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[JournaledLogEntry{index=3, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true}]} 01:11:58,997 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - follower: persist complete JournaledLogEntry{index=3, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false} 01:11:58,997 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): Number of entries to be appended = 1 01:11:58,997 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): After cleanup, lastIndex: 2, entries to be added from: 0 01:11:58,997 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - test: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=3, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@77a06828} 01:11:58,997 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,997 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] ReplicatedLogImpl - new-server: Append log entry and persist JournaledLogEntry{index=3, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:58,997 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PeerInfos - follower: Updated server config: isVoting: true, peers: [PeerInfo [id=leader, address=, votingState=VOTING], PeerInfo [id=new-server, address=null, votingState=VOTING]] 01:11:58,997 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower (Follower): Log size is now 2 01:11:58,997 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - follower (Follower): handleAppendEntries returning : AppendEntriesReply{term=1, success=true, followerId=follower, logLastIndex=3, logLastTerm=1, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=0, raftVersion=5, recipientRaftVersion=5} 01:11:58,997 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SyncStatusTracker - follower: Lagging 0 entries behind leader leader and reached 2 (of expected -1) 01:11:58,997 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] PeerInfos - new-server: Updated server config: isVoting: true, peers: [PeerInfo [id=leader, address=null, votingState=VOTING], PeerInfo [id=follower, address=null, votingState=VOTING]] 01:11:58,997 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): Log size is now 1 01:11:58,997 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): handleAppendEntries returning : AppendEntriesReply{term=1, success=true, followerId=new-server, logLastIndex=3, logLastTerm=1, forceInstallSnapshot=false, needsLeaderAddress=true, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:58,997 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] SyncStatusTracker - new-server: Lagging 0 entries behind leader leader and reached 2 (of expected 2) 01:11:58,997 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for follower updated: matchIndex: 3, nextIndex: 4 01:11:58,997 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorageCompleter - new-server: awaiting more completions to resolve 1 synchronized callback(s) 01:11:58,997 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: true, followerNextIndex: 4, leaderLastIndex: 3, leaderSnapShotIndex: 1 01:11:58,997 AM [new-server-%d793178] [DEBUG] RaftStorage - new-server: starting snapshot writeout to /tmp/junit-15793356145164304984/new-server/snapshot-0000000069A240DE-3B719116.tmp 01:11:58,997 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for new-server updated: matchIndex: 3, nextIndex: 4 01:11:58,997 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server: active: true, followerNextIndex: 4, leaderLastIndex: 3, leaderSnapShotIndex: 1 01:11:58,998 AM [leader-%d484185] [DEBUG] RaftStorage - leader: finished snapshot writeout to /tmp/junit-15793356145164304984/leader/snapshot-0000000069A240DE-3B60C9A0.v1 01:11:58,999 AM [leader-%d484185] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-15793356145164304984/leader/snapshot-0000000069A240DE-3B60C9A0.v1 01:11:58,999 AM [leader-%d484185] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-15793356145164304984/leader/snapshot-0000000069A240DE-3A9403B7.v1 01:11:58,999 AM [leader-%d484185] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-15793356145164304984/leader/TermInfo.properties 01:11:58,999 AM [leader-%d484185] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-15793356145164304984/leader/journal-v1-1.log 01:11:58,999 AM [leader-%d484185] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-15793356145164304984/leader/metadata-v1-1.log 01:11:58,999 AM [leader-%d484185] [DEBUG] RaftStorage - leader: deleted snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.982778807Z, file=/tmp/junit-15793356145164304984/leader/snapshot-0000000069A240DE-3A9403B7.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:58,999 AM [leader-%d484185] [DEBUG] RaftStorage - leader: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.996198816Z, file=/tmp/junit-15793356145164304984/leader/snapshot-0000000069A240DE-3B60C9A0.v1, size=97, entryCompress=NONE, stateCompress=NONE} 01:11:58,999 AM [leader-%d484185] [DEBUG] RaftStorageCompleter - leader: 1 completion(s) pending 01:11:58,999 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - leader: running 1 completion(s) 01:11:58,999 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - leader: persist complete JournaledLogEntry{index=3, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=true} 01:11:58,999 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader (Leader): Applying to log - commitIndex: 3, lastAppliedIndex: 2 01:11:58,999 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorBehavior - leader (Leader): Setting last applied to 3 01:11:58,999 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from 2 to 3 01:11:58,999 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader: Applying state for log index 3 data VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:58,999 AM [new-server-%d793178] [DEBUG] RaftStorage - new-server: finished snapshot writeout to /tmp/junit-15793356145164304984/new-server/snapshot-0000000069A240DE-3B719116.v1 01:11:59,0 AM [new-server-%d793178] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-15793356145164304984/new-server/snapshot-0000000069A240DE-3AE3944A.v1 01:11:59,0 AM [new-server-%d793178] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-15793356145164304984/new-server/snapshot-0000000069A240DE-3B719116.v1 01:11:59,0 AM [new-server-%d793178] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-15793356145164304984/new-server/TermInfo.properties 01:11:59,0 AM [new-server-%d793178] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-15793356145164304984/new-server/journal-v1-1.log 01:11:59,0 AM [new-server-%d793178] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-15793356145164304984/new-server/metadata-v1-1.log 01:11:59,0 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SnapshotManager - leader: fakeSnapshot purging log to 2 for term 1 01:11:59,0 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActorVotingConfigSupport - leader: VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} has been successfully replicated to a majority of followers 01:11:59,0 AM [new-server-%d793178] [DEBUG] RaftStorage - new-server: deleted snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.987993162Z, file=/tmp/junit-15793356145164304984/new-server/snapshot-0000000069A240DE-3AE3944A.v1, size=64, entryCompress=NONE, stateCompress=NONE} 01:11:59,0 AM [new-server-%d793178] [DEBUG] RaftStorage - new-server: retaining snapshot SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.997298454Z, file=/tmp/junit-15793356145164304984/new-server/snapshot-0000000069A240DE-3B719116.v1, size=97, entryCompress=NONE, stateCompress=NONE} 01:11:59,0 AM [new-server-%d793178] [DEBUG] RaftStorageCompleter - new-server: 1 completion(s) pending 01:11:59,0 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorageCompleter - new-server: running 1 completion(s) 01:11:59,0 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] ReplicatedLogImpl - new-server: persist complete JournaledLogEntry{index=3, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false} 01:11:59,0 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorageCompleter - new-server: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=3, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@39f00aa1} 01:11:59,0 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftStorageCompleter - new-server: synchronized callbacks after 2.920 ms [WARN] [02/28/2026 01:11:59.000] [test-pekko.actor.default-dispatcher-6] [pekko://test/user/new-server190] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=new-server, initialSyncDone=true] 01:11:59,206 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): Commit index set to 3 01:11:59,206 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] SyncStatusTracker - new-server: Lagging 0 entries behind leader leader and reached 3 (of expected 2) 01:11:59,206 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] Follower - new-server (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 3, context.getLastApplied(): 2, lastIndex(): 3 01:11:59,206 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActorBehavior - new-server (Follower): Setting last applied to 3 01:11:59,206 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] AbstractReplicatedLog - new-server: Moving last applied index from 2 to 3 01:11:59,206 AM [test-pekko.actor.default-dispatcher-6] [DEBUG] RaftActor - new-server: Applying state for log index 3 data VotingConfig{serverInfo=[ServerInfo[peerId=follower, isVoting=true], ServerInfo[peerId=new-server, isVoting=true], ServerInfo[peerId=leader, isVoting=true]]} 01:11:59,206 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): Commit index set to 3 01:11:59,207 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower: Lagging 0 entries behind leader leader and reached 3 (of expected -1) 01:11:59,207 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - follower (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 3, context.getLastApplied(): 2, lastIndex(): 3 01:11:59,207 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - follower (Follower): Setting last applied to 3 01:11:59,207 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - follower: Moving last applied index from 2 to 3 01:11:59,207 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SnapshotManager - follower: fakeSnapshot purging log to 2 for term 1 01:11:59,232 AM [main] [DEBUG] RaftStorage - leader: selected SNAPSHOT_V1 to handle file /tmp/junit-15793356145164304984/leader/snapshot-0000000069A240DE-3B60C9A0.v1 01:11:59,233 AM [main] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-15793356145164304984/leader/TermInfo.properties 01:11:59,233 AM [main] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-15793356145164304984/leader/journal-v1-1.log 01:11:59,233 AM [main] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-15793356145164304984/leader/metadata-v1-1.log 01:11:59,233 AM [main] [DEBUG] RaftStorage - leader: picked SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.996198816Z, file=/tmp/junit-15793356145164304984/leader/snapshot-0000000069A240DE-3B60C9A0.v1, size=97, entryCompress=NONE, stateCompress=NONE} as the latest file 01:11:59,233 AM [main] [DEBUG] RaftStorage - new-server: selected SNAPSHOT_V1 to handle file /tmp/junit-15793356145164304984/new-server/snapshot-0000000069A240DE-3B719116.v1 01:11:59,233 AM [main] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-15793356145164304984/new-server/TermInfo.properties 01:11:59,233 AM [main] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-15793356145164304984/new-server/journal-v1-1.log 01:11:59,233 AM [main] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-15793356145164304984/new-server/metadata-v1-1.log 01:11:59,233 AM [main] [DEBUG] RaftStorage - new-server: picked SnapshotFileV1{lastIncluded=EntryInfo[index=-1, term=-1], timestamp=2026-02-28T01:11:58.997298454Z, file=/tmp/junit-15793356145164304984/new-server/snapshot-0000000069A240DE-3B719116.v1, size=97, entryCompress=NONE, stateCompress=NONE} as the latest file 01:11:59,233 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithExistingFollower ending 01:11:59,234 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower188] 01:11:59,245 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/new-serverCollector189#1900158908] 01:11:59,246 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/new-server190] 01:11:59,246 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EnabledRaftStorage - new-server: terminating thread VirtualThread[#347,new-server-writer-71]/waiting 01:11:59,246 AM [new-server-writer-71] [DEBUG] JournalWriteTask - new-server: received 1 commands after 291.2 ms 01:11:59,247 AM [new-server-writer-71] [DEBUG] JournalWriteTask - new-server: completed 1 commands in 57.91 μs 01:11:59,247 AM [new-server-writer-71] [DEBUG] JournalWriteTask - new-server: journal writer stopped 01:11:59,247 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - new-server: journal closed 01:11:59,247 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - new-server: journal closed 01:11:59,247 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:59,247 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:59,248 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader191] 01:11:59,248 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#348,leader-writer-72]/waiting 01:11:59,248 AM [leader-writer-72] [DEBUG] JournalWriteTask - leader: received 1 commands after 285.7 ms 01:11:59,248 AM [leader-writer-72] [DEBUG] JournalWriteTask - leader: completed 1 commands in 18.64 μs 01:11:59,248 AM [leader-writer-72] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:59,248 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:59,248 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - leader: journal closed 01:11:59,248 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:59,248 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:59,249 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leaderCollector192] 01:11:59,253 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerForwardedToLeader starting 01:11:59,254 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActorVotingConfigSupportTest$MockNewFollowerRaftActor - Actor created TestActor[pekko://test/user/new-server195] [WARN] [02/28/2026 01:11:59.255] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/new-server195]: org.opendaylight.controller.cluster.common.actor.Monitor@4b5db0b1 01:11:59,256 AM [test-pekko.actor.default-dispatcher-15] [INFO] RaftActor - new-server: Starting recovery with journal batch size 1000 01:11:59,256 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - new-server: started executor 01:11:59,256 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - new-server: started executor 01:11:59,257 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - new-server: metadata journal open: replayFrom=1 applyTo=0 01:11:59,257 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] EntryJournalV1 - new-server: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:59,257 AM [test-pekko.actor.default-dispatcher-15] [INFO] EnabledRaftStorage - new-server: journal open: applyTo=0 01:11:59,257 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - new-server: recovering to non-persistent 01:11:59,257 AM [new-server-writer-73] [DEBUG] JournalWriteTask - new-server: journal writer started 01:11:59,257 AM [new-server-writer-73] [DEBUG] JournalWriteTask - new-server: waiting to receive commands 01:11:59,258 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - /tmp/junit-13038403244263932760/new-server/TermInfo.properties does not exist 01:11:59,261 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=0, votedFor=null 01:11:59,261 AM [test-pekko.actor.default-dispatcher-15] [INFO] Recovery - new-server: Local TermInfo store seeded with TermInfo{term=0} 01:11:59,261 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-13038403244263932760/new-server/TermInfo.properties 01:11:59,261 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-13038403244263932760/new-server/journal-v1-1.log 01:11:59,261 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-13038403244263932760/new-server/metadata-v1-1.log 01:11:59,261 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorage - new-server: no eligible files found 01:11:59,261 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] AbstractReplicatedLog - new-server: Moving last applied index from -1 to -1 01:11:59,261 AM [test-pekko.actor.default-dispatcher-15] [INFO] Recovery - new-server: Recovery completed in in 3.741 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:59,261 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftActor - new-server: Recovery completed and can restore from snapshot 01:11:59,263 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] MockRaftActor - Actor created TestActor[pekko://test/user/follower197] [WARN] [02/28/2026 01:11:59.263] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/follower197]: org.opendaylight.controller.cluster.common.actor.Monitor@48507898 01:11:59,264 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActor - follower: Starting recovery with journal batch size 1000 01:11:59,264 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - follower: started executor 01:11:59,264 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - follower: started executor 01:11:59,265 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - follower: metadata journal open: replayFrom=1 applyTo=0 01:11:59,266 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - follower: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:59,266 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - follower: journal open: applyTo=0 01:11:59,266 AM [follower-writer-74] [DEBUG] JournalWriteTask - follower: journal writer started 01:11:59,266 AM [follower-writer-74] [DEBUG] JournalWriteTask - follower: waiting to receive commands 01:11:59,266 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower: recovering to non-persistent 01:11:59,266 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - /tmp/junit-13038403244263932760/follower/TermInfo.properties does not exist 01:11:59,269 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - follower: Set currentTerm=0, votedFor=null 01:11:59,269 AM [test-pekko.actor.default-dispatcher-16] [INFO] Recovery - follower: Local TermInfo store seeded with TermInfo{term=0} 01:11:59,269 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-13038403244263932760/follower/TermInfo.properties 01:11:59,269 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-13038403244263932760/follower/journal-v1-1.log 01:11:59,269 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-13038403244263932760/follower/metadata-v1-1.log 01:11:59,269 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - follower: no eligible files found 01:11:59,269 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - follower: Moving last applied index from -1 to -1 01:11:59,269 AM [test-pekko.actor.default-dispatcher-16] [INFO] Recovery - follower: Recovery completed in in 3.197 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:59,269 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower: Recovery completed and can restore from snapshot 01:11:59,270 AM [test-pekko.actor.default-dispatcher-16] [INFO] Follower - follower (Follower): Term 1 in "AppendEntries{term=1, leaderId=leader, prevLogIndex=0, prevLogTerm=1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=0, recipientRaftVersion=5, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 0 - updating term 01:11:59,273 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - follower: Set currentTerm=1, votedFor=null 01:11:59,273 AM [test-pekko.actor.default-dispatcher-16] [INFO] Follower - follower (Follower): The followers log is empty and the senders prevLogIndex is 0 01:11:59,273 AM [test-pekko.actor.default-dispatcher-16] [INFO] Follower - follower (Follower): Follower is out-of-sync so sending negative reply: AppendEntriesReply{term=1, success=false, followerId=follower, logLastIndex=-1, logLastTerm=-1, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:59,273 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower: Last sync leader does not match current leader leader, need to catch up to -1 [WARN] [02/28/2026 01:11:59.273] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/follower197] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=follower, initialSyncDone=false] 01:11:59,280 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - follower: onAddServer: AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server195, votingMember=true], state: Idle 01:11:59,280 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower: getLeaderAddress leaderId = leader peerAddress = pekko://test/user/leader196 01:11:59,280 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - follower: Not leader - forwarding to leader ActorSelection[Anchor(pekko://test/), Path(/user/leader196)] 01:11:59,330 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerForwardedToLeader ending 01:11:59,331 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower193] 01:11:59,342 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/new-serverCollector194#240991956] 01:11:59,342 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/new-server195] 01:11:59,343 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EnabledRaftStorage - new-server: terminating thread VirtualThread[#354,new-server-writer-73]/waiting 01:11:59,343 AM [new-server-writer-73] [DEBUG] JournalWriteTask - new-server: received 1 commands after 85.74 ms 01:11:59,343 AM [new-server-writer-73] [DEBUG] JournalWriteTask - new-server: completed 1 commands in 33.64 μs 01:11:59,343 AM [new-server-writer-73] [DEBUG] JournalWriteTask - new-server: journal writer stopped 01:11:59,344 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - new-server: journal closed 01:11:59,344 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - new-server: journal closed 01:11:59,344 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:59,344 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:11:59,344 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/leader196#1821998734] 01:11:59,346 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower197] 01:11:59,347 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EnabledRaftStorage - follower: terminating thread VirtualThread[#355,follower-writer-74]/waiting 01:11:59,347 AM [follower-writer-74] [DEBUG] JournalWriteTask - follower: received 1 commands after 80.96 ms 01:11:59,347 AM [follower-writer-74] [DEBUG] JournalWriteTask - follower: completed 1 commands in 19.09 μs 01:11:59,347 AM [follower-writer-74] [DEBUG] JournalWriteTask - follower: journal writer stopped 01:11:59,347 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - follower: journal closed 01:11:59,347 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - follower: journal closed 01:11:59,347 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - follower: stopped executor with 0 remaining tasks 01:11:59,347 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - follower: stopped executor with 0 remaining tasks 01:11:59,455 AM [main] [INFO] RaftActorVotingConfigSupportTest - testRemoveServerForwardToLeader starting 01:11:59,457 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] MockRaftActor - Actor created TestActor[pekko://test/user/follower200] 01:11:59,459 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActor - follower: Starting recovery with journal batch size 1000 01:11:59,459 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - follower: started executor 01:11:59,459 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - follower: started executor [WARN] [02/28/2026 01:11:59.460] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/follower200]: org.opendaylight.controller.cluster.common.actor.Monitor@6ef8750e 01:11:59,460 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - follower: metadata journal open: replayFrom=1 applyTo=0 01:11:59,461 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - follower: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:59,461 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - follower: journal open: applyTo=0 01:11:59,461 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower: recovering to non-persistent 01:11:59,461 AM [follower-writer-75] [DEBUG] JournalWriteTask - follower: journal writer started 01:11:59,461 AM [follower-writer-75] [DEBUG] JournalWriteTask - follower: waiting to receive commands 01:11:59,461 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - /tmp/junit-16744222420796398259/follower/TermInfo.properties does not exist 01:11:59,464 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - follower: Set currentTerm=0, votedFor=null 01:11:59,464 AM [test-pekko.actor.default-dispatcher-16] [INFO] Recovery - follower: Local TermInfo store seeded with TermInfo{term=0} 01:11:59,465 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-16744222420796398259/follower/TermInfo.properties 01:11:59,465 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-16744222420796398259/follower/journal-v1-1.log 01:11:59,465 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - follower: skipping unrecognized file /tmp/junit-16744222420796398259/follower/metadata-v1-1.log 01:11:59,465 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - follower: no eligible files found 01:11:59,465 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - follower: Moving last applied index from -1 to -1 01:11:59,465 AM [test-pekko.actor.default-dispatcher-16] [INFO] Recovery - follower: Recovery completed in in 3.610 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:59,465 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower: Recovery completed and can restore from snapshot 01:11:59,465 AM [test-pekko.actor.default-dispatcher-16] [INFO] Follower - follower (Follower): Term 1 in "AppendEntries{term=1, leaderId=leader, prevLogIndex=0, prevLogTerm=1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=0, recipientRaftVersion=5, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 0 - updating term 01:11:59,468 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - follower: Set currentTerm=1, votedFor=null 01:11:59,468 AM [test-pekko.actor.default-dispatcher-16] [INFO] Follower - follower (Follower): The followers log is empty and the senders prevLogIndex is 0 01:11:59,468 AM [test-pekko.actor.default-dispatcher-16] [INFO] Follower - follower (Follower): Follower is out-of-sync so sending negative reply: AppendEntriesReply{term=1, success=false, followerId=follower, logLastIndex=-1, logLastTerm=-1, forceInstallSnapshot=false, needsLeaderAddress=false, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:11:59,468 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - follower: Last sync leader does not match current leader leader, need to catch up to -1 [WARN] [02/28/2026 01:11:59.468] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/follower200] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=follower, initialSyncDone=false] 01:11:59,476 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - follower: onRemoveServer: RemoveServer{serverId='follower'}, state: Idle 01:11:59,476 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - follower: getLeaderAddress leaderId = leader peerAddress = pekko://test/user/leader199 01:11:59,476 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - follower: Not leader - forwarding to leader ActorSelection[Anchor(pekko://test/), Path(/user/leader199)] 01:11:59,526 AM [main] [INFO] RaftActorVotingConfigSupportTest - testRemoveServerForwardToLeader ending 01:11:59,526 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower198] 01:11:59,537 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader199] 01:11:59,538 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower200] 01:11:59,538 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EnabledRaftStorage - follower: terminating thread VirtualThread[#356,follower-writer-75]/waiting 01:11:59,538 AM [follower-writer-75] [DEBUG] JournalWriteTask - follower: received 1 commands after 77.27 ms 01:11:59,539 AM [follower-writer-75] [DEBUG] JournalWriteTask - follower: completed 1 commands in 46.65 μs 01:11:59,539 AM [follower-writer-75] [DEBUG] JournalWriteTask - follower: journal writer stopped 01:11:59,539 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - follower: journal closed 01:11:59,539 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - follower: journal closed 01:11:59,539 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - follower: stopped executor with 0 remaining tasks 01:11:59,539 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - follower: stopped executor with 0 remaining tasks 01:11:59,543 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithExistingServer starting 01:11:59,544 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupportTest$MockLeaderRaftActor - Actor created TestActor[pekko://test/user/leader202] 01:11:59,545 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:59,545 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:11:59,545 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: started executor [WARN] [02/28/2026 01:11:59.545] [test-pekko.actor.default-dispatcher-14] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader202]: org.opendaylight.controller.cluster.common.actor.Monitor@3fb9169f 01:11:59,545 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: started executor 01:11:59,546 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:11:59,546 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:59,546 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:11:59,547 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader: recovering to non-persistent 01:11:59,547 AM [leader-writer-76] [DEBUG] JournalWriteTask - leader: journal writer started 01:11:59,547 AM [leader-writer-76] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:11:59,547 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - /tmp/junit-4434591057932302615/leader/TermInfo.properties does not exist 01:11:59,561 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:11:59,561 AM [test-pekko.actor.default-dispatcher-16] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=1, votedFor=} 01:11:59,561 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-4434591057932302615/leader/TermInfo.properties 01:11:59,561 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-4434591057932302615/leader/journal-v1-1.log 01:11:59,561 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-4434591057932302615/leader/metadata-v1-1.log 01:11:59,561 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: no eligible files found 01:11:59,561 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:11:59,561 AM [test-pekko.actor.default-dispatcher-16] [INFO] Recovery - leader: Recovery completed in in 14.45 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:11:59,561 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:11:59,561 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Election: Leader has following peers: [follower] 01:11:59,561 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower follower: active: false, followerNextIndex: -1, leaderLastIndex: -1, leaderSnapShotIndex: -1 01:11:59,572 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: onAddServer: AddServer [newServerId=follower, newServerAddress=pekko://test/user/follower201, votingMember=true], state: Idle 01:11:59,572 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating AddServer [newServerId=follower, newServerAddress=pekko://test/user/follower201, votingMember=true] 01:11:59,572 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: Returning ALREADY_EXISTS for operation AddServer [newServerId=follower, newServerAddress=pekko://test/user/follower201, votingMember=true] 01:11:59,573 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithExistingServer ending 01:11:59,573 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower201] 01:11:59,584 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader202] 01:11:59,584 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#357,leader-writer-76]/waiting 01:11:59,584 AM [leader-writer-76] [DEBUG] JournalWriteTask - leader: received 1 commands after 37.66 ms 01:11:59,584 AM [leader-writer-76] [DEBUG] JournalWriteTask - leader: completed 1 commands in 32.03 μs 01:11:59,584 AM [leader-writer-76] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:11:59,585 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - leader: journal closed 01:11:59,585 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - leader: journal closed 01:11:59,585 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:59,585 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:11:59,590 AM [main] [INFO] RaftActorVotingConfigSupportTest - testChangeToVotingWithNoLeaderAndElectionTimeout starting 01:11:59,594 AM [main] [DEBUG] PropertiesTermInfoStore - node1: Set currentTerm=1, votedFor=node1 01:11:59,594 AM [main] [DEBUG] EntryJournalV1 - node1: metadata journal open: replayFrom=1 applyTo=0 01:11:59,595 AM [main] [DEBUG] EntryJournalV1 - node1: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:59,599 AM [main] [DEBUG] EntryJournalV1 - node1: journal closed 01:11:59,601 AM [main] [DEBUG] PropertiesTermInfoStore - node2: Set currentTerm=1, votedFor=node1 01:11:59,602 AM [main] [DEBUG] EntryJournalV1 - node2: metadata journal open: replayFrom=1 applyTo=0 01:11:59,602 AM [main] [DEBUG] EntryJournalV1 - node2: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:59,606 AM [main] [DEBUG] EntryJournalV1 - node2: journal closed 01:11:59,607 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupportTest$CollectingMockRaftActor - Actor created TestActor[pekko://test/user/node1] [WARN] [02/28/2026 01:11:59.607] [test-pekko.actor.default-dispatcher-14] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/node1]: org.opendaylight.controller.cluster.common.actor.Monitor@225f840a 01:11:59,608 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActor - node1: Starting recovery with journal batch size 1000 01:11:59,608 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node1: started executor 01:11:59,608 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node1: started executor 01:11:59,609 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - node1: metadata journal open: replayFrom=1 applyTo=0 01:11:59,610 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - node1: journal open: firstIndex=1 lastIndex=1 replayFrom=1 fileEntries=0 01:11:59,610 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - node1: journal open: applyTo=0 01:11:59,610 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - node1: starting journal recovery 01:11:59,610 AM [node1-writer-77] [DEBUG] JournalWriteTask - node1: journal writer started 01:11:59,610 AM [node1-writer-77] [DEBUG] JournalWriteTask - node1: waiting to receive commands 01:11:59,610 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - node1: Set currentTerm=1, votedFor=node1 01:11:59,610 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node1: skipping unrecognized file /tmp/junit-1792135109352345923/node1/TermInfo.properties 01:11:59,610 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node1: skipping unrecognized file /tmp/junit-1792135109352345923/node1/journal-v1-1.log 01:11:59,610 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node1: skipping unrecognized file /tmp/junit-1792135109352345923/node1/metadata-v1-1.log 01:11:59,610 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node1: no eligible files found 01:11:59,610 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - node1: Moving last applied index from -1 to -1 01:11:59,610 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] JournalRecovery - node1: applying entries up to 0 01:11:59,611 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] JournalRecovery - node1: recovered journal DefaultLogEntry[index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=false], ServerInfo[peerId=node2, isVoting=true]]}] 01:11:59,611 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PeerInfos - node1: Updated server config: isVoting: false, peers: [PeerInfo [id=node2, address=null, votingState=VOTING]] 01:11:59,611 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - node1: Moving last applied index from -1 to -1 01:11:59,611 AM [test-pekko.actor.default-dispatcher-16] [INFO] Recovery - node1: Recovery completed in in 1.223 ms: last log index = 0, last log term = 1, napshot index = -1, snapshot term = -1, journal size = 1 01:11:59,611 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - node1: Recovery completed and cannot restore from snapshot 01:11:59,613 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupportTest$CollectingMockRaftActor - Actor created TestActor[pekko://test/user/node2] [WARN] [02/28/2026 01:11:59.613] [test-pekko.actor.default-dispatcher-14] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/node2]: org.opendaylight.controller.cluster.common.actor.Monitor@32ebd1d1 01:11:59,614 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActor - node2: Starting recovery with journal batch size 1000 01:11:59,614 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node2: started executor 01:11:59,614 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node2: started executor 01:11:59,615 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - node2: metadata journal open: replayFrom=1 applyTo=0 01:11:59,616 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - node2: journal open: firstIndex=1 lastIndex=1 replayFrom=1 fileEntries=0 01:11:59,616 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - node2: journal open: applyTo=0 01:11:59,616 AM [node2-writer-78] [DEBUG] JournalWriteTask - node2: journal writer started 01:11:59,616 AM [node2-writer-78] [DEBUG] JournalWriteTask - node2: waiting to receive commands 01:11:59,616 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - node2: starting journal recovery 01:11:59,616 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - node2: Set currentTerm=1, votedFor=node1 01:11:59,616 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node2: skipping unrecognized file /tmp/junit-1792135109352345923/node2/TermInfo.properties 01:11:59,616 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node2: skipping unrecognized file /tmp/junit-1792135109352345923/node2/journal-v1-1.log 01:11:59,616 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node2: skipping unrecognized file /tmp/junit-1792135109352345923/node2/metadata-v1-1.log 01:11:59,616 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node2: no eligible files found 01:11:59,616 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - node2: Moving last applied index from -1 to -1 01:11:59,617 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] JournalRecovery - node2: applying entries up to 0 01:11:59,617 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] JournalRecovery - node2: recovered journal DefaultLogEntry[index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=false], ServerInfo[peerId=node2, isVoting=true]]}] 01:11:59,617 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PeerInfos - node2: Updated server config: isVoting: true, peers: [PeerInfo [id=node1, address=null, votingState=NON_VOTING]] 01:11:59,617 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - node2: Moving last applied index from -1 to -1 01:11:59,618 AM [test-pekko.actor.default-dispatcher-16] [INFO] Recovery - node2: Recovery completed in in 1.342 ms: last log index = 0, last log term = 1, napshot index = -1, snapshot term = -1, journal size = 1 01:11:59,618 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - node2: Recovery completed and cannot restore from snapshot 01:11:59,620 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - node1: onChangeServersVotingStatus: ChangeServersVotingStatus [serverVotingStatusMap={node1=true}, serversVisited=[]], state: Idle 01:11:59,620 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - Initiating ChangeServersVotingStatusState 01:11:59,620 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - node1: Sending local ElectionTimeout to start leader election 01:11:59,620 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PeerInfos - node1: Updated server config: isVoting: true, peers: [PeerInfo [id=node2, address=null, votingState=VOTING]] 01:11:59,621 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - node1 (Follower): Received TimeoutNow - switching to Candidate 01:11:59,621 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Candidate - node1 (Candidate): Election: Candidate has following voting peers: [node2] 01:11:59,624 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - node1: Set currentTerm=2, votedFor=node1 01:11:59,624 AM [test-pekko.actor.default-dispatcher-14] [INFO] Candidate - node1 (Candidate): Starting new election term 2 01:11:59,624 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Candidate - node1 (Candidate): Sending RequestVote{term=2, candidateId=node1, lastLogIndex=0, lastLogTerm=1} to peer node2 01:11:59,624 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActorBehavior - node1 (Follower) :- Switching from behavior Follower to Candidate, election term: 2 01:11:59,735 AM [test-pekko.actor.default-dispatcher-14] [WARN] RaftActorVotingConfigSupport - node1: Leader election timed out - cannot apply operation ChangeServersVotingStatus [serverVotingStatusMap={node1=true}, serversVisited=[]] 01:11:59,736 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PeerInfos - node1: Updated server config: isVoting: false, peers: [PeerInfo [id=node2, address=pekko://test/user/node2, votingState=VOTING]] 01:11:59,736 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - node1: tryToForwardOperationToAnotherServer - servers already visited [] 01:11:59,736 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - node1: Returning NO_LEADER for operation ChangeServersVotingStatus [serverVotingStatusMap={node1=true}, serversVisited=[]] 01:11:59,738 AM [main] [INFO] RaftActorVotingConfigSupportTest - testChangeToVotingWithNoLeaderAndElectionTimeout ending 01:11:59,738 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower203] 01:11:59,749 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/collector204#1852700215] 01:11:59,750 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/node1] 01:11:59,750 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EnabledRaftStorage - node1: terminating thread VirtualThread[#358,node1-writer-77]/waiting 01:11:59,750 AM [node1-writer-77] [DEBUG] JournalWriteTask - node1: received 1 commands after 140.3 ms 01:11:59,750 AM [node1-writer-77] [DEBUG] JournalWriteTask - node1: completed 1 commands in 46.66 μs 01:11:59,750 AM [node1-writer-77] [DEBUG] JournalWriteTask - node1: journal writer stopped 01:11:59,751 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - node1: journal closed 01:11:59,751 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - node1: journal closed 01:11:59,751 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node1: stopped executor with 0 remaining tasks 01:11:59,751 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node1: stopped executor with 0 remaining tasks 01:11:59,751 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/collector205#-214527264] 01:11:59,752 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/node2] 01:11:59,752 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EnabledRaftStorage - node2: terminating thread VirtualThread[#359,node2-writer-78]/waiting 01:11:59,752 AM [node2-writer-78] [DEBUG] JournalWriteTask - node2: received 1 commands after 136.0 ms 01:11:59,752 AM [node2-writer-78] [DEBUG] JournalWriteTask - node2: completed 1 commands in 18.13 μs 01:11:59,752 AM [node2-writer-78] [DEBUG] JournalWriteTask - node2: journal writer stopped 01:11:59,752 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - node2: journal closed 01:11:59,752 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - node2: journal closed 01:11:59,752 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node2: stopped executor with 0 remaining tasks 01:11:59,752 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node2: stopped executor with 0 remaining tasks 01:11:59,757 AM [main] [INFO] RaftActorVotingConfigSupportTest - testChangeToVotingWithNoLeader starting 01:11:59,760 AM [main] [DEBUG] PropertiesTermInfoStore - node1: Set currentTerm=1, votedFor=downNode1 01:11:59,761 AM [main] [DEBUG] EntryJournalV1 - node1: metadata journal open: replayFrom=1 applyTo=0 01:11:59,761 AM [main] [DEBUG] EntryJournalV1 - node1: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:59,766 AM [main] [DEBUG] EntryJournalV1 - node1: updated meta to JournalMeta[replayFrom=1, applyTo=1] 01:11:59,766 AM [main] [DEBUG] EntryJournalV1 - node1: journal closed 01:11:59,768 AM [main] [DEBUG] PropertiesTermInfoStore - node2: Set currentTerm=1, votedFor=downNode2 01:11:59,769 AM [main] [DEBUG] EntryJournalV1 - node2: metadata journal open: replayFrom=1 applyTo=0 01:11:59,769 AM [main] [DEBUG] EntryJournalV1 - node2: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:11:59,773 AM [main] [DEBUG] EntryJournalV1 - node2: updated meta to JournalMeta[replayFrom=1, applyTo=1] 01:11:59,773 AM [main] [DEBUG] EntryJournalV1 - node2: journal closed 01:11:59,774 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupportTest$CollectingMockRaftActor - Actor created TestActor[pekko://test/user/node1] [WARN] [02/28/2026 01:11:59.775] [test-pekko.actor.default-dispatcher-14] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/node1]: org.opendaylight.controller.cluster.common.actor.Monitor@35108d27 01:11:59,777 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActor - node1: Starting recovery with journal batch size 1000 01:11:59,778 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node1: started executor 01:11:59,778 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node1: started executor 01:11:59,779 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - node1: metadata journal open: replayFrom=1 applyTo=1 01:11:59,780 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - node1: journal open: firstIndex=1 lastIndex=1 replayFrom=1 fileEntries=0 01:11:59,780 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - node1: journal open: applyTo=1 01:11:59,780 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - node1: starting journal recovery 01:11:59,780 AM [node1-writer-79] [DEBUG] JournalWriteTask - node1: journal writer started 01:11:59,780 AM [node1-writer-79] [DEBUG] JournalWriteTask - node1: waiting to receive commands 01:11:59,780 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - node1: Set currentTerm=1, votedFor=downNode1 01:11:59,780 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node1: skipping unrecognized file /tmp/junit-11335305996141737433/node1/TermInfo.properties 01:11:59,780 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node1: skipping unrecognized file /tmp/junit-11335305996141737433/node1/journal-v1-1.log 01:11:59,780 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node1: skipping unrecognized file /tmp/junit-11335305996141737433/node1/metadata-v1-1.log 01:11:59,781 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node1: no eligible files found 01:11:59,781 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - node1: Moving last applied index from -1 to -1 01:11:59,781 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] JournalRecovery - node1: applying entries up to 1 01:11:59,781 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] JournalRecovery - node1: recovered journal DefaultLogEntry[index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=false], ServerInfo[peerId=node2, isVoting=false], ServerInfo[peerId=downNode1, isVoting=true], ServerInfo[peerId=downNode2, isVoting=true]]}] 01:11:59,781 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PeerInfos - node1: Updated server config: isVoting: false, peers: [PeerInfo [id=node2, address=null, votingState=NON_VOTING], PeerInfo [id=downNode2, address=null, votingState=VOTING], PeerInfo [id=downNode1, address=null, votingState=VOTING]] 01:11:59,782 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - node1: Moving last applied index from -1 to 0 01:11:59,782 AM [test-pekko.actor.default-dispatcher-16] [INFO] Recovery - node1: Recovery completed in in 1.500 ms: last log index = 0, last log term = 1, napshot index = -1, snapshot term = -1, journal size = 1 01:11:59,782 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - node1: Recovery completed and cannot restore from snapshot 01:11:59,783 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupportTest$CollectingMockRaftActor - Actor created TestActor[pekko://test/user/node2] [WARN] [02/28/2026 01:11:59.784] [test-pekko.actor.default-dispatcher-14] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/node2]: org.opendaylight.controller.cluster.common.actor.Monitor@23abd3d2 01:11:59,785 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActor - node2: Starting recovery with journal batch size 1000 01:11:59,785 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node2: started executor 01:11:59,785 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node2: started executor 01:11:59,786 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - node2: metadata journal open: replayFrom=1 applyTo=1 01:11:59,786 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - node2: journal open: firstIndex=1 lastIndex=1 replayFrom=1 fileEntries=0 01:11:59,787 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - node2: journal open: applyTo=1 01:11:59,787 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - node2: starting journal recovery 01:11:59,787 AM [node2-writer-80] [DEBUG] JournalWriteTask - node2: journal writer started 01:11:59,787 AM [node2-writer-80] [DEBUG] JournalWriteTask - node2: waiting to receive commands 01:11:59,787 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - node2: Set currentTerm=1, votedFor=downNode2 01:11:59,787 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node2: skipping unrecognized file /tmp/junit-11335305996141737433/node2/TermInfo.properties 01:11:59,787 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node2: skipping unrecognized file /tmp/junit-11335305996141737433/node2/journal-v1-1.log 01:11:59,787 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node2: skipping unrecognized file /tmp/junit-11335305996141737433/node2/metadata-v1-1.log 01:11:59,787 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - node2: no eligible files found 01:11:59,787 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - node2: Moving last applied index from -1 to -1 01:11:59,787 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] JournalRecovery - node2: applying entries up to 1 01:11:59,788 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] JournalRecovery - node2: recovered journal DefaultLogEntry[index=0, term=1, command=VotingConfig{serverInfo=[ServerInfo[peerId=node1, isVoting=false], ServerInfo[peerId=node2, isVoting=false], ServerInfo[peerId=downNode1, isVoting=true], ServerInfo[peerId=downNode2, isVoting=true]]}] 01:11:59,788 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PeerInfos - node2: Updated server config: isVoting: false, peers: [PeerInfo [id=downNode2, address=null, votingState=VOTING], PeerInfo [id=downNode1, address=null, votingState=VOTING], PeerInfo [id=node1, address=null, votingState=NON_VOTING]] 01:11:59,788 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - node2: Moving last applied index from -1 to 0 01:11:59,788 AM [test-pekko.actor.default-dispatcher-16] [INFO] Recovery - node2: Recovery completed in in 1.507 ms: last log index = 0, last log term = 1, napshot index = -1, snapshot term = -1, journal size = 1 01:11:59,788 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - node2: Recovery completed and cannot restore from snapshot 01:11:59,800 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - node1: onChangeServersVotingStatus: ChangeServersVotingStatus [serverVotingStatusMap={downNode2=false, node2=true, downNode1=false, node1=true}, serversVisited=[]], state: Idle 01:11:59,800 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - Initiating ChangeServersVotingStatusState 01:11:59,800 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - node1: Sending local ElectionTimeout to start leader election 01:11:59,800 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PeerInfos - node1: Updated server config: isVoting: true, peers: [PeerInfo [id=node2, address=null, votingState=VOTING], PeerInfo [id=downNode2, address=null, votingState=NON_VOTING], PeerInfo [id=downNode1, address=null, votingState=NON_VOTING]] 01:11:59,800 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - node1 (Follower): Received TimeoutNow - switching to Candidate 01:11:59,800 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Candidate - node1 (Candidate): Election: Candidate has following voting peers: [node2] 01:11:59,803 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - node1: Set currentTerm=2, votedFor=node1 01:11:59,803 AM [test-pekko.actor.default-dispatcher-16] [INFO] Candidate - node1 (Candidate): Starting new election term 2 01:11:59,803 AM [test-pekko.actor.default-dispatcher-16] [INFO] RaftActorBehavior - node1 (Follower) :- Switching from behavior Follower to Candidate, election term: 2 01:12:00,315 AM [test-pekko.actor.default-dispatcher-16] [WARN] RaftActorVotingConfigSupport - node1: Leader election timed out - cannot apply operation ChangeServersVotingStatus [serverVotingStatusMap={downNode2=false, node2=true, downNode1=false, node1=true}, serversVisited=[]] 01:12:00,316 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PeerInfos - node1: Updated server config: isVoting: false, peers: [PeerInfo [id=node2, address=null, votingState=NON_VOTING], PeerInfo [id=downNode2, address=null, votingState=VOTING], PeerInfo [id=downNode1, address=null, votingState=VOTING]] 01:12:00,316 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - node1: tryToForwardOperationToAnotherServer - servers already visited [] 01:12:00,316 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - node1: Returning NO_LEADER for operation ChangeServersVotingStatus [serverVotingStatusMap={downNode2=false, node2=true, downNode1=false, node1=true}, serversVisited=[]] 01:12:00,317 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SyncStatusTracker - node1: Last sync leader does not match current leader downNode1, need to catch up to 0 [WARN] [02/28/2026 01:12:00.317] [test-pekko.actor.default-dispatcher-16] [pekko://test/deadLetters] received dead letter from TestActor[pekko://test/user/node1]: AppendEntriesReply{term=2, success=true, followerId=node1, logLastIndex=0, logLastTerm=1, forceInstallSnapshot=false, needsLeaderAddress=true, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} [WARN] [02/28/2026 01:12:00.318] [test-pekko.actor.default-dispatcher-14] [pekko://test/user/node1] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=node1, initialSyncDone=false] 01:12:00,974 AM [main] [INFO] PeerInfos - node1: Peer address for peer node2 set to pekko://test/user/node2 01:12:00,974 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - node1: onChangeServersVotingStatus: ChangeServersVotingStatus [serverVotingStatusMap={downNode2=false, node2=true, downNode1=false, node1=true}, serversVisited=[]], state: Idle 01:12:00,975 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - Initiating ChangeServersVotingStatusState 01:12:00,975 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - node1: Sending local ElectionTimeout to start leader election 01:12:00,975 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PeerInfos - node1: Updated server config: isVoting: true, peers: [PeerInfo [id=node2, address=pekko://test/user/node2, votingState=VOTING], PeerInfo [id=downNode2, address=null, votingState=NON_VOTING], PeerInfo [id=downNode1, address=null, votingState=NON_VOTING]] 01:12:00,975 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - node1 (Follower): Received TimeoutNow - switching to Candidate 01:12:00,975 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Candidate - node1 (Candidate): Election: Candidate has following voting peers: [node2] 01:12:00,979 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - node1: Set currentTerm=3, votedFor=node1 01:12:00,979 AM [test-pekko.actor.default-dispatcher-14] [INFO] Candidate - node1 (Candidate): Starting new election term 3 01:12:00,979 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Candidate - node1 (Candidate): Sending RequestVote{term=3, candidateId=node1, lastLogIndex=0, lastLogTerm=1} to peer node2 01:12:00,980 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActorBehavior - node1 (Follower) :- Switching from behavior Follower to Candidate, election term: 3 01:12:00,980 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - node2 (Follower): Found higher term in RequestVote rpc, verifying whether it's safe to update term. 01:12:00,980 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - node2 (Follower): Cluster state: [] 01:12:00,980 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - node2 (Follower): Candidate in requestVote:RequestVote{term=3, candidateId=node1, lastLogIndex=0, lastLogTerm=1} with higher term appears reachable, updating term. 01:12:00,980 AM [test-pekko.actor.default-dispatcher-16] [INFO] Follower - node2 (Follower): Term 3 in "RequestVote{term=3, candidateId=node1, lastLogIndex=0, lastLogTerm=1}" message is greater than follower's term 1 - updating term 01:12:00,983 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - node2: Set currentTerm=3, votedFor=null 01:12:00,983 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - node2 (Follower): In requestVote: RequestVote{term=3, candidateId=node1, lastLogIndex=0, lastLogTerm=1} - currentTerm: 3, votedFor: null, lastIndex: 0, lastTerm: 1 01:12:00,986 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - node2: Set currentTerm=3, votedFor=node1 01:12:00,986 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - node2 (Follower): requestVote returning: RequestVoteReply{term=3, voteGranted=true} 01:12:00,986 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Candidate - node1 (Candidate): RaftRPC message received RequestVoteReply{term=3, voteGranted=true}, my term is 3 01:12:00,986 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Candidate - node1 (Candidate): handleRequestVoteReply: RequestVoteReply{term=3, voteGranted=true}, current voteCount: 1 01:12:00,986 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - node1 (Leader): Election: Leader has following peers: [node2, downNode2, downNode1] 01:12:00,987 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - node1 (Leader): Checking sendAppendEntries for follower node2: active: false, followerNextIndex: 0, leaderLastIndex: 0, leaderSnapShotIndex: -1 01:12:00,987 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActorBehavior - node1 (Candidate) :- Switching from behavior Candidate to Leader, election term: 3 01:12:00,987 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - node1: New leader node1 elected 01:12:00,987 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - node1: New server configuration : [ServerInfo[peerId=node2, isVoting=true], ServerInfo[peerId=downNode2, isVoting=false], ServerInfo[peerId=downNode1, isVoting=false], ServerInfo[peerId=node1, isVoting=true]] 01:12:00,987 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - node1: Persist data index=1 term=3 command=VotingConfig{serverInfo=[ServerInfo[peerId=node2, isVoting=true], ServerInfo[peerId=downNode2, isVoting=false], ServerInfo[peerId=downNode1, isVoting=false], ServerInfo[peerId=node1, isVoting=true]]} 01:12:00,987 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - node1: Append log entry and persist JournaledLogEntry{index=1, term=3, command=VotingConfig{serverInfo=[ServerInfo[peerId=node2, isVoting=true], ServerInfo[peerId=downNode2, isVoting=false], ServerInfo[peerId=downNode1, isVoting=false], ServerInfo[peerId=node1, isVoting=true]]}, pending=true} 01:12:00,987 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - node2: Last sync leader does not match current leader node1, need to catch up to -1 01:12:00,987 AM [node1-writer-79] [DEBUG] JournalWriteTask - node1: received 1 commands after 1.207 s [WARN] [02/28/2026 01:12:00.987] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/node2] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=node2, initialSyncDone=false] 01:12:00,987 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - node1 (Leader): Replicate message: identifier: ServerOperationContextIdentifier{value=9d4d2cec-287f-44a2-a0d5-0ac79338f394}, logIndex: 1, isSendImmediate: true 01:12:00,988 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - node1 (Leader): Checking sendAppendEntries for follower node2: active: false, followerNextIndex: 0, leaderLastIndex: 1, leaderSnapShotIndex: -1 01:12:00,988 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - node2: Lagging -1 entries behind leader node1 and reached 0 (of expected -1) 01:12:00,988 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - node1: Returning OK for operation ChangeServersVotingStatus [serverVotingStatusMap={downNode2=false, node2=true, downNode1=false, node1=true}, serversVisited=[]] [WARN] [02/28/2026 01:12:00.988] [test-pekko.actor.default-dispatcher-15] [pekko://test/user/node2] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=node2, initialSyncDone=true] 01:12:00,988 AM [node1-writer-79] [DEBUG] RaftStorageCompleter - node1: 1 completion(s) pending 01:12:00,988 AM [node1-writer-79] [DEBUG] JournalWriteTask - node1: completed 1 commands in 1.063 ms 01:12:00,988 AM [node1-writer-79] [DEBUG] JournalWriteTask - node1: waiting to receive commands 01:12:00,989 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - node1: running 1 completion(s) 01:12:00,989 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - node1: persist complete JournaledLogEntry{index=1, term=3, command=VotingConfig{serverInfo=[ServerInfo[peerId=node2, isVoting=true], ServerInfo[peerId=downNode2, isVoting=false], ServerInfo[peerId=downNode1, isVoting=false], ServerInfo[peerId=node1, isVoting=true]]}, pending=true} 01:12:00,989 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - node1 (Leader): handleAppendEntriesReply - FollowerLogInformation for node2 updated: matchIndex: 0, nextIndex: 1 01:12:00,989 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - node1 (Leader): Checking sendAppendEntries for follower node2: active: true, followerNextIndex: 1, leaderLastIndex: 1, leaderSnapShotIndex: -1 01:12:00,989 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - node1 (Leader): sendAppendEntries: 1 is present for follower node2 01:12:00,989 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - node1 (Leader): Sending AppendEntries to follower node2: AppendEntries{term=3, leaderId=node1, prevLogIndex=0, prevLogTerm=1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=1, term=3, command=VotingConfig{serverInfo=[ServerInfo[peerId=node2, isVoting=true], ServerInfo[peerId=downNode2, isVoting=false], ServerInfo[peerId=downNode1, isVoting=false], ServerInfo[peerId=node1, isVoting=true]]}, pending=false}]} 01:12:00,989 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - node1 (Leader): sendAppendEntries: 1 is present for follower node2 01:12:00,989 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - node2 (Follower): handleAppendEntries: AppendEntries{term=3, leaderId=node1, prevLogIndex=0, prevLogTerm=1, leaderCommit=0, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=5, leaderRaftVersion=5, entries==[JournaledLogEntry{index=1, term=3, command=VotingConfig{serverInfo=[ServerInfo[peerId=node2, isVoting=true], ServerInfo[peerId=downNode2, isVoting=false], ServerInfo[peerId=downNode1, isVoting=false], ServerInfo[peerId=node1, isVoting=true]]}, pending=false}]} 01:12:00,989 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - node2 (Follower): Number of entries to be appended = 1 01:12:00,989 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - node2 (Follower): After cleanup, lastIndex: 0, entries to be added from: 0 01:12:00,989 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - node2 (Follower): Append entry to log VotingConfig{serverInfo=[ServerInfo[peerId=node2, isVoting=true], ServerInfo[peerId=downNode2, isVoting=false], ServerInfo[peerId=downNode1, isVoting=false], ServerInfo[peerId=node1, isVoting=true]]} 01:12:00,989 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - node2: Append log entry and persist JournaledLogEntry{index=1, term=3, command=VotingConfig{serverInfo=[ServerInfo[peerId=node2, isVoting=true], ServerInfo[peerId=downNode2, isVoting=false], ServerInfo[peerId=downNode1, isVoting=false], ServerInfo[peerId=node1, isVoting=true]]}, pending=false} 01:12:00,989 AM [node2-writer-80] [DEBUG] JournalWriteTask - node2: received 1 commands after 1.203 s 01:12:00,989 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PeerInfos - node2: Updated server config: isVoting: true, peers: [PeerInfo [id=downNode2, address=null, votingState=NON_VOTING], PeerInfo [id=downNode1, address=null, votingState=NON_VOTING], PeerInfo [id=node1, address=null, votingState=VOTING]] 01:12:00,990 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - node2 (Follower): Log size is now 2 01:12:00,990 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] Follower - node2 (Follower): handleAppendEntries returning : AppendEntriesReply{term=3, success=true, followerId=node2, logLastIndex=1, logLastTerm=3, forceInstallSnapshot=false, needsLeaderAddress=true, payloadVersion=5, raftVersion=5, recipientRaftVersion=5} 01:12:00,990 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SyncStatusTracker - node2: Lagging 0 entries behind leader node1 and reached 0 (of expected -1) 01:12:00,990 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - node2: awaiting more completions to resolve 1 synchronized callback(s) 01:12:00,990 AM [node2-writer-80] [DEBUG] RaftStorageCompleter - node2: 1 completion(s) pending 01:12:00,990 AM [node2-writer-80] [DEBUG] JournalWriteTask - node2: completed 1 commands in 1.136 ms 01:12:00,990 AM [node2-writer-80] [DEBUG] JournalWriteTask - node2: waiting to receive commands 01:12:00,990 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - node2: running 1 completion(s) 01:12:00,990 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] ReplicatedLogImpl - node2: persist complete JournaledLogEntry{index=1, term=3, command=VotingConfig{serverInfo=[ServerInfo[peerId=node2, isVoting=true], ServerInfo[peerId=downNode2, isVoting=false], ServerInfo[peerId=downNode1, isVoting=false], ServerInfo[peerId=node1, isVoting=true]]}, pending=false} 01:12:00,990 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - node2: completed synchronized callback AppendReceivedCallback{entry=JournaledLogEntry{index=1, term=3, command=VotingConfig{serverInfo=[ServerInfo[peerId=node2, isVoting=true], ServerInfo[peerId=downNode2, isVoting=false], ServerInfo[peerId=downNode1, isVoting=false], ServerInfo[peerId=node1, isVoting=true]]}, pending=false}, callback=org.opendaylight.controller.cluster.raft.behaviors.Follower$$Lambda/0x00000007c0829ab0@1cb4350e} 01:12:00,990 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - node2: synchronized callbacks after 902.4 μs 01:12:00,991 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - node1 (Leader): handleAppendEntriesReply - FollowerLogInformation for node2 updated: matchIndex: 1, nextIndex: 2 01:12:00,991 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - node1 (Leader): Applying to log - commitIndex: 1, lastAppliedIndex: 0 01:12:00,991 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorBehavior - node1 (Leader): Setting last applied to 1 01:12:00,991 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractReplicatedLog - node1: Moving last applied index from 0 to 1 01:12:00,991 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - node1: Applying state for log index 1 data VotingConfig{serverInfo=[ServerInfo[peerId=node2, isVoting=true], ServerInfo[peerId=downNode2, isVoting=false], ServerInfo[peerId=downNode1, isVoting=false], ServerInfo[peerId=node1, isVoting=true]]} 01:12:00,991 AM [node1-writer-79] [DEBUG] JournalWriteTask - node1: received 1 commands after 2.500 ms 01:12:00,991 AM [node1-writer-79] [DEBUG] EntryJournalV1 - node1: updated meta to JournalMeta[replayFrom=1, applyTo=2] 01:12:00,991 AM [node1-writer-79] [DEBUG] RaftStorageCompleter - node1: 1 completion(s) pending 01:12:00,991 AM [node1-writer-79] [DEBUG] JournalWriteTask - node1: completed 1 commands in 189.4 μs 01:12:00,991 AM [node1-writer-79] [DEBUG] JournalWriteTask - node1: waiting to receive commands 01:12:00,991 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - node1 (Leader): Checking sendAppendEntries for follower node2: active: true, followerNextIndex: 2, leaderLastIndex: 1, leaderSnapShotIndex: -1 01:12:00,991 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorageCompleter - node1: running 1 completion(s) 01:12:00,991 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActorVotingConfigSupport - node1: VotingConfig{serverInfo=[ServerInfo[peerId=node2, isVoting=true], ServerInfo[peerId=downNode2, isVoting=false], ServerInfo[peerId=downNode1, isVoting=false], ServerInfo[peerId=node1, isVoting=true]]} has been successfully replicated to a majority of followers 01:12:00,991 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - node2 (Follower): Commit index set to 1 01:12:00,992 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - node2: Lagging 0 entries behind leader node1 and reached 1 (of expected -1) 01:12:00,992 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] Follower - node2 (Follower): applyLogToStateMachine, appendEntries.getLeaderCommit(): 1, context.getLastApplied(): 0, lastIndex(): 1 01:12:00,992 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorBehavior - node2 (Follower): Setting last applied to 1 01:12:00,992 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractReplicatedLog - node2: Moving last applied index from 0 to 1 01:12:00,992 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActor - node2: Applying state for log index 1 data VotingConfig{serverInfo=[ServerInfo[peerId=node2, isVoting=true], ServerInfo[peerId=downNode2, isVoting=false], ServerInfo[peerId=downNode1, isVoting=false], ServerInfo[peerId=node1, isVoting=true]]} 01:12:00,992 AM [node2-writer-80] [DEBUG] JournalWriteTask - node2: received 1 commands after 1.562 ms 01:12:00,992 AM [node2-writer-80] [DEBUG] EntryJournalV1 - node2: updated meta to JournalMeta[replayFrom=1, applyTo=2] 01:12:00,992 AM [node2-writer-80] [DEBUG] RaftStorageCompleter - node2: 1 completion(s) pending 01:12:00,992 AM [node2-writer-80] [DEBUG] JournalWriteTask - node2: completed 1 commands in 158.7 μs 01:12:00,992 AM [node2-writer-80] [DEBUG] JournalWriteTask - node2: waiting to receive commands 01:12:00,992 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] RaftStorageCompleter - node2: running 1 completion(s) 01:12:01,106 AM [test-pekko.actor.default-dispatcher-15] [DEBUG] SyncStatusTracker - node2: Lagging 0 entries behind leader node1 and reached 1 (of expected -1) 01:12:01,191 AM [main] [INFO] RaftActorVotingConfigSupportTest - testChangeToVotingWithNoLeader ending 01:12:01,192 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower206] 01:12:01,204 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/collector207#1826958798] 01:12:01,204 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/node1] 01:12:01,204 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EnabledRaftStorage - node1: terminating thread VirtualThread[#360,node1-writer-79]/waiting 01:12:01,205 AM [node1-writer-79] [DEBUG] JournalWriteTask - node1: received 1 commands after 213.7 ms 01:12:01,205 AM [node1-writer-79] [DEBUG] JournalWriteTask - node1: completed 1 commands in 41.69 μs 01:12:01,205 AM [node1-writer-79] [DEBUG] JournalWriteTask - node1: journal writer stopped 01:12:01,205 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EntryJournalV1 - node1: journal closed 01:12:01,205 AM [test-pekko.actor.default-dispatcher-14] [INFO] EnabledRaftStorage - node1: journal closed 01:12:01,205 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - node1: stopped executor with 0 remaining tasks 01:12:01,205 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - node1: stopped executor with 0 remaining tasks 01:12:01,206 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/collector208#182981259] 01:12:01,208 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/node2] 01:12:01,208 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EnabledRaftStorage - node2: terminating thread VirtualThread[#361,node2-writer-80]/waiting 01:12:01,208 AM [node2-writer-80] [DEBUG] JournalWriteTask - node2: received 1 commands after 216.3 ms 01:12:01,209 AM [node2-writer-80] [DEBUG] JournalWriteTask - node2: completed 1 commands in 18.50 μs 01:12:01,209 AM [node2-writer-80] [DEBUG] JournalWriteTask - node2: journal writer stopped 01:12:01,209 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EntryJournalV1 - node2: journal closed 01:12:01,209 AM [test-pekko.actor.default-dispatcher-14] [INFO] EnabledRaftStorage - node2: journal closed 01:12:01,209 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - node2: stopped executor with 0 remaining tasks 01:12:01,209 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - node2: stopped executor with 0 remaining tasks 01:12:01,214 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithPriorSnapshotCompleteTimeout starting 01:12:01,215 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupportTest$MockNewFollowerRaftActor - Actor created TestActor[pekko://test/user/new-server211] [WARN] [02/28/2026 01:12:01.215] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/new-server211]: org.opendaylight.controller.cluster.common.actor.Monitor@41d8d85f 01:12:01,216 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActor - new-server: Starting recovery with journal batch size 1000 01:12:01,216 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - new-server: started executor 01:12:01,216 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - new-server: started executor 01:12:01,217 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EntryJournalV1 - new-server: metadata journal open: replayFrom=1 applyTo=0 01:12:01,217 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EntryJournalV1 - new-server: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:12:01,217 AM [test-pekko.actor.default-dispatcher-14] [INFO] EnabledRaftStorage - new-server: journal open: applyTo=0 01:12:01,217 AM [new-server-writer-81] [DEBUG] JournalWriteTask - new-server: journal writer started 01:12:01,217 AM [new-server-writer-81] [DEBUG] JournalWriteTask - new-server: waiting to receive commands 01:12:01,217 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - new-server: recovering to non-persistent 01:12:01,217 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - /tmp/junit-17696548124263204583/new-server/TermInfo.properties does not exist 01:12:01,221 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=0, votedFor=null 01:12:01,221 AM [test-pekko.actor.default-dispatcher-14] [INFO] Recovery - new-server: Local TermInfo store seeded with TermInfo{term=0} 01:12:01,221 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-17696548124263204583/new-server/TermInfo.properties 01:12:01,221 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-17696548124263204583/new-server/journal-v1-1.log 01:12:01,221 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - new-server: skipping unrecognized file /tmp/junit-17696548124263204583/new-server/metadata-v1-1.log 01:12:01,221 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - new-server: no eligible files found 01:12:01,221 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractReplicatedLog - new-server: Moving last applied index from -1 to -1 01:12:01,221 AM [test-pekko.actor.default-dispatcher-14] [INFO] Recovery - new-server: Recovery completed in in 4.020 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:12:01,221 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - new-server: Recovery completed and can restore from snapshot 01:12:01,223 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupportTest$MockLeaderRaftActor - Actor created TestActor[pekko://test/user/leader212] [WARN] [02/28/2026 01:12:01.223] [test-pekko.actor.default-dispatcher-16] [pekko://test/user/termination-monitor] received dead letter from TestActor[pekko://test/user/leader212]: org.opendaylight.controller.cluster.common.actor.Monitor@6d2d7e2 01:12:01,223 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:12:01,223 AM [test-pekko.actor.default-dispatcher-14] [INFO] RaftActor - leader: Starting recovery with journal batch size 1000 01:12:01,223 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: started executor 01:12:01,223 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: started executor 01:12:01,224 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EntryJournalV1 - leader: metadata journal open: replayFrom=1 applyTo=0 01:12:01,224 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] EntryJournalV1 - leader: journal open: firstIndex=1 lastIndex=0 replayFrom=1 fileEntries=0 01:12:01,224 AM [test-pekko.actor.default-dispatcher-14] [INFO] EnabledRaftStorage - leader: journal open: applyTo=0 01:12:01,224 AM [leader-writer-82] [DEBUG] JournalWriteTask - leader: journal writer started 01:12:01,224 AM [leader-writer-82] [DEBUG] JournalWriteTask - leader: waiting to receive commands 01:12:01,224 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader: recovering to non-persistent 01:12:01,224 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - /tmp/junit-17696548124263204583/leader/TermInfo.properties does not exist 01:12:01,232 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] PropertiesTermInfoStore - leader: Set currentTerm=1, votedFor= 01:12:01,232 AM [test-pekko.actor.default-dispatcher-14] [INFO] Recovery - leader: Local TermInfo store seeded with TermInfo{term=1, votedFor=} 01:12:01,232 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-17696548124263204583/leader/TermInfo.properties 01:12:01,232 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-17696548124263204583/leader/journal-v1-1.log 01:12:01,232 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: skipping unrecognized file /tmp/junit-17696548124263204583/leader/metadata-v1-1.log 01:12:01,232 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftStorage - leader: no eligible files found 01:12:01,232 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractReplicatedLog - leader: Moving last applied index from -1 to -1 01:12:01,232 AM [test-pekko.actor.default-dispatcher-14] [INFO] Recovery - leader: Recovery completed in in 8.041 ms: last log index = -1, last log term = -1, napshot index = -1, snapshot term = -1, journal size = 0 01:12:01,232 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader: Recovery completed and can restore from snapshot 01:12:01,232 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractLeader - leader (Leader): Election: Leader has following peers: [] 01:12:01,234 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActor - leader: Take a snapshot of current state. lastReplicatedLog is null and replicatedToAllIndex is -1 01:12:01,234 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] AbstractReplicatedLog - leader: Capturing Snapshot : lastLogEntry is null. Using snapshot values lastAppliedIndex -1 and lastAppliedTerm -1 instead. 01:12:01,234 AM [test-pekko.actor.default-dispatcher-14] [INFO] SnapshotManager - leader: Initiating snapshot capture CaptureSnapshot [lastAppliedIndex=-1, lastAppliedTerm=-1, lastIndex=-1, lastTerm=-1, installSnapshotInitiated=, replicatedToAllIndex=-1, replicatedToAllTerm=-1, unAppliedEntries size=0, mandatoryTrim=true] 01:12:01,234 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SnapshotManager - leader: captured snapshot at lastSequenceNumber: 0 01:12:01,234 AM [test-pekko.actor.default-dispatcher-14] [INFO] SnapshotManager - leader: Persising snapshot at EntryInfo[index=-1, term=-1]/EntryInfo[index=-1, term=-1] 01:12:01,234 AM [test-pekko.actor.default-dispatcher-14] [INFO] MockRaftActor - leader: support() called 01:12:01,234 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SnapshotManager - leader: user triggered or root overwrite snapshot encountered, trimming log up to last applied index -1 01:12:01,234 AM [test-pekko.actor.default-dispatcher-14] [INFO] SnapshotManager - leader: Removed in-memory snapshotted entries, adjusted snapshotIndex: -1 and term: -1 01:12:01,234 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - leader: onAddServer: AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server211, votingMember=true], state: Idle 01:12:01,235 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - leader: Initiating AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server211, votingMember=true] 01:12:01,235 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] SnapshotManager - leader: captureToInstall should not be called in state PersistCapture[lastJournalIndex=0, request=CaptureSnapshot [lastAppliedIndex=-1, lastAppliedTerm=-1, lastIndex=-1, lastTerm=-1, installSnapshotInitiated=, replicatedToAllIndex=-1, replicatedToAllTerm=-1, unAppliedEntries size=0, mandatoryTrim=true]] 01:12:01,235 AM [test-pekko.actor.default-dispatcher-14] [DEBUG] RaftActorVotingConfigSupport - leader: Snapshot already in progress - waiting for completion 01:12:01,346 AM [test-pekko.actor.default-dispatcher-16] [INFO] Follower - new-server (Follower): Term 1 in "AppendEntries{term=1, leaderId=leader, prevLogIndex=-1, prevLogTerm=-1, leaderCommit=-1, replicatedToAllIndex=-1, payloadVersion=5, recipientRaftVersion=4, leaderRaftVersion=5, entries==[]}" message is greater than follower's term 0 - updating term 01:12:01,376 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] PropertiesTermInfoStore - new-server: Set currentTerm=1, votedFor=null 01:12:01,376 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] SyncStatusTracker - new-server: Last sync leader does not match current leader leader, need to catch up to -1 01:12:01,376 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): handleAppendEntriesReply - FollowerLogInformation for new-server updated: matchIndex: -1, nextIndex: 0 [WARN] [02/28/2026 01:12:01.377] [test-pekko.actor.default-dispatcher-14] [pekko://test/user/new-server211] unhandled message from Actor[pekko://test/deadLetters]: FollowerInitialSyncUpStatus[memberId=new-server, initialSyncDone=false] 01:12:01,377 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] AbstractLeader - leader (Leader): Checking sendAppendEntries for follower new-server: active: false, followerNextIndex: 0, leaderLastIndex: -1, leaderSnapShotIndex: -1 01:12:01,446 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: handleInstallSnapshotTimeout for new server new-server 01:12:01,446 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftActorVotingConfigSupport - leader: Returning TIMEOUT for operation AddServer [newServerId=new-server, newServerAddress=pekko://test/user/new-server211, votingMember=true] 01:12:01,447 AM [test-pekko.actor.default-dispatcher-16] [WARN] RaftActorVotingConfigSupport - leader: Timeout occured for new server new-server while waiting for prior snapshot to complete 01:12:01,447 AM [main] [INFO] RaftActorVotingConfigSupportTest - testAddServerWithPriorSnapshotCompleteTimeout ending 01:12:01,447 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/follower209] 01:12:01,449 AM [main] [INFO] TestActorFactory - Killing actor Actor[pekko://test/user/new-serverCollector210#-1530767512] 01:12:01,450 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/new-server211] 01:12:01,450 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EnabledRaftStorage - new-server: terminating thread VirtualThread[#364,new-server-writer-81]/waiting 01:12:01,450 AM [new-server-writer-81] [DEBUG] JournalWriteTask - new-server: received 1 commands after 232.9 ms 01:12:01,450 AM [new-server-writer-81] [DEBUG] JournalWriteTask - new-server: completed 1 commands in 57.57 μs 01:12:01,450 AM [new-server-writer-81] [DEBUG] JournalWriteTask - new-server: journal writer stopped 01:12:01,451 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - new-server: journal closed 01:12:01,451 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - new-server: journal closed 01:12:01,451 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:12:01,451 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - new-server: stopped executor with 0 remaining tasks 01:12:01,451 AM [main] [INFO] TestActorFactory - Killing actor TestActor[pekko://test/user/leader212] 01:12:01,451 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EnabledRaftStorage - leader: terminating thread VirtualThread[#365,leader-writer-82]/waiting 01:12:01,451 AM [leader-writer-82] [DEBUG] JournalWriteTask - leader: received 1 commands after 227.3 ms 01:12:01,452 AM [leader-writer-82] [DEBUG] JournalWriteTask - leader: completed 1 commands in 17.74 μs 01:12:01,452 AM [leader-writer-82] [DEBUG] JournalWriteTask - leader: journal writer stopped 01:12:01,452 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] EntryJournalV1 - leader: journal closed 01:12:01,452 AM [test-pekko.actor.default-dispatcher-16] [INFO] EnabledRaftStorage - leader: journal closed 01:12:01,452 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks 01:12:01,452 AM [test-pekko.actor.default-dispatcher-16] [DEBUG] RaftStorage - leader: stopped executor with 0 remaining tasks [INFO] [02/28/2026 01:12:01.455] [main] [CoordinatedShutdown(pekko://test)] Running CoordinatedShutdown with reason [ActorSystemTerminateReason] 01:12:01,455 AM [test-pekko.actor.default-dispatcher-14] [INFO] CoordinatedShutdown - Running CoordinatedShutdown with reason [ActorSystemTerminateReason] 01:12:01,458 AM [test-pekko.actor.default-dispatcher-16] [INFO] Cluster - Cluster Node [pekko://test@10.30.171.17:17355] - Exiting completed 01:12:01,458 AM [test-pekko.actor.default-dispatcher-16] [INFO] Cluster - Cluster Node [pekko://test@10.30.171.17:17355] - Shutting down... [WARN] [02/28/2026 01:12:01.457] [test-pekko.actor.default-dispatcher-14] [pekko://test/system/cluster/core/daemon] unhandled message from Actor[pekko://test/deadLetters]: Leave(pekko://test@10.30.171.17:17355) 01:12:01,458 AM [test-pekko.actor.default-dispatcher-16] [INFO] Cluster - Cluster Node [pekko://test@10.30.171.17:17355] - Successfully shut down [INFO] [02/28/2026 01:12:01.457] [test-pekko.actor.internal-dispatcher-4] [Cluster(pekko://test)] Cluster Node [pekko://test@10.30.171.17:17355] - Exiting completed [INFO] [02/28/2026 01:12:01.458] [test-pekko.actor.internal-dispatcher-4] [Cluster(pekko://test)] Cluster Node [pekko://test@10.30.171.17:17355] - Shutting down... [INFO] [02/28/2026 01:12:01.458] [test-pekko.actor.internal-dispatcher-4] [Cluster(pekko://test)] Cluster Node [pekko://test@10.30.171.17:17355] - Successfully shut down [INFO] [02/28/2026 01:12:01.462] [test-pekko.remote.default-remote-dispatcher-9] [pekko://test@10.30.171.17:17355/system/remoting-terminator] Shutting down remote daemon. [INFO] [02/28/2026 01:12:01.462] [test-pekko.remote.default-remote-dispatcher-9] [pekko://test@10.30.171.17:17355/system/remoting-terminator] Remote daemon shut down; proceeding with flushing remote transports. 01:12:01,465 AM [test-pekko.actor.default-dispatcher-14] [INFO] RemoteActorRefProvider$RemotingTerminator - Shutting down remote daemon. 01:12:01,465 AM [test-pekko.actor.default-dispatcher-14] [INFO] RemoteActorRefProvider$RemotingTerminator - Remote daemon shut down; proceeding with flushing remote transports. 01:12:01,465 AM [test-pekko.actor.default-dispatcher-14] [INFO] RemoteActorRefProvider$RemotingTerminator - Remoting shut down. [INFO] [02/28/2026 01:12:01.465] [test-pekko.remote.default-remote-dispatcher-8] [pekko://test@10.30.171.17:17355/system/remoting-terminator] Remoting shut down.