2 package org.opendaylight.controller.cluster.datastore;
4 import akka.actor.ActorRef;
5 import akka.actor.Props;
6 import junit.framework.Assert;
8 import org.opendaylight.controller.cluster.datastore.messages.DataChanged;
9 import org.opendaylight.controller.cluster.datastore.utils.ActorContext;
10 import org.opendaylight.controller.cluster.datastore.utils.DoNothingActor;
11 import org.opendaylight.controller.cluster.datastore.utils.MessageCollectorActor;
12 import org.opendaylight.controller.cluster.datastore.utils.MockConfiguration;
13 import org.opendaylight.controller.md.sal.common.api.data.AsyncDataChangeEvent;
14 import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier;
15 import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
17 import java.util.List;
21 public class DataChangeListenerProxyTest extends AbstractActorTest {
23 private static class MockDataChangeEvent implements
24 AsyncDataChangeEvent<InstanceIdentifier,NormalizedNode<?,?>> {
27 public Map<InstanceIdentifier, NormalizedNode<?, ?>> getCreatedData() {
28 throw new UnsupportedOperationException("getCreatedData");
32 public Map<InstanceIdentifier, NormalizedNode<?, ?>> getUpdatedData() {
33 throw new UnsupportedOperationException("getUpdatedData");
36 @Override public Set<InstanceIdentifier> getRemovedPaths() {
37 throw new UnsupportedOperationException("getRemovedPaths");
41 public Map<InstanceIdentifier, NormalizedNode<?, ?>> getOriginalData() {
42 throw new UnsupportedOperationException("getOriginalData");
45 @Override public NormalizedNode<?, ?> getOriginalSubtree() {
46 throw new UnsupportedOperationException("getOriginalSubtree");
49 @Override public NormalizedNode<?, ?> getUpdatedSubtree() {
50 throw new UnsupportedOperationException("getUpdatedSubtree");
55 public void testOnDataChanged() throws Exception {
56 final Props props = Props.create(MessageCollectorActor.class);
57 final ActorRef actorRef = getSystem().actorOf(props);
59 DataChangeListenerProxy dataChangeListenerProxy =
60 new DataChangeListenerProxy(
61 getSystem().actorSelection(actorRef.path()));
63 dataChangeListenerProxy.onDataChanged(new MockDataChangeEvent());
65 //Check if it was received by the remote actor
67 testContext = new ActorContext(getSystem(), getSystem().actorOf(Props.create(DoNothingActor.class)), new MockConfiguration());
68 Object messages = testContext
69 .executeLocalOperation(actorRef, "messages",
70 ActorContext.ASK_DURATION);
72 Assert.assertNotNull(messages);
74 Assert.assertTrue(messages instanceof List);
76 List<Object> listMessages = (List<Object>) messages;
78 Assert.assertEquals(1, listMessages.size());
80 Assert.assertTrue(listMessages.get(0) instanceof DataChanged);