X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;ds=sidebyside;f=opendaylight%2Fmd-sal%2Fsal-clustering-commons%2Fsrc%2Ftest%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fmessaging%2FMessageSliceReplyTest.java;fp=opendaylight%2Fmd-sal%2Fsal-clustering-commons%2Fsrc%2Ftest%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fmessaging%2FMessageSliceReplyTest.java;h=fa31fbfeef60dd98348878f922945aa2f4c5b20f;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/MessageSliceReplyTest.java b/opendaylight/md-sal/sal-clustering-commons/src/test/java/org/opendaylight/controller/cluster/messaging/MessageSliceReplyTest.java new file mode 100644 index 0000000000..fa31fbfeef --- /dev/null +++ b/opendaylight/md-sal/sal-clustering-commons/src/test/java/org/opendaylight/controller/cluster/messaging/MessageSliceReplyTest.java @@ -0,0 +1,71 @@ +/* + * 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.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 MessageSliceReply. + * + * @author Thomas Pantelis + */ +public class MessageSliceReplyTest { + 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() { + testSuccess(); + testFailure(); + } + + private void testSuccess() { + MessageSliceReply expected = MessageSliceReply.success(new StringIdentifier("test"), 3, + TestProbe.apply(actorSystem).ref()); + MessageSliceReply cloned = (MessageSliceReply) SerializationUtils.clone(expected); + + assertEquals("getIdentifier", expected.getIdentifier(), cloned.getIdentifier()); + assertEquals("getSliceIndex", expected.getSliceIndex(), cloned.getSliceIndex()); + assertEquals("getSendTo", expected.getSendTo(), cloned.getSendTo()); + assertEquals("getFailure present", Boolean.FALSE, cloned.getFailure().isPresent()); + } + + private void testFailure() { + MessageSliceReply expected = MessageSliceReply.failed(new StringIdentifier("test"), + new MessageSliceException("mock", true), TestProbe.apply(actorSystem).ref()); + MessageSliceReply cloned = (MessageSliceReply) SerializationUtils.clone(expected); + + assertEquals("getIdentifier", expected.getIdentifier(), cloned.getIdentifier()); + assertEquals("getSliceIndex", expected.getSliceIndex(), cloned.getSliceIndex()); + assertEquals("getSendTo", expected.getSendTo(), cloned.getSendTo()); + assertEquals("getFailure present", Boolean.TRUE, cloned.getFailure().isPresent()); + assertEquals("getFailure message", expected.getFailure().get().getMessage(), + cloned.getFailure().get().getMessage()); + assertEquals("getFailure isRetriable", expected.getFailure().get().isRetriable(), + cloned.getFailure().get().isRetriable()); + } +}