1 package org.opendaylight.controller.cluster.datastore;
3 import org.junit.After;
4 import org.junit.Assert;
6 import org.opendaylight.controller.cluster.datastore.modification.MutableCompositeModification;
7 import org.opendaylight.controller.cluster.datastore.modification.WriteModification;
8 import org.opendaylight.controller.cluster.raft.ReplicatedLogEntry;
9 import org.opendaylight.controller.cluster.raft.messages.AppendEntries;
10 import org.opendaylight.controller.cluster.raft.protobuff.client.messages.Payload;
11 import org.opendaylight.controller.cluster.raft.protobuff.messages.AppendEntriesMessages;
12 import org.opendaylight.controller.md.cluster.datastore.model.TestModel;
13 import org.opendaylight.yangtools.yang.data.impl.schema.ImmutableNodes;
16 import java.io.FileInputStream;
17 import java.io.FileOutputStream;
18 import java.io.IOException;
19 import java.util.ArrayList;
20 import java.util.List;
22 public class CompositeModificationPayloadTest {
25 private static final String SERIALIZE_OUT = "serialize.out";
28 public void shutDown(){
29 File f = new File(SERIALIZE_OUT);
36 public void testBasic() throws IOException {
38 List<ReplicatedLogEntry> entries = new ArrayList<>();
40 entries.add(0, new ReplicatedLogEntry() {
41 @Override public Payload getData() {
42 WriteModification writeModification =
43 new WriteModification(TestModel.TEST_PATH, ImmutableNodes
44 .containerNode(TestModel.TEST_QNAME),
45 TestModel.createTestContext());
47 MutableCompositeModification compositeModification =
48 new MutableCompositeModification();
50 compositeModification.addModification(writeModification);
52 return new CompositeModificationPayload(compositeModification.toSerializable());
55 @Override public long getTerm() {
59 @Override public long getIndex() {
64 AppendEntries appendEntries =
65 new AppendEntries(1, "member-1", 0, 100, entries, 1);
67 AppendEntriesMessages.AppendEntries o = (AppendEntriesMessages.AppendEntries) appendEntries.toSerializable();
69 o.writeDelimitedTo(new FileOutputStream(SERIALIZE_OUT));
71 AppendEntriesMessages.AppendEntries appendEntries2 =
72 AppendEntriesMessages.AppendEntries
73 .parseDelimitedFrom(new FileInputStream(SERIALIZE_OUT));
75 AppendEntries appendEntries1 = AppendEntries.fromSerializable(appendEntries2);
77 Payload data = appendEntries1.getEntries().get(0).getData();
80 Assert.assertTrue(((CompositeModificationPayload) data).getModification().toString().contains(TestModel.TEST_QNAME.getNamespace().toString()));