X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-clustering-commons%2Fsrc%2Ftest%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fmessaging%2FMessageSliceTest.java;fp=opendaylight%2Fmd-sal%2Fsal-clustering-commons%2Fsrc%2Ftest%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fmessaging%2FMessageSliceTest.java;h=6331e0b7b29bba566d93315e3b6e7be596fff09e;hb=3582bb6dbc506b0c79dd3e4b4f791f4e17cd3103;hp=0000000000000000000000000000000000000000;hpb=90ba78e0575edaa56610eeed936c03261839f2d2;p=controller.git diff --git a/opendaylight/md-sal/sal-clustering-commons/src/test/java/org/opendaylight/controller/cluster/messaging/MessageSliceTest.java b/opendaylight/md-sal/sal-clustering-commons/src/test/java/org/opendaylight/controller/cluster/messaging/MessageSliceTest.java new file mode 100644 index 0000000000..6331e0b7b2 --- /dev/null +++ b/opendaylight/md-sal/sal-clustering-commons/src/test/java/org/opendaylight/controller/cluster/messaging/MessageSliceTest.java @@ -0,0 +1,62 @@ +/* + * Copyright (c) 2017 Inocybe Technologies 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.messaging; + +import static org.junit.Assert.assertArrayEquals; +import static org.junit.Assert.assertEquals; + +import akka.actor.ActorSystem; +import akka.actor.ExtendedActorSystem; +import akka.serialization.JavaSerializer; +import akka.testkit.JavaTestKit; +import akka.testkit.TestProbe; +import org.apache.commons.lang.SerializationUtils; +import org.junit.After; +import org.junit.Before; +import org.junit.Test; + +/** + * Unit tests for MessageSlice. + * + * @author Thomas Pantelis + */ +public class MessageSliceTest { + private final ActorSystem actorSystem = ActorSystem.create("test"); + + @Before + public void setUp() { + JavaSerializer.currentSystem().value_$eq((ExtendedActorSystem) actorSystem); + } + + @After + public void tearDown() { + JavaTestKit.shutdownActorSystem(actorSystem, Boolean.TRUE); + } + + @Test + public void testSerialization() { + byte[] data = new byte[1000]; + for (int i = 0, j = 0; i < data.length; i++) { + data[i] = (byte)j; + if (++j >= 255) { + j = 0; + } + } + + MessageSlice expected = new MessageSlice(new StringIdentifier("test"), data, 2, 3, 54321, + TestProbe.apply(actorSystem).ref()); + MessageSlice cloned = (MessageSlice) SerializationUtils.clone(expected); + + assertEquals("getIdentifier", expected.getIdentifier(), cloned.getIdentifier()); + assertEquals("getSliceIndex", expected.getSliceIndex(), cloned.getSliceIndex()); + assertEquals("getTotalSlices", expected.getTotalSlices(), cloned.getTotalSlices()); + assertEquals("getLastSliceHashCode", expected.getLastSliceHashCode(), cloned.getLastSliceHashCode()); + assertArrayEquals("getData", expected.getData(), cloned.getData()); + assertEquals("getReplyTo", expected.getReplyTo(), cloned.getReplyTo()); + } +}