1 package org.opendaylight.controller.cluster.datastore;
4 import java.io.FileInputStream;
5 import java.io.FileOutputStream;
6 import java.io.IOException;
7 import java.util.ArrayList;
9 import org.junit.After;
10 import org.junit.Assert;
11 import org.junit.Test;
12 import org.opendaylight.controller.cluster.datastore.modification.MutableCompositeModification;
13 import org.opendaylight.controller.cluster.datastore.modification.WriteModification;
14 import org.opendaylight.controller.cluster.raft.RaftVersions;
15 import org.opendaylight.controller.cluster.raft.ReplicatedLogEntry;
16 import org.opendaylight.controller.cluster.raft.messages.AppendEntries;
17 import org.opendaylight.controller.cluster.raft.protobuff.client.messages.CompositeModificationPayload;
18 import org.opendaylight.controller.cluster.raft.protobuff.client.messages.Payload;
19 import org.opendaylight.controller.md.cluster.datastore.model.TestModel;
20 import org.opendaylight.controller.protobuff.messages.cluster.raft.AppendEntriesMessages;
21 import org.opendaylight.yangtools.yang.data.impl.schema.ImmutableNodes;
23 public class CompositeModificationPayloadTest {
26 private static final String SERIALIZE_OUT = "serialize.out";
29 public void shutDown(){
30 File f = new File(SERIALIZE_OUT);
37 public void testBasic() throws IOException {
39 List<ReplicatedLogEntry> entries = new ArrayList<>();
41 entries.add(0, new ReplicatedLogEntry() {
42 @Override public Payload getData() {
43 WriteModification writeModification =
44 new WriteModification(TestModel.TEST_PATH, ImmutableNodes
45 .containerNode(TestModel.TEST_QNAME),
46 TestModel.createTestContext());
48 MutableCompositeModification compositeModification =
49 new MutableCompositeModification();
51 compositeModification.addModification(writeModification);
53 return new CompositeModificationPayload(compositeModification.toSerializable());
56 @Override public long getTerm() {
60 @Override public long getIndex() {
66 return getData().size();
70 AppendEntries appendEntries =
71 new AppendEntries(1, "member-1", 0, 100, entries, 1);
73 AppendEntriesMessages.AppendEntries o = (AppendEntriesMessages.AppendEntries)
74 appendEntries.toSerializable(RaftVersions.HELIUM_VERSION);
76 o.writeDelimitedTo(new FileOutputStream(SERIALIZE_OUT));
78 AppendEntriesMessages.AppendEntries appendEntries2 =
79 AppendEntriesMessages.AppendEntries
80 .parseDelimitedFrom(new FileInputStream(SERIALIZE_OUT));
82 AppendEntries appendEntries1 = AppendEntries.fromSerializable(appendEntries2);
84 Payload data = appendEntries1.getEntries().get(0).getData();
87 Assert.assertTrue(((CompositeModificationPayload) data).getModification().toString().contains(TestModel.TEST_QNAME.getNamespace().toString()));