Add specific serializer for SimpleReplicatedLogEntry
[controller.git] / opendaylight / md-sal / sal-akka-raft / src / test / java / org / opendaylight / controller / cluster / raft / persisted / SimpleReplicatedLogEntrySerializerTest.java
diff --git a/opendaylight/md-sal/sal-akka-raft/src/test/java/org/opendaylight/controller/cluster/raft/persisted/SimpleReplicatedLogEntrySerializerTest.java b/opendaylight/md-sal/sal-akka-raft/src/test/java/org/opendaylight/controller/cluster/raft/persisted/SimpleReplicatedLogEntrySerializerTest.java
new file mode 100644 (file)
index 0000000..be48c06
--- /dev/null
@@ -0,0 +1,49 @@
+/*
+ * Copyright (c) 2018 Red Hat, Inc. and others. All rights reserved.
+ *
+ * This program and the accompanying materials are made available under the
+ * terms of the Eclipse Public License v1.0 which accompanies this distribution,
+ * and is available at http://www.eclipse.org/legal/epl-v10.html
+ */
+package org.opendaylight.controller.cluster.raft.persisted;
+
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertNotNull;
+
+import akka.actor.ExtendedActorSystem;
+import akka.testkit.javadsl.TestKit;
+import java.io.NotSerializableException;
+import org.junit.Test;
+import org.opendaylight.controller.cluster.raft.MockRaftActorContext;
+
+/**
+ * Unit tests for SimpleReplicatedLogEntrySerializer.
+ *
+ * @author Thomas Pantelis
+ */
+public class SimpleReplicatedLogEntrySerializerTest {
+
+    @Test
+    public void testToAndFromBinary() throws NotSerializableException {
+        SimpleReplicatedLogEntry expected = new SimpleReplicatedLogEntry(0, 1,
+                new MockRaftActorContext.MockPayload("A"));
+
+        final ExtendedActorSystem system = (ExtendedActorSystem) ExtendedActorSystem.create("test");
+        final Object deserialized;
+        try {
+            final SimpleReplicatedLogEntrySerializer serializer = new SimpleReplicatedLogEntrySerializer(system);
+            final byte[] bytes = serializer.toBinary(expected);
+            deserialized = serializer.fromBinary(bytes, SimpleReplicatedLogEntry.class);
+        } finally {
+            TestKit.shutdownActorSystem(system);
+        }
+
+        assertNotNull("fromBinary returned null", deserialized);
+        assertEquals("fromBinary return type", SimpleReplicatedLogEntry.class, deserialized.getClass());
+
+        SimpleReplicatedLogEntry actual = (SimpleReplicatedLogEntry)deserialized;
+        assertEquals("getTerm", expected.getTerm(), actual.getTerm());
+        assertEquals("getIndex", expected.getIndex(), actual.getIndex());
+        assertEquals("getData", expected.getData(), actual.getData());
+    }
+}