Bug 7449: Add message slicing/re-assembly classes
[controller.git] / opendaylight / md-sal / sal-clustering-commons / src / test / java / org / opendaylight / controller / cluster / messaging / MessageSliceReplyTest.java
1 /*
2  * Copyright (c) 2017 Inocybe Technologies and others.  All rights reserved.
3  *
4  * This program and the accompanying materials are made available under the
5  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6  * and is available at http://www.eclipse.org/legal/epl-v10.html
7  */
8 package org.opendaylight.controller.cluster.messaging;
9
10 import static org.junit.Assert.assertEquals;
11
12 import akka.actor.ActorSystem;
13 import akka.actor.ExtendedActorSystem;
14 import akka.serialization.JavaSerializer;
15 import akka.testkit.JavaTestKit;
16 import akka.testkit.TestProbe;
17 import org.apache.commons.lang.SerializationUtils;
18 import org.junit.After;
19 import org.junit.Before;
20 import org.junit.Test;
21
22 /**
23  * Unit tests for MessageSliceReply.
24  *
25  * @author Thomas Pantelis
26  */
27 public class MessageSliceReplyTest {
28     private final ActorSystem actorSystem = ActorSystem.create("test");
29
30     @Before
31     public void setUp() {
32         JavaSerializer.currentSystem().value_$eq((ExtendedActorSystem) actorSystem);
33     }
34
35     @After
36     public void tearDown() {
37         JavaTestKit.shutdownActorSystem(actorSystem, Boolean.TRUE);
38     }
39
40     @Test
41     public void testSerialization() {
42         testSuccess();
43         testFailure();
44     }
45
46     private void testSuccess() {
47         MessageSliceReply expected = MessageSliceReply.success(new StringIdentifier("test"), 3,
48                 TestProbe.apply(actorSystem).ref());
49         MessageSliceReply cloned = (MessageSliceReply) SerializationUtils.clone(expected);
50
51         assertEquals("getIdentifier", expected.getIdentifier(), cloned.getIdentifier());
52         assertEquals("getSliceIndex", expected.getSliceIndex(), cloned.getSliceIndex());
53         assertEquals("getSendTo", expected.getSendTo(), cloned.getSendTo());
54         assertEquals("getFailure present", Boolean.FALSE, cloned.getFailure().isPresent());
55     }
56
57     private void testFailure() {
58         MessageSliceReply expected = MessageSliceReply.failed(new StringIdentifier("test"),
59                 new MessageSliceException("mock", true), TestProbe.apply(actorSystem).ref());
60         MessageSliceReply cloned = (MessageSliceReply) SerializationUtils.clone(expected);
61
62         assertEquals("getIdentifier", expected.getIdentifier(), cloned.getIdentifier());
63         assertEquals("getSliceIndex", expected.getSliceIndex(), cloned.getSliceIndex());
64         assertEquals("getSendTo", expected.getSendTo(), cloned.getSendTo());
65         assertEquals("getFailure present", Boolean.TRUE, cloned.getFailure().isPresent());
66         assertEquals("getFailure message", expected.getFailure().get().getMessage(),
67                 cloned.getFailure().get().getMessage());
68         assertEquals("getFailure isRetriable", expected.getFailure().get().isRetriable(),
69                 cloned.getFailure().get().isRetriable());
70     }
71 }