Switch to ARGON raft version
[controller.git] / opendaylight / md-sal / sal-akka-raft / src / main / java / org / opendaylight / controller / cluster / raft / persisted / NoopPayload.java
index 800ea45d15c087fe59b399df3444d7883d74edfc..1fa865948a3b3fcad6f0efa0d2bf9c30acf17a89 100644 (file)
@@ -9,6 +9,7 @@ package org.opendaylight.controller.cluster.raft.persisted;
 
 import akka.dispatch.ControlMessage;
 import java.io.Serializable;
+import org.apache.commons.lang3.SerializationUtils;
 import org.opendaylight.controller.cluster.raft.messages.Payload;
 
 /**
@@ -21,18 +22,25 @@ public final class NoopPayload extends Payload implements ControlMessage {
     public static final NoopPayload INSTANCE = new NoopPayload();
 
     // There is no need for Externalizable
+    @Deprecated(since = "7.0.0", forRemoval = true)
     private static final class Proxy implements Serializable {
+        @java.io.Serial
         private static final long serialVersionUID = 1L;
 
+        @java.io.Serial
         private Object readResolve() {
             return INSTANCE;
         }
     }
 
+    @java.io.Serial
     private static final long serialVersionUID = 1L;
-    private static final Proxy PROXY = new Proxy();
+    private static final NP PROXY = new NP();
+    // Estimate to how big the proxy is. Note this includes object stream overhead, so it is a bit conservative
+    private static final int PROXY_SIZE = SerializationUtils.serialize(PROXY).length;
 
     private NoopPayload() {
+        // Hidden on purpose
     }
 
     @Override
@@ -40,6 +48,11 @@ public final class NoopPayload extends Payload implements ControlMessage {
         return 0;
     }
 
+    @Override
+    public int serializedSize() {
+        return PROXY_SIZE;
+    }
+
     @Override
     protected Object writeReplace() {
         return PROXY;