Resubmitted with source code synchronized. Added integration test for hosttracker...
[controller.git] / opendaylight / hosttracker / integrationtest / src / test / java / org / opendaylight / controller / hosttracker / internal / HostTrackerIntegrationTest.java
diff --git a/opendaylight/hosttracker/integrationtest/src/test/java/org/opendaylight/controller/hosttracker/internal/HostTrackerIntegrationTest.java b/opendaylight/hosttracker/integrationtest/src/test/java/org/opendaylight/controller/hosttracker/internal/HostTrackerIntegrationTest.java
new file mode 100644 (file)
index 0000000..f351d1a
--- /dev/null
@@ -0,0 +1,323 @@
+\r
+/*\r
+ * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.\r
+ *\r
+ * This program and the accompanying materials are made available under the\r
+ * terms of the Eclipse Public License v1.0 which accompanies this distribution,\r
+ * and is available at http://www.eclipse.org/legal/epl-v10.html\r
+ */\r
+\r
+package org.opendaylight.controller.hosttracker.internal;\r
+\r
+\r
+import java.net.InetAddress;\r
+import java.net.UnknownHostException;\r
+import java.util.ArrayList;\r
+import java.util.HashSet;\r
+import java.util.Iterator;\r
+import java.util.List;\r
+import java.util.Map;\r
+import java.util.Set;\r
+import java.util.Map.Entry;\r
+\r
+import org.slf4j.Logger;\r
+import org.slf4j.LoggerFactory;\r
+import org.osgi.framework.ServiceReference;\r
+import org.osgi.framework.Bundle;\r
+import javax.inject.Inject;\r
+\r
+import org.eclipse.osgi.framework.console.CommandProvider;\r
+import org.junit.Assert;\r
+import org.junit.Test;\r
+import org.junit.Before;\r
+import org.junit.After;\r
+import org.junit.runner.RunWith;\r
+import org.opendaylight.controller.sal.core.Node;\r
+import org.opendaylight.controller.sal.core.NodeConnector;\r
+import org.opendaylight.controller.sal.core.UpdateType;\r
+import org.opendaylight.controller.sal.utils.NodeConnectorCreator;\r
+import org.opendaylight.controller.sal.utils.NodeCreator;\r
+import org.opendaylight.controller.sal.utils.Status;\r
+//import org.opendaylight.controller.hosttracker.*;\r
+import org.opendaylight.controller.hosttracker.IfIptoHost;\r
+import org.opendaylight.controller.hosttracker.IfHostListener;\r
+import org.opendaylight.controller.hosttracker.hostAware.HostNodeConnector;\r
+import org.opendaylight.controller.switchmanager.IInventoryListener;\r
+import org.opendaylight.controller.switchmanager.ISwitchManager;\r
+import org.opendaylight.controller.switchmanager.ISwitchManagerAware;\r
+import org.opendaylight.controller.topologymanager.ITopologyManagerAware;\r
+\r
+import org.ops4j.pax.exam.junit.PaxExam;\r
+import org.ops4j.pax.exam.util.Filter;\r
+import org.osgi.framework.BundleContext;\r
+import static org.junit.Assert.*;\r
+import org.ops4j.pax.exam.junit.Configuration;\r
+import static org.ops4j.pax.exam.CoreOptions.*;\r
+\r
+import org.ops4j.pax.exam.Option;\r
+import org.ops4j.pax.exam.util.PathUtils;\r
+import org.ops4j.pax.exam.spi.reactors.ExamReactorStrategy;\r
+import org.ops4j.pax.exam.spi.reactors.PerClass;\r
+\r
+@RunWith(PaxExam.class)\r
+public class HostTrackerIntegrationTest {\r
+    private Logger log = LoggerFactory\r
+            .getLogger(HostTrackerIntegrationTest.class);\r
+    // get the OSGI bundle context\r
+    @Inject\r
+    private BundleContext bc;\r
+    \r
+    private IfIptoHost hosttracker = null;\r
+    private ISwitchManagerAware switchManagerAware = null;\r
+    private IInventoryListener invtoryListener = null;\r
+    private IfHostListener hostListener = null;\r
+    private ITopologyManagerAware topologyManagerAware = null;\r
+    \r
+    // Configure the OSGi container\r
+    @Configuration\r
+    public Option[] config() {\r
+        return options(\r
+                //\r
+                systemProperty("logback.configurationFile").value(\r
+                        "file:" + PathUtils.getBaseDir()\r
+                                + "/src/test/resources/logback.xml"),\r
+                // To start OSGi console for inspection remotely\r
+                systemProperty("osgi.console").value("2401"),\r
+                // Set the systemPackages (used by clustering)\r
+                systemPackages("sun.reflect", "sun.reflect.misc", "sun.misc"),\r
+                // List framework bundles\r
+                mavenBundle("equinoxSDK381", "org.eclipse.equinox.console",\r
+                        "1.0.0.v20120522-1841"),\r
+                mavenBundle("equinoxSDK381", "org.eclipse.equinox.util",\r
+                        "1.0.400.v20120522-2049"),\r
+                mavenBundle("equinoxSDK381", "org.eclipse.osgi.services",\r
+                        "3.3.100.v20120522-1822"),\r
+                mavenBundle("equinoxSDK381", "org.eclipse.equinox.ds",\r
+                        "1.4.0.v20120522-1841"),\r
+                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.command",\r
+                        "0.8.0.v201108120515"),\r
+                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.runtime",\r
+                        "0.8.0.v201108120515"),\r
+                mavenBundle("equinoxSDK381", "org.apache.felix.gogo.shell",\r
+                        "0.8.0.v201110170705"),\r
+                // List logger bundles\r
+                mavenBundle("org.slf4j", "slf4j-api", "1.7.2"),\r
+                mavenBundle("org.slf4j", "log4j-over-slf4j", "1.7.2"),\r
+                mavenBundle("ch.qos.logback", "logback-core", "1.0.9"),\r
+                mavenBundle("ch.qos.logback", "logback-classic", "1.0.9"),\r
+                \r
+                // List all the bundles on which the test case depends\r
+                mavenBundle("org.opendaylight.controller", "sal",\r
+                        "0.4.0-SNAPSHOT"),\r
+                mavenBundle("org.opendaylight.controller", "sal.implementation",\r
+                        "0.4.0-SNAPSHOT"),\r
+\r
+               // needed by statisticsmanager\r
+               mavenBundle("org.opendaylight.controller", "containermanager",\r
+                        "0.4.0-SNAPSHOT"),\r
+               mavenBundle("org.opendaylight.controller", "containermanager.implementation",\r
+                       "0.4.0-SNAPSHOT"),\r
+               \r
+               mavenBundle("org.opendaylight.controller",\r
+                        "clustering.services", "0.4.0-SNAPSHOT"),\r
+               mavenBundle("org.opendaylight.controller",\r
+                        "clustering.services-implementation", "0.4.0-SNAPSHOT"),\r
+\r
+                // needed by forwardingrulesmanager\r
+                mavenBundle("org.opendaylight.controller", "switchmanager",\r
+                        "0.4.0-SNAPSHOT"),\r
+                mavenBundle("org.opendaylight.controller", "switchmanager.implementation",\r
+                        "0.4.0-SNAPSHOT"),\r
+                mavenBundle("org.opendaylight.controller", "configuration",\r
+                        "0.4.0-SNAPSHOT"),\r
+                mavenBundle("org.opendaylight.controller",\r
+                        "configuration.implementation", "0.4.0-SNAPSHOT"),\r
+                mavenBundle("org.opendaylight.controller", "hosttracker",\r
+                        "0.4.0-SNAPSHOT"),\r
+                mavenBundle("org.opendaylight.controller", "hosttracker.implementation",\r
+                        "0.4.0-SNAPSHOT"),\r
+\r
+                // needed by hosttracker\r
+                mavenBundle("org.opendaylight.controller", "topologymanager",\r
+                        "0.4.0-SNAPSHOT"),\r
+                mavenBundle("org.opendaylight.controller", "arphandler",\r
+                        "0.4.0-SNAPSHOT"),\r
+\r
+\r
+                mavenBundle("org.jboss.spec.javax.transaction",\r
+                        "jboss-transaction-api_1.1_spec", "1.0.1.Final"),\r
+                mavenBundle("org.apache.commons", "commons-lang3", "3.1"),\r
+                mavenBundle("org.apache.felix",\r
+                        "org.apache.felix.dependencymanager", "3.1.0"),\r
+                junitBundles());\r
+    }\r
+\r
+    private String stateToString(int state) {\r
+        switch (state) {\r
+        case Bundle.ACTIVE:\r
+            return "ACTIVE";\r
+        case Bundle.INSTALLED:\r
+            return "INSTALLED";\r
+        case Bundle.RESOLVED:\r
+            return "RESOLVED";\r
+        case Bundle.UNINSTALLED:\r
+            return "UNINSTALLED";\r
+        default:\r
+            return "Not CONVERTED";\r
+        }\r
+    }\r
+\r
+    @Before\r
+    public void areWeReady() {\r
+        assertNotNull(bc);\r
+        boolean debugit = false;\r
+        Bundle b[] = bc.getBundles();\r
+        for (int i = 0; i < b.length; i++) {\r
+            int state = b[i].getState();\r
+            if (state != Bundle.ACTIVE && state != Bundle.RESOLVED) {\r
+                log.debug("Bundle:" + b[i].getSymbolicName() + " state:"\r
+                        + stateToString(state));\r
+                debugit = true;\r
+            }\r
+        }\r
+        if (debugit) {\r
+            log.debug("Do some debugging because some bundle is "\r
+                    + "unresolved");\r
+        }\r
+\r
+        // Assert if true, if false we are good to go!\r
+        assertFalse(debugit);\r
+\r
+         // Now lets create a hosttracker for testing purpose\r
+         ServiceReference s = bc\r
+             .getServiceReference(IfIptoHost.class.getName());\r
+         if (s != null) {\r
+                 this.hosttracker = (IfIptoHost)bc.getService(s);\r
+                 this.switchManagerAware = (ISwitchManagerAware) this.hosttracker;\r
+                 this.invtoryListener = (IInventoryListener) this.hosttracker;\r
+                 this.hostListener = (IfHostListener) this.hosttracker;\r
+                 this.topologyManagerAware = (ITopologyManagerAware) this.hosttracker;\r
+         }\r
+\r
+         // If StatisticsManager is null, cannot run tests.\r
+         assertNotNull(this.hosttracker);\r
+    }\r
+    \r
+    \r
+    @Test\r
+    public void testStaticHost() throws UnknownHostException {\r
+        String ip;\r
+        \r
+        assertNotNull(this.hosttracker);\r
+        \r
+        // create one node and two node connectors\r
+        Node node1 = NodeCreator.createOFNode(1L);\r
+        NodeConnector nc1_1 = NodeConnectorCreator.createOFNodeConnector((short) 1, node1);\r
+        NodeConnector nc1_2 = NodeConnectorCreator.createOFNodeConnector((short) 2, node1);\r
+        \r
+        // test addStaticHost(), store into inactive host DB \r
+        Status st = this.hosttracker.addStaticHost("192.168.0.8", "11:22:33:44:55:66",\r
+                nc1_1, "0");\r
+        Assert.assertTrue(st.isSuccess());\r
+        st = this.hosttracker.addStaticHost("192.168.0.13", "11:22:33:44:55:77",\r
+                nc1_2, "0");\r
+        Assert.assertTrue(st.isSuccess());\r
+        \r
+        // check inactive DB\r
+        Iterator<HostNodeConnector> hnci = this.hosttracker.getInactiveStaticHosts().iterator();\r
+        while (hnci.hasNext()) {\r
+            ip = hnci.next().getNetworkAddressAsString();\r
+            Assert.assertTrue(ip.equals("192.168.0.8") || ip.equals("192.168.0.13"));\r
+        }\r
+        \r
+        // check active host DB\r
+        hnci = this.hosttracker.getActiveStaticHosts().iterator();\r
+        Assert.assertFalse(hnci.hasNext());\r
+        \r
+        // test removeStaticHost()\r
+        st = this.hosttracker.removeStaticHost("192.168.0.8");\r
+        Assert.assertTrue(st.isSuccess());\r
+\r
+        hnci = this.hosttracker.getInactiveStaticHosts().iterator();\r
+        while (hnci.hasNext()) {\r
+            ip = hnci.next().getNetworkAddressAsString();\r
+            Assert.assertTrue(ip.equals("192.168.0.13"));\r
+        }\r
+    }               \r
+            \r
+\r
+    \r
+    @Test\r
+    public void testNotifyNodeConnector() throws UnknownHostException {\r
+        String ip;\r
+        \r
+        assertNotNull(this.invtoryListener);\r
+\r
+        // create one node and two node connectors\r
+        Node node1 = NodeCreator.createOFNode(1L);\r
+        NodeConnector nc1_1 = NodeConnectorCreator.createOFNodeConnector((short) 1, node1);\r
+        NodeConnector nc1_2 = NodeConnectorCreator.createOFNodeConnector((short) 2, node1);\r
+        \r
+        // test addStaticHost(), put into inactive host DB if not verifiable\r
+        Status st = this.hosttracker.addStaticHost("192.168.0.8", "11:22:33:44:55:66",\r
+                nc1_1, "0");\r
+        st = this.hosttracker.addStaticHost("192.168.0.13", "11:22:33:44:55:77",\r
+                nc1_2, "0");\r
+        \r
+        this.invtoryListener.notifyNodeConnector(nc1_1,\r
+                UpdateType.ADDED, null);\r
+\r
+        // check all host list\r
+        Iterator<HostNodeConnector> hnci = this.hosttracker\r
+                .getAllHosts().iterator();\r
+        while (hnci.hasNext()) {\r
+            ip = hnci.next().getNetworkAddressAsString();\r
+            Assert.assertTrue(ip.equals("192.168.0.8"));\r
+        }\r
+        \r
+        // check active host DB\r
+        hnci = this.hosttracker.getActiveStaticHosts().iterator();\r
+        while (hnci.hasNext()) {\r
+            ip = hnci.next().getNetworkAddressAsString();\r
+            Assert.assertTrue(ip.equals("192.168.0.8"));\r
+        }\r
+        \r
+        // check inactive host DB\r
+        hnci = this.hosttracker.getInactiveStaticHosts().iterator();\r
+        while (hnci.hasNext()) {\r
+            ip = hnci.next().getNetworkAddressAsString();\r
+            Assert.assertTrue(ip.equals("192.168.0.13"));\r
+        }\r
+    }\r
+    \r
+    \r
+    \r
+    @Test\r
+    public void testHostFind() throws UnknownHostException {\r
+        \r
+        assertNotNull(this.invtoryListener);\r
+\r
+        // create one node and two node connectors\r
+        Node node1 = NodeCreator.createOFNode(1L);\r
+        NodeConnector nc1_1 = NodeConnectorCreator.createOFNodeConnector((short) 1, node1);\r
+        NodeConnector nc1_2 = NodeConnectorCreator.createOFNodeConnector((short) 2, node1);\r
+        \r
+        // test addStaticHost(), put into inactive host DB if not verifiable\r
+        Status st = this.hosttracker.addStaticHost(\r
+                "192.168.0.8", "11:22:33:44:55:66", nc1_1, "0");\r
+        st = this.hosttracker.addStaticHost(\r
+                "192.168.0.13", "11:22:33:44:55:77", nc1_2, "0");\r
+        \r
+        HostNodeConnector hnc_1 = this.hosttracker\r
+                .hostFind(InetAddress.getByName("192.168.0.8"));\r
+        assertNull(hnc_1);\r
+        \r
+        this.invtoryListener.notifyNodeConnector(nc1_1,\r
+                UpdateType.ADDED, null);\r
+\r
+        hnc_1 = this.hosttracker.hostFind(InetAddress.getByName("192.168.0.8"));\r
+        assertNotNull(hnc_1);\r
+        \r
+    }\r
+    \r
+}\r