<module>../../containermanager/api</module>
<module>../../containermanager/implementation</module>
<module>../../switchmanager</module>
- <module>../../statisticsmanager</module>
+ <module>../../statisticsmanager/api</module>
+ <module>../../statisticsmanager/implementation</module>
+ <module>../../statisticsmanager/integrationtest</module>
<module>../../topologymanager</module>
<module>../../usermanager</module>
<module>../../security</module>
<!-- Southbound bundles -->
<module>../../protocol_plugins/openflow</module>
+ <module>../../protocol_plugins/stub</module>
<!-- Samples -->
<module>../../samples/simpleforwarding</module>
--- /dev/null
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+ xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+ <modelVersion>4.0.0</modelVersion>
+ <parent>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>commons.opendaylight</artifactId>
+ <version>1.4.0-SNAPSHOT</version>
+ <relativePath>../../commons/opendaylight</relativePath>
+ </parent>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>protocol_plugins.stub</artifactId>
+ <version>0.4.0-SNAPSHOT</version>
+ <packaging>bundle</packaging>
+ <build>
+ <plugins>
+ <plugin>
+ <groupId>org.apache.felix</groupId>
+ <artifactId>maven-bundle-plugin</artifactId>
+ <version>2.3.6</version>
+ <extensions>true</extensions>
+ <configuration>
+ <instructions>
+ <Import-Package> org.opendaylight.controller.sal.packet,
+ org.opendaylight.controller.sal.action,
+ org.opendaylight.controller.sal.discovery,
+ org.opendaylight.controller.sal.topology,
+ org.opendaylight.controller.sal.core,
+ org.opendaylight.controller.sal.flowprogrammer,
+ org.opendaylight.controller.sal.reader,
+ org.opendaylight.controller.sal.inventory,
+ org.opendaylight.controller.sal.match,
+ org.opendaylight.controller.sal.utils,
+ org.apache.commons.lang3.builder,
+ org.apache.commons.lang3.tuple, org.apache.felix.dm,
+ org.slf4j, org.eclipse.osgi.framework.console,
+ org.osgi.framework
+ </Import-Package>
+ <Export-Package>
+ org.opendaylight.controller.protocol_plugins.stub.internal
+ </Export-Package>
+ <Bundle-Activator>
+ org.opendaylight.controller.protocol_plugins.stub.internal.Activator
+ </Bundle-Activator>
+ </instructions>
+ </configuration>
+ </plugin>
+ </plugins>
+ </build>
+ <dependencies>
+ <dependency>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>sal</artifactId>
+ <version>0.4.0-SNAPSHOT</version>
+ </dependency>
+ <dependency>
+ <groupId>junit</groupId>
+ <artifactId>junit</artifactId>
+ <version>4.8.1</version>
+ <scope>test</scope>
+ </dependency>
+ </dependencies>
+</project>
\ No newline at end of file
--- /dev/null
+package org.opendaylight.controller.protocol_plugins.stub.internal;
+
+import java.util.Dictionary;
+import java.util.Hashtable;
+
+import org.apache.felix.dm.Component;
+
+import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
+import org.opendaylight.controller.sal.core.IContainerListener;
+import org.opendaylight.controller.sal.core.Node;
+import org.opendaylight.controller.sal.discovery.IDiscoveryService;
+import org.opendaylight.controller.sal.flowprogrammer.IPluginInFlowProgrammerService;
+import org.opendaylight.controller.sal.inventory.IPluginInInventoryService;
+import org.opendaylight.controller.sal.inventory.IPluginOutInventoryService;
+import org.opendaylight.controller.sal.packet.IPluginInDataPacketService;
+import org.opendaylight.controller.sal.packet.IPluginOutDataPacketService;
+import org.opendaylight.controller.sal.reader.IPluginInReadService;
+import org.opendaylight.controller.sal.reader.IReadService;
+import org.opendaylight.controller.sal.topology.IPluginInTopologyService;
+import org.opendaylight.controller.sal.topology.IPluginOutTopologyService;
+import org.opendaylight.controller.sal.utils.GlobalConstants;
+
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+/**
+ * stub protocol plugin Activator
+ *
+ *
+ */
+public class Activator extends ComponentActivatorAbstractBase {
+ protected static final Logger logger = LoggerFactory
+ .getLogger(Activator.class);
+
+ /**
+ * Function called when the activator starts just after some initializations
+ * are done by the ComponentActivatorAbstractBase.
+ *
+ */
+ public void init() {
+ }
+
+ /**
+ * Function called when the activator stops just before the cleanup done by
+ * ComponentActivatorAbstractBase
+ *
+ */
+ public void destroy() {
+ }
+
+ /**
+ * Function that is used to communicate to dependency manager the list of
+ * known implementations for services inside a container
+ *
+ *
+ * @return An array containing all the CLASS objects that will be
+ * instantiated in order to get an fully working implementation
+ * Object
+ */
+ public Object[] getImplementations() {
+ Object[] res = { ReadService.class };
+ return res;
+ }
+
+ /**
+ * Function that is called when configuration of the dependencies is
+ * required.
+ *
+ * @param c
+ * dependency manager Component object, used for configuring the
+ * dependencies exported and imported
+ * @param imp
+ * Implementation class that is being configured, needed as long
+ * as the same routine can configure multiple implementations
+ * @param containerName
+ * The containerName being configured, this allow also optional
+ * per-container different behavior if needed, usually should not
+ * be the case though.
+ */
+ public void configureInstance(Component c, Object imp, String containerName) {
+ if (imp.equals(ReadService.class)) {
+ // export the service to be used by SAL
+ Dictionary<String, Object> props = new Hashtable<String, Object>();
+ // Set the protocolPluginType property which will be used
+ // by SAL
+ props.put("protocolPluginType", Node.NodeIDType.OPENFLOW);
+ c.setInterface(IPluginInReadService.class.getName(), props);
+ }
+ }
+
+}
--- /dev/null
+package org.opendaylight.controller.protocol_plugins.stub.internal;
+
+import java.net.InetAddress;
+import java.net.UnknownHostException;
+import java.util.ArrayList;
+import java.util.Dictionary;
+import java.util.List;
+
+import org.apache.felix.dm.Component;
+//import org.opendaylight.controller.protocol_plugin_stubs.IPluginReadServiceFilter;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+import org.opendaylight.controller.sal.action.Action;
+import org.opendaylight.controller.sal.action.Drop;
+import org.opendaylight.controller.sal.core.Node;
+import org.opendaylight.controller.sal.core.NodeConnector;
+import org.opendaylight.controller.sal.flowprogrammer.Flow;
+import org.opendaylight.controller.sal.match.Match;
+import org.opendaylight.controller.sal.match.MatchType;
+import org.opendaylight.controller.sal.reader.FlowOnNode;
+import org.opendaylight.controller.sal.reader.IPluginInReadService;
+import org.opendaylight.controller.sal.reader.NodeConnectorStatistics;
+import org.opendaylight.controller.sal.reader.NodeDescription;
+
+/**
+ * Stub Implementation for IPluginInReadService used by SAL
+ *
+ *
+ */
+public class ReadService implements IPluginInReadService {
+ private static final Logger logger = LoggerFactory
+ .getLogger(ReadService.class);
+
+ /**
+ * Function called by the dependency manager when all the required
+ * dependencies are satisfied
+ *
+ */
+ void init() {
+ }
+
+ /**
+ * Function called by the dependency manager when at least one dependency
+ * become unsatisfied or when the component is shutting down because for
+ * example bundle is being stopped.
+ *
+ */
+ void destroy() {
+ }
+
+ /**
+ * Function called by dependency manager after "init ()" is called and after
+ * the services provided by the class are registered in the service registry
+ *
+ */
+ void start() {
+ }
+
+ /**
+ * Function called by the dependency manager before the services exported by
+ * the component are unregistered, this will be followed by a "destroy ()"
+ * calls
+ *
+ */
+ void stop() {
+ }
+
+ @Override
+ public FlowOnNode readFlow(Node node, Flow flow, boolean cached) {
+ FlowOnNode fn1 = new FlowOnNode(flow);
+ fn1.setByteCount(100);
+ fn1.setDurationNanoseconds(400);
+ fn1.setDurationSeconds(40);
+ fn1.setTableId((byte) 0x1);
+ fn1.setPacketCount(200);
+ return fn1;
+ }
+
+ @Override
+ public List<FlowOnNode> readAllFlow(Node node, boolean cached) {
+ Flow flow = new Flow();
+
+ Match match = new Match();
+ try {
+ match.setField(MatchType.NW_DST, InetAddress.getByName("1.1.1.1"));
+ } catch (UnknownHostException e) {
+
+ }
+ flow.setMatch(match);
+ Action action = new Drop();
+
+ List<Action> actions = new ArrayList<Action>();
+ actions.add(action);
+ flow.setActions(actions);
+
+ FlowOnNode fn1 = new FlowOnNode(flow);
+ fn1.setByteCount(100);
+ fn1.setDurationNanoseconds(400);
+ fn1.setDurationSeconds(40);
+ fn1.setTableId((byte) 0x1);
+ fn1.setPacketCount(200);
+
+ ArrayList<FlowOnNode> list = new ArrayList<FlowOnNode>();
+ list.add(fn1);
+ return list;
+ }
+
+ @Override
+ public NodeDescription readDescription(Node node, boolean cached) {
+ NodeDescription desc = new NodeDescription();
+ desc.setDescription("This is a sample node description");
+ desc.setHardware("stub hardware");
+ desc.setSoftware("stub software");
+ desc.setSerialNumber("123");
+ desc.setManufacturer("opendaylight");
+ return desc;
+ }
+
+ @Override
+ public NodeConnectorStatistics readNodeConnector(NodeConnector connector,
+ boolean cached) {
+ NodeConnectorStatistics stats = new NodeConnectorStatistics();
+ stats.setNodeConnector(connector);
+ stats.setCollisionCount(4);
+ stats.setReceiveByteCount(1000);
+ stats.setReceiveCRCErrorCount(1);
+ stats.setReceiveDropCount(2);
+ stats.setReceiveErrorCount(3);
+ stats.setReceiveFrameErrorCount(5);
+ stats.setReceiveOverRunErrorCount(6);
+ stats.setReceivePacketCount(250);
+ stats.setTransmitByteCount(5000);
+ stats.setTransmitDropCount(50);
+ stats.setTransmitErrorCount(10);
+ stats.setTransmitPacketCount(500);
+
+ return stats;
+ }
+
+ @Override
+ public List<NodeConnectorStatistics> readAllNodeConnector(Node node,
+ boolean cached) {
+ NodeConnector nc = NodeConnector.fromStringNoNode("123", node);
+ NodeConnectorStatistics stats = new NodeConnectorStatistics();
+ stats.setNodeConnector(nc);
+ stats.setCollisionCount(4);
+ stats.setReceiveByteCount(1000);
+ stats.setReceiveCRCErrorCount(1);
+ stats.setReceiveDropCount(2);
+ stats.setReceiveErrorCount(3);
+ stats.setReceiveFrameErrorCount(5);
+ stats.setReceiveOverRunErrorCount(6);
+ stats.setReceivePacketCount(250);
+ stats.setTransmitByteCount(5000);
+ stats.setTransmitDropCount(50);
+ stats.setTransmitErrorCount(10);
+ stats.setTransmitPacketCount(500);
+
+ List<NodeConnectorStatistics> result = new ArrayList<NodeConnectorStatistics>();
+ result.add(stats);
+ return result;
+ }
+
+ @Override
+ public long getTransmitRate(NodeConnector connector) {
+ return 100;
+ }
+
+}
<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+ xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.opendaylight.controller</groupId>
<artifactId>commons.opendaylight</artifactId>
<version>1.4.0-SNAPSHOT</version>
- <relativePath>../commons/opendaylight</relativePath>
+ <relativePath>../../commons/opendaylight</relativePath>
</parent>
-
<groupId>org.opendaylight.controller</groupId>
<artifactId>statisticsmanager</artifactId>
<version>0.4.0-SNAPSHOT</version>
<packaging>bundle</packaging>
-
<build>
<plugins>
<plugin>
- <groupId>org.apache.felix</groupId>
- <artifactId>maven-bundle-plugin</artifactId>
- <version>2.3.6</version>
- <extensions>true</extensions>
- <configuration>
- <instructions>
- <Import-Package>
- org.opendaylight.controller.forwardingrulesmanager,
- org.opendaylight.controller.containermanager,
- org.opendaylight.controller.sal.core,
- org.opendaylight.controller.sal.flowprogrammer,
- org.slf4j,
- org.opendaylight.controller.sal.reader,
- org.apache.felix.dm
- </Import-Package>
- <Bundle-Activator>
- org.opendaylight.controller.statisticsmanager.internal.Activator
- </Bundle-Activator>
- <Export-Package>
- org.opendaylight.controller.statisticsmanager
- </Export-Package>
- </instructions>
- </configuration>
+ <groupId>org.apache.felix</groupId>
+ <artifactId>maven-bundle-plugin</artifactId>
+ <version>2.3.6</version>
+ <extensions>true</extensions>
+ <configuration>
+ <instructions>
+ <Import-Package>
+ org.opendaylight.controller.forwardingrulesmanager,
+ org.opendaylight.controller.containermanager,
+ org.opendaylight.controller.sal.core,
+ org.opendaylight.controller.sal.flowprogrammer, org.slf4j,
+ org.opendaylight.controller.sal.reader,
+ org.apache.felix.dm
+ </Import-Package>
+ <Export-Package>
+ org.opendaylight.controller.statisticsmanager
+ </Export-Package>
+ </instructions>
+ </configuration>
</plugin>
</plugins>
</build>
<artifactId>forwardingrulesmanager</artifactId>
<version>0.4.0-SNAPSHOT</version>
</dependency>
- <dependency>
+ <dependency>
<groupId>org.opendaylight.controller</groupId>
<artifactId>clustering.services</artifactId>
<version>0.4.0-SNAPSHOT</version>
</dependency>
</dependencies>
-</project>
+</project>
\ No newline at end of file
--- /dev/null
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+ xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+ <modelVersion>4.0.0</modelVersion>
+ <parent>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>commons.opendaylight</artifactId>
+ <version>1.4.0-SNAPSHOT</version>
+ <relativePath>../../commons/opendaylight</relativePath>
+ </parent>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>statisticsmanager.implementation</artifactId>
+ <version>0.4.0-SNAPSHOT</version>
+ <packaging>bundle</packaging>
+ <properties>
+ <!-- Sonar properties using jacoco to retrieve integration test results -->
+ <sonar.java.coveragePlugin>jacoco</sonar.java.coveragePlugin>
+ <sonar.dynamicAnalysis>reuseReports</sonar.dynamicAnalysis>
+ <sonar.jacoco.Reportpath>target/jacobo.exec</sonar.jacoco.Reportpath>
+ <sonar.jacoco.itReportPath>target/jacoco-it.exec</sonar.jacoco.itReportPath>
+ <sonar.language>java</sonar.language>
+ </properties>
+ <build>
+ <pluginManagement>
+ <plugins>
+ <plugin>
+ <groupId>org.jacoco</groupId>
+ <artifactId>jacoco-maven-plugin</artifactId>
+ <version>0.5.3.201107060350</version>
+ </plugin>
+ </plugins>
+ </pluginManagement>
+ <plugins>
+ <plugin>
+ <groupId>org.apache.felix</groupId>
+ <artifactId>maven-bundle-plugin</artifactId>
+ <version>2.3.6</version>
+ <extensions>true</extensions>
+ <configuration>
+ <instructions>
+ <Import-Package>
+ org.opendaylight.controller.containermanager,
+ org.opendaylight.controller.sal.core,
+ org.opendaylight.controller.sal.flowprogrammer, org.slf4j,
+ org.opendaylight.controller.sal.reader,
+ org.opendaylight.controller.statisticsmanager,
+ org.opendaylight.controller.forwardingrulesmanager,
+ org.apache.felix.dm
+ </Import-Package>
+ <Bundle-Activator>
+ org.opendaylight.controller.statisticsmanager.internal.Activator
+ </Bundle-Activator>
+ <Export-Package>
+ </Export-Package>
+ </instructions>
+ </configuration>
+ </plugin>
+ <plugin>
+ <groupId>org.jacoco</groupId>
+ <artifactId>jacoco-maven-plugin</artifactId>
+ <configuration>
+ <includes>org.opendaylight.controller.*</includes>
+ </configuration>
+ <executions>
+ <execution>
+ <id>pre-test</id>
+ <goals>
+ <goal>prepare-agent</goal>
+ </goals>
+ </execution>
+ <execution>
+ <id>post-test</id>
+ <phase>test</phase>
+ <goals>
+ <goal>report</goal>
+ </goals>
+ </execution>
+ </executions>
+ </plugin>
+ </plugins>
+ </build>
+ <dependencies>
+ <dependency>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>statisticsmanager</artifactId>
+ <version>0.4.0-SNAPSHOT</version>
+ </dependency>
+ <dependency>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>sal</artifactId>
+ <version>0.4.0-SNAPSHOT</version>
+ </dependency>
+ <dependency>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>containermanager</artifactId>
+ <version>0.4.0-SNAPSHOT</version>
+ </dependency>
+ <dependency>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>forwardingrulesmanager</artifactId>
+ <version>0.4.0-SNAPSHOT</version>
+ </dependency>
+ <dependency>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>clustering.services</artifactId>
+ <version>0.4.0-SNAPSHOT</version>
+ </dependency>
+ </dependencies>
+</project>
\ No newline at end of file
import org.opendaylight.controller.sal.core.ComponentActivatorAbstractBase;
import org.opendaylight.controller.sal.reader.IReadService;
import org.opendaylight.controller.statisticsmanager.IStatisticsManager;
-import org.opendaylight.controller.statisticsmanager.StatisticsManager;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
* and is available at http://www.eclipse.org/legal/epl-v10.html
*/
-package org.opendaylight.controller.statisticsmanager;
+package org.opendaylight.controller.statisticsmanager.internal;
import java.util.ArrayList;
import java.util.HashMap;
import org.opendaylight.controller.sal.reader.IReadService;
import org.opendaylight.controller.sal.reader.NodeConnectorStatistics;
import org.opendaylight.controller.sal.reader.NodeDescription;
+import org.opendaylight.controller.statisticsmanager.IStatisticsManager;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
-\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.statisticsmanager;\r
-\r
-import org.junit.Test;\r
-\r
-public class StatisticsManagerTest {\r
-\r
- @Test\r
- public void test() {\r
- StatisticsManager sm = new StatisticsManager();\r
- \r
- sm.init();\r
- sm.start();\r
- sm.stop();\r
- sm.destroy();\r
- \r
- \r
- }\r
-\r
-}\r
+/*
+ * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
+ *
+ * This program and the accompanying materials are made available under the
+ * terms of the Eclipse Public License v1.0 which accompanies this distribution,
+ * and is available at http://www.eclipse.org/legal/epl-v10.html
+ */
+
+package org.opendaylight.controller.statisticsmanager.internal;
+
+import org.junit.Test;
+import org.opendaylight.controller.statisticsmanager.internal.StatisticsManager;
+
+public class StatisticsManagerTest {
+
+ @Test
+ public void test() {
+ StatisticsManager sm = new StatisticsManager();
+
+ sm.init();
+ sm.start();
+ sm.stop();
+ sm.destroy();
+
+ }
+
+}
--- /dev/null
+<configuration scan="true">
+
+ <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
+ <encoder>
+ <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
+ </pattern>
+ </encoder>
+ </appender>
+
+ <root level="error">
+ <appender-ref ref="STDOUT" />
+ </root>
+</configuration>
--- /dev/null
+<?xml version="1.0" encoding="UTF-8"?>
+<project
+ xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
+ xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
+ <modelVersion>4.0.0</modelVersion>
+ <parent>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>commons.opendaylight</artifactId>
+ <version>1.4.0-SNAPSHOT</version>
+ <relativePath>../../commons/opendaylight</relativePath>
+ </parent>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>statisticsmanager.integrationtest</artifactId>
+ <version>0.4.0-SNAPSHOT</version>
+ <dependencies>
+ <dependency>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>protocol_plugins.stub</artifactId>
+ <version>0.4.0-SNAPSHOT</version>
+ </dependency>
+ <dependency>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>sal</artifactId>
+ <version>0.4.0-SNAPSHOT</version>
+ </dependency>
+ <dependency>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>sal.implementation</artifactId>
+ <version>0.4.0-SNAPSHOT</version>
+ </dependency>
+ <dependency>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>containermanager</artifactId>
+ <version>0.4.0-SNAPSHOT</version>
+ </dependency>
+ <dependency>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>forwardingrulesmanager</artifactId>
+ <version>0.4.0-SNAPSHOT</version>
+ </dependency>
+ <dependency>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>clustering.services</artifactId>
+ <version>0.4.0-SNAPSHOT</version>
+ </dependency>
+ <dependency>
+ <groupId>org.opendaylight.controller</groupId>
+ <artifactId>statisticsmanager</artifactId>
+ <version>0.4.0-SNAPSHOT</version>
+ </dependency>
+ </dependencies>
+ <properties>
+ <!-- Sonar jacoco plugin to get integration test coverage info -->
+ <sonar.java.coveragePlugin>jacoco</sonar.java.coveragePlugin>
+ <sonar.jacoco.reportPath>../implementation/target/jacoco.exec</sonar.jacoco.reportPath>
+ <sonar.jacoco.itReportPath>../implementaiton/target/jacoco-it.exec</sonar.jacoco.itReportPath>
+ <sonar.language>java</sonar.language>
+ </properties>
+ <build>
+ <pluginManagement>
+ <plugins>
+ <plugin>
+ <groupId>org.jacoco</groupId>
+ <artifactId>jacoco-maven-plugin</artifactId>
+ <version>0.5.3.201107060350</version>
+ </plugin>
+ </plugins>
+ </pluginManagement>
+ <plugins>
+ <plugin>
+ <groupId>org.jacoco</groupId>
+ <artifactId>jacoco-maven-plugin</artifactId>
+ <version>0.5.3.201107060350</version>
+ <configuration>
+ <destFile>../implementation/target/jacoco-it.exec</destFile>
+ <includes>org.opendaylight.controller.*</includes>
+ </configuration>
+ <executions>
+ <execution>
+ <id>pre-test</id>
+ <goals>
+ <goal>prepare-agent</goal>
+ </goals>
+ </execution>
+ <execution>
+ <id>post-test</id>
+ <configuration>
+ <skip>true</skip>
+ </configuration>
+ </execution>
+ </executions>
+ </plugin>
+ </plugins>
+ </build>
+</project>
\ No newline at end of file
--- /dev/null
+package org.opendaylight.controller.statisticsmanager.internal;
+
+import java.net.InetAddress;
+import java.net.UnknownHostException;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Map;
+
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+import org.osgi.framework.ServiceReference;
+import org.osgi.framework.Bundle;
+import javax.inject.Inject;
+
+import org.junit.Assert;
+import org.junit.Test;
+import org.junit.Before;
+import org.junit.runner.RunWith;
+import org.opendaylight.controller.forwardingrulesmanager.FlowEntry;
+import org.opendaylight.controller.sal.action.Action;
+import org.opendaylight.controller.sal.action.Drop;
+import org.opendaylight.controller.sal.core.Node;
+import org.opendaylight.controller.sal.core.NodeConnector;
+import org.opendaylight.controller.sal.flowprogrammer.Flow;
+import org.opendaylight.controller.sal.match.Match;
+import org.opendaylight.controller.sal.match.MatchType;
+import org.opendaylight.controller.sal.reader.FlowOnNode;
+import org.opendaylight.controller.sal.reader.NodeConnectorStatistics;
+import org.opendaylight.controller.sal.reader.NodeDescription;
+import org.opendaylight.controller.sal.utils.NodeCreator;
+import org.opendaylight.controller.statisticsmanager.*;
+import org.ops4j.pax.exam.junit.PaxExam;
+import org.osgi.framework.BundleContext;
+import static org.junit.Assert.*;
+import org.ops4j.pax.exam.junit.Configuration;
+import static org.ops4j.pax.exam.CoreOptions.*;
+
+import org.ops4j.pax.exam.Option;
+import org.ops4j.pax.exam.util.PathUtils;
+
+@RunWith(PaxExam.class)
+public class StatisticsManagerIntegrationTest {
+ private Logger log = LoggerFactory
+ .getLogger(StatisticsManagerIntegrationTest.class);
+ // get the OSGI bundle context
+ @Inject
+ private BundleContext bc;
+
+ private IStatisticsManager manager = null;
+
+ // Configure the OSGi container
+ @Configuration
+ public Option[] config() {
+ return options(
+ //
+ systemProperty("logback.configurationFile").value(
+ "file:" + PathUtils.getBaseDir()
+ + "/src/test/resources/logback.xml"),
+ // To start OSGi console for inspection remotely
+ systemProperty("osgi.console").value("2401"),
+ // Set the systemPackages (used by clustering)
+ systemPackages("sun.reflect", "sun.reflect.misc", "sun.misc"),
+ // List framework bundles
+ mavenBundle("equinoxSDK381", "org.eclipse.equinox.console",
+ "1.0.0.v20120522-1841"),
+ mavenBundle("equinoxSDK381", "org.eclipse.equinox.util",
+ "1.0.400.v20120522-2049"),
+ mavenBundle("equinoxSDK381", "org.eclipse.osgi.services",
+ "3.3.100.v20120522-1822"),
+ mavenBundle("equinoxSDK381", "org.eclipse.equinox.ds",
+ "1.4.0.v20120522-1841"),
+ mavenBundle("equinoxSDK381", "org.apache.felix.gogo.command",
+ "0.8.0.v201108120515"),
+ mavenBundle("equinoxSDK381", "org.apache.felix.gogo.runtime",
+ "0.8.0.v201108120515"),
+ mavenBundle("equinoxSDK381", "org.apache.felix.gogo.shell",
+ "0.8.0.v201110170705"),
+ // List logger bundles
+ mavenBundle("org.slf4j", "slf4j-api", "1.7.2"),
+ mavenBundle("org.slf4j", "log4j-over-slf4j", "1.7.2"),
+ mavenBundle("ch.qos.logback", "logback-core", "1.0.9"),
+ mavenBundle("ch.qos.logback", "logback-classic", "1.0.9"),
+ // List all the bundles on which the test case depends
+ mavenBundle("org.opendaylight.controller", "sal",
+ "0.4.0-SNAPSHOT"),
+ mavenBundle("org.opendaylight.controller",
+ "sal.implementation", "0.4.0-SNAPSHOT"),
+ mavenBundle("org.opendaylight.controller", "statisticsmanager",
+ "0.4.0-SNAPSHOT"),
+ mavenBundle("org.opendaylight.controller", "statisticsmanager.implementation",
+ "0.4.0-SNAPSHOT"),
+ mavenBundle("org.opendaylight.controller",
+ "protocol_plugins.stub", "0.4.0-SNAPSHOT"),
+ // needed by statisticsmanager
+ mavenBundle("org.opendaylight.controller", "containermanager",
+ "0.4.0-SNAPSHOT"),
+ mavenBundle("org.opendaylight.controller",
+ "containermanager.implementation", "0.4.0-SNAPSHOT"),
+ mavenBundle("org.opendaylight.controller",
+ "forwardingrulesmanager", "0.4.0-SNAPSHOT"),
+
+ mavenBundle("org.opendaylight.controller",
+ "clustering.services", "0.4.0-SNAPSHOT"),
+ mavenBundle("org.opendaylight.controller",
+ "clustering.services-implementation", "0.4.0-SNAPSHOT"),
+
+ // needed by forwardingrulesmanager
+ mavenBundle("org.opendaylight.controller", "switchmanager",
+ "0.4.0-SNAPSHOT"),
+ mavenBundle("org.opendaylight.controller", "configuration",
+ "0.4.0-SNAPSHOT"),
+
+ mavenBundle("org.opendaylight.controller",
+ "configuration.implementation", "0.4.0-SNAPSHOT"),
+ mavenBundle("org.opendaylight.controller", "hosttracker",
+ "0.4.0-SNAPSHOT"),
+
+ // needed by hosttracker
+ mavenBundle("org.opendaylight.controller", "topologymanager",
+ "0.4.0-SNAPSHOT"),
+
+ mavenBundle("org.jboss.spec.javax.transaction",
+ "jboss-transaction-api_1.1_spec", "1.0.1.Final"),
+ mavenBundle("org.apache.commons", "commons-lang3", "3.1"),
+ mavenBundle("org.apache.felix",
+ "org.apache.felix.dependencymanager", "3.1.0"),
+ junitBundles());
+ }
+
+ private String stateToString(int state) {
+ switch (state) {
+ case Bundle.ACTIVE:
+ return "ACTIVE";
+ case Bundle.INSTALLED:
+ return "INSTALLED";
+ case Bundle.RESOLVED:
+ return "RESOLVED";
+ case Bundle.UNINSTALLED:
+ return "UNINSTALLED";
+ default:
+ return "Not CONVERTED";
+ }
+ }
+
+ @Before
+ public void areWeReady() {
+ assertNotNull(bc);
+ boolean debugit = false;
+ Bundle b[] = bc.getBundles();
+ for (int i = 0; i < b.length; i++) {
+ int state = b[i].getState();
+ if (state != Bundle.ACTIVE && state != Bundle.RESOLVED) {
+ log.debug("Bundle:" + b[i].getSymbolicName() + " state:"
+ + stateToString(state));
+ debugit = true;
+ }
+ }
+ if (debugit) {
+ log.debug("Do some debugging because some bundle is "
+ + "unresolved");
+ }
+
+ // Assert if true, if false we are good to go!
+ assertFalse(debugit);
+
+ ServiceReference r = bc.getServiceReference(IStatisticsManager.class
+ .getName());
+ if (r != null) {
+ this.manager = (IStatisticsManager) bc.getService(r);
+ }
+ // If StatisticsManager is null, cannot run tests.
+ assertNotNull(this.manager);
+
+ }
+
+ @Test
+ public void testGetFlows() {
+ Node node = NodeCreator.createOFNode(1L);
+ List<FlowOnNode> flows = this.manager.getFlows(node);
+ FlowOnNode fn = flows.get(0);
+ Assert.assertTrue(fn.getByteCount() == 100);
+ Assert.assertTrue(fn.getDurationNanoseconds() == 400);
+ Assert.assertTrue(fn.getDurationSeconds() == 40);
+ Assert.assertTrue(fn.getTableId() == (byte) 0x1);
+ Assert.assertTrue(fn.getPacketCount() == 200);
+
+ Match match = new Match();
+ try {
+ match.setField(MatchType.NW_DST, InetAddress.getByName("1.1.1.1"));
+ } catch (UnknownHostException e) {
+ fail("Couldn't create match");
+ }
+ Assert.assertTrue(match.equals(fn.getFlow().getMatch()));
+ Assert.assertTrue(fn.getFlow().getActions().get(0).equals(new Drop()));
+ }
+
+ @Test
+ public void testGetFlowStatistics() {
+ Flow flow = new Flow();
+
+ Match match = new Match();
+ try {
+ match.setField(MatchType.NW_DST, InetAddress.getByName("1.1.1.1"));
+ } catch (UnknownHostException e) {
+ }
+ flow.setMatch(match);
+ Action action = new Drop();
+
+ List<Action> actions = new ArrayList<Action>();
+ actions.add(action);
+ flow.setActions(actions);
+
+ Node node = NodeCreator.createOFNode(1L);
+ FlowEntry fe = new FlowEntry("g1", "f1", flow, node);
+ List<FlowEntry> list = new ArrayList<FlowEntry>();
+ list.add(fe);
+ FlowEntry fe2 = new FlowEntry("g1", "f2", flow, node);
+ list.add(fe2);
+
+ Map<Node, List<FlowOnNode>> result = this.manager
+ .getFlowStatisticsForFlowList(null);
+ Assert.assertTrue(result.isEmpty());
+ result = this.manager.getFlowStatisticsForFlowList(list);
+ List<FlowOnNode> results = result.get(node);
+ FlowOnNode fn = results.get(0);
+ Assert.assertTrue(fn.getByteCount() == 100);
+ Assert.assertTrue(fn.getDurationNanoseconds() == 400);
+ Assert.assertTrue(fn.getDurationSeconds() == 40);
+ Assert.assertTrue(fn.getTableId() == (byte) 0x1);
+ Assert.assertTrue(fn.getPacketCount() == 200);
+ Assert.assertTrue(fn.getFlow().equals(flow));
+
+ }
+
+ @Test
+ public void testGetFlowsNumber() {
+ Node node = NodeCreator.createOFNode(1L);
+ Assert.assertTrue(this.manager.getFlowsNumber(node) == 1);
+ }
+
+ @Test
+ public void testGetNodeDescription() {
+ Node node = NodeCreator.createOFNode(1L);
+ NodeDescription desc = this.manager.getNodeDescription(node);
+ Assert.assertTrue(desc.getDescription().equals(
+ "This is a sample node description"));
+ Assert.assertTrue(desc.getHardware().equals("stub hardware"));
+ Assert.assertTrue(desc.getSoftware().equals("stub software"));
+ Assert.assertTrue(desc.getSerialNumber().equals("123"));
+ Assert.assertTrue(desc.getManufacturer().equals("opendaylight"));
+
+ }
+
+ @Test
+ public void testGetNodeConnectorStatistics() {
+ Node node = NodeCreator.createOFNode(1L);
+ List<NodeConnectorStatistics> stats = this.manager
+ .getNodeConnectorStatistics(node);
+ NodeConnectorStatistics ns = stats.get(0);
+ Assert.assertTrue(ns.getCollisionCount() == 4);
+ Assert.assertTrue(ns.getReceiveByteCount() == 1000);
+ Assert.assertTrue(ns.getReceiveCRCErrorCount() == 1);
+ Assert.assertTrue(ns.getReceiveDropCount() == 2);
+ Assert.assertTrue(ns.getReceiveErrorCount() == 3);
+ Assert.assertTrue(ns.getReceiveFrameErrorCount() == 5);
+ Assert.assertTrue(ns.getReceiveOverRunErrorCount() == 6);
+ Assert.assertTrue(ns.getReceivePacketCount() == 250);
+ Assert.assertTrue(ns.getTransmitByteCount() == 5000);
+ Assert.assertTrue(ns.getTransmitDropCount() == 50);
+ Assert.assertTrue(ns.getTransmitErrorCount() == 10);
+ Assert.assertTrue(ns.getTransmitPacketCount() == 500);
+
+ NodeConnector nc = ns.getNodeConnector();
+ NodeConnectorStatistics ns2 = this.manager
+ .getNodeConnectorStatistics(nc);
+ Assert.assertTrue(ns2.getCollisionCount() == 4);
+ Assert.assertTrue(ns2.getReceiveByteCount() == 1000);
+ Assert.assertTrue(ns2.getReceiveCRCErrorCount() == 1);
+ Assert.assertTrue(ns2.getReceiveDropCount() == 2);
+ Assert.assertTrue(ns2.getReceiveErrorCount() == 3);
+ Assert.assertTrue(ns2.getReceiveFrameErrorCount() == 5);
+ Assert.assertTrue(ns2.getReceiveOverRunErrorCount() == 6);
+ Assert.assertTrue(ns2.getReceivePacketCount() == 250);
+ Assert.assertTrue(ns2.getTransmitByteCount() == 5000);
+ Assert.assertTrue(ns2.getTransmitDropCount() == 50);
+ Assert.assertTrue(ns2.getTransmitErrorCount() == 10);
+ Assert.assertTrue(ns2.getTransmitPacketCount() == 500);
+ }
+
+}
--- /dev/null
+<configuration scan="true">
+
+ <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
+ <encoder>
+ <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
+ </pattern>
+ </encoder>
+ </appender>
+
+ <root level="error">
+ <appender-ref ref="STDOUT" />
+ </root>
+</configuration>