Merge "Bug-2590: Clustering : Minimize usage of in-memory journal"
[controller.git] / opendaylight / md-sal / sal-distributed-datastore / src / test / java / org / opendaylight / controller / cluster / datastore / CompositeModificationByteStringPayloadTest.java
1 /*
2  * Copyright (c) 2014 Cisco Systems, Inc. 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
9 package org.opendaylight.controller.cluster.datastore;
10
11 import java.util.ArrayList;
12 import java.util.List;
13 import org.apache.commons.lang.SerializationUtils;
14 import org.junit.Test;
15 import org.opendaylight.controller.cluster.datastore.modification.MutableCompositeModification;
16 import org.opendaylight.controller.cluster.datastore.modification.WriteModification;
17 import org.opendaylight.controller.cluster.raft.ReplicatedLogEntry;
18 import org.opendaylight.controller.cluster.raft.ReplicatedLogImplEntry;
19 import org.opendaylight.controller.cluster.raft.messages.AppendEntries;
20 import org.opendaylight.controller.cluster.raft.protobuff.client.messages.CompositeModificationByteStringPayload;
21 import org.opendaylight.controller.md.cluster.datastore.model.TestModel;
22 import org.opendaylight.yangtools.yang.data.impl.schema.ImmutableNodes;
23 import org.opendaylight.yangtools.yang.model.api.SchemaContext;
24
25 import static junit.framework.Assert.assertNotNull;
26 import static junit.framework.Assert.assertTrue;
27
28 @Deprecated
29 public class CompositeModificationByteStringPayloadTest {
30
31     private static final SchemaContext SCHEMA_CONTEXT = TestModel.createTestContext();
32
33     @Test
34     public void testSerialization(){
35         WriteModification writeModification =
36                 new WriteModification(TestModel.TEST_PATH, ImmutableNodes
37                         .containerNode(TestModel.TEST_QNAME));
38
39         MutableCompositeModification compositeModification =
40                 new MutableCompositeModification();
41
42         compositeModification.addModification(writeModification);
43
44         CompositeModificationByteStringPayload compositeModificationByteStringPayload
45                 = new CompositeModificationByteStringPayload(compositeModification.toSerializable());
46
47         byte[] bytes = SerializationUtils.serialize(compositeModificationByteStringPayload);
48
49         Object deserialize = SerializationUtils.deserialize(bytes);
50
51         assertTrue(deserialize instanceof CompositeModificationByteStringPayload);
52
53     }
54
55     @Test
56     public void testAppendEntries(){
57         List<ReplicatedLogEntry> entries = new ArrayList<>();
58
59         WriteModification writeModification = new WriteModification(TestModel.OUTER_LIST_PATH,
60                 ImmutableNodes.mapNodeBuilder(TestModel.OUTER_LIST_QNAME).build());
61
62         MutableCompositeModification compositeModification = new MutableCompositeModification();
63
64         compositeModification.addModification(writeModification);
65
66         CompositeModificationByteStringPayload payload =
67                 new CompositeModificationByteStringPayload(compositeModification.toSerializable());
68
69         payload.clearModificationReference();
70
71         entries.add(new ReplicatedLogImplEntry(0, 1, payload));
72
73         assertNotNull(new AppendEntries(10, "foobar", 10, 10, entries, 10, -1).toSerializable());
74     }
75 }