Removed uncessary calls to RpcBroker to find routes.
[controller.git] / opendaylight / md-sal / sal-remoterpc-connector / src / test / java / org / opendaylight / controller / remote / rpc / RpcListenerTest.java
index ecfaef841979421553297616d3c5ec84fd0c6ade..37d81c7afb7859e9e18b616afdef46befad71f42 100644 (file)
@@ -8,26 +8,70 @@
 
 package org.opendaylight.controller.remote.rpc;
 
+
+import akka.actor.ActorRef;
 import akka.actor.ActorSystem;
 import akka.testkit.JavaTestKit;
 import com.typesafe.config.ConfigFactory;
+import java.net.URISyntaxException;
+import java.util.Collections;
 import org.junit.AfterClass;
 import org.junit.BeforeClass;
+import org.junit.Test;
+import org.opendaylight.controller.md.sal.dom.api.DOMRpcIdentifier;
+import org.opendaylight.controller.remote.rpc.registry.RpcRegistry;
+import org.opendaylight.yangtools.yang.common.QName;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
+import org.opendaylight.yangtools.yang.model.api.SchemaPath;
 
 public class RpcListenerTest {
 
-  static ActorSystem system;
+    private static final QName TEST_QNAME = QName.create("test", "2015-06-12", "test");
+    private static final SchemaPath RPC_TYPE = SchemaPath.create(true, TEST_QNAME);
+    private static final YangInstanceIdentifier TEST_PATH = YangInstanceIdentifier
+            .create(new YangInstanceIdentifier.NodeIdentifier(TEST_QNAME));
+    private static final DOMRpcIdentifier RPC_ID = DOMRpcIdentifier.create(RPC_TYPE, TEST_PATH);
+    static ActorSystem system;
+
+
+    @BeforeClass
+    public static void setup() throws InterruptedException {
+        system = ActorSystem.create("opendaylight-rpc", ConfigFactory.load().getConfig("odl-cluster-rpc"));
+    }
+
+    @AfterClass
+    public static void teardown() {
+        JavaTestKit.shutdownActorSystem(system);
+        system = null;
+    }
 
+    @Test
+    public void testRouteAdd() throws URISyntaxException, InterruptedException {
+        new JavaTestKit(system) {
+            {
+                // Test announcements
+                final JavaTestKit probeReg = new JavaTestKit(system);
+                final ActorRef rpcRegistry = probeReg.getRef();
 
-  @BeforeClass
-  public static void setup() throws InterruptedException {
-    system = ActorSystem.create("opendaylight-rpc", ConfigFactory.load().getConfig("odl-cluster-rpc"));
-  }
+                final RpcListener rpcListener = new RpcListener(rpcRegistry);
+                rpcListener.onRpcAvailable(Collections.singleton(RPC_ID));
+                probeReg.expectMsgClass(RpcRegistry.Messages.AddOrUpdateRoutes.class);
+            }
+        };
+    }
 
-  @AfterClass
-  public static void teardown() {
-    JavaTestKit.shutdownActorSystem(system);
-    system = null;
-  }
+    @Test
+    public void testRouteRemove() throws URISyntaxException, InterruptedException {
+        new JavaTestKit(system) {
+            {
+                // Test announcements
+                final JavaTestKit probeReg = new JavaTestKit(system);
+                final ActorRef rpcRegistry = probeReg.getRef();
 
+                final RpcListener rpcListener = new RpcListener(rpcRegistry);
+                rpcListener.onRpcUnavailable(Collections.singleton(RPC_ID));
+                probeReg.expectMsgClass(RpcRegistry.Messages.RemoveRoutes.class);
+            }
+        };
+    }
 }