Reset replyReceivedForOffset correctly 31/82731/2
authorTomas Cere <tomas.cere@pantheon.tech>
Tue, 25 Jun 2019 12:16:50 +0000 (14:16 +0200)
committerRobert Varga <nite@hq.sk>
Wed, 26 Jun 2019 10:10:45 +0000 (10:10 +0000)
replyReceivedForOffset needs to be set to the initial -1
otherwise we can have multiple sendSnapshotChunk()'s called
before receiving any replies. Which would fail due to the already
running stopwatch.

Change-Id: Ie708f0c2454a87f77cba97e4fed8a9ffc866b624
Signed-off-by: Tomas Cere <tomas.cere@pantheon.tech>
(cherry picked from commit 78282f605d76598e3b0e30cfc660a3a6c38ace48)

opendaylight/md-sal/sal-akka-raft/src/main/java/org/opendaylight/controller/cluster/raft/behaviors/LeaderInstallSnapshotState.java

index 758345214841ba62ab41af0827427a505562198f..b362530d575964d3d3b5144e490518062970200f 100644 (file)
@@ -174,10 +174,11 @@ public final class LeaderInstallSnapshotState implements AutoCloseable {
 
         offset = 0;
         replyStatus = false;
-        replyReceivedForOffset = offset;
+        replyReceivedForOffset = INITIAL_LAST_CHUNK_HASH_CODE;
         chunkIndex = FIRST_CHUNK_INDEX;
         currentChunk = null;
         lastChunkHashCode = INITIAL_LAST_CHUNK_HASH_CODE;
+        nextChunkHashCode = INITIAL_LAST_CHUNK_HASH_CODE;
 
         try {
             snapshotInputStream = snapshotBytes.openStream();