6331e0b7b29bba566d93315e3b6e7be596fff09e
[controller.git] / opendaylight / md-sal / sal-clustering-commons / src / test / java / org / opendaylight / controller / cluster / messaging / MessageSliceTest.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.assertArrayEquals;
11 import static org.junit.Assert.assertEquals;
12
13 import akka.actor.ActorSystem;
14 import akka.actor.ExtendedActorSystem;
15 import akka.serialization.JavaSerializer;
16 import akka.testkit.JavaTestKit;
17 import akka.testkit.TestProbe;
18 import org.apache.commons.lang.SerializationUtils;
19 import org.junit.After;
20 import org.junit.Before;
21 import org.junit.Test;
22
23 /**
24  * Unit tests for MessageSlice.
25  *
26  * @author Thomas Pantelis
27  */
28 public class MessageSliceTest {
29     private final ActorSystem actorSystem = ActorSystem.create("test");
30
31     @Before
32     public void setUp() {
33         JavaSerializer.currentSystem().value_$eq((ExtendedActorSystem) actorSystem);
34     }
35
36     @After
37     public void tearDown() {
38         JavaTestKit.shutdownActorSystem(actorSystem, Boolean.TRUE);
39     }
40
41     @Test
42     public void testSerialization() {
43         byte[] data = new byte[1000];
44         for (int i = 0, j = 0; i < data.length; i++) {
45             data[i] = (byte)j;
46             if (++j >= 255) {
47                 j = 0;
48             }
49         }
50
51         MessageSlice expected = new MessageSlice(new StringIdentifier("test"), data, 2, 3, 54321,
52                 TestProbe.apply(actorSystem).ref());
53         MessageSlice cloned = (MessageSlice) SerializationUtils.clone(expected);
54
55         assertEquals("getIdentifier", expected.getIdentifier(), cloned.getIdentifier());
56         assertEquals("getSliceIndex", expected.getSliceIndex(), cloned.getSliceIndex());
57         assertEquals("getTotalSlices", expected.getTotalSlices(), cloned.getTotalSlices());
58         assertEquals("getLastSliceHashCode", expected.getLastSliceHashCode(), cloned.getLastSliceHashCode());
59         assertArrayEquals("getData", expected.getData(), cloned.getData());
60         assertEquals("getReplyTo", expected.getReplyTo(), cloned.getReplyTo());
61     }
62 }