Improve segmented journal actor metrics
[controller.git] / opendaylight / md-sal / sal-distributed-datastore / src / test / java / org / opendaylight / controller / cluster / datastore / persisted / AbstractIdentifiablePayloadTest.java
1 /*
2  * Copyright (c) 2017 Pantheon Technologies s.r.o. 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.datastore.persisted;
9
10 import static java.util.Objects.requireNonNull;
11 import static org.junit.Assert.assertEquals;
12
13 import org.apache.commons.lang3.SerializationUtils;
14 import org.junit.Test;
15 import org.opendaylight.controller.cluster.datastore.AbstractTest;
16
17 abstract class AbstractIdentifiablePayloadTest<T extends AbstractIdentifiablePayload<?>> extends AbstractTest {
18     private final T object;
19     private final int expectedSize;
20
21     AbstractIdentifiablePayloadTest(final T object, final int expectedSize) {
22         this.object = requireNonNull(object);
23         this.expectedSize = expectedSize;
24     }
25
26     @Test
27     public void testSerialization() {
28         final byte[] bytes = SerializationUtils.serialize(object);
29         assertEquals(expectedSize, bytes.length);
30         final T cloned = SerializationUtils.deserialize(bytes);
31         assertEquals(object.getIdentifier(), cloned.getIdentifier());
32     }
33 }