aboutsummaryrefslogtreecommitdiffstats
path: root/framework/src/onos/apps/flowanalyzer
diff options
context:
space:
mode:
authorCNlucius <lukai1@huawei.com>2016-09-13 11:40:12 +0800
committerCNlucius <lukai1@huawei.com>2016-09-13 11:41:53 +0800
commitb731e2f1dd0972409b136aebc7b463dd72c9cfad (patch)
tree5107d7d80c19ad8076c2c97c2b5ef8d1cf3ab903 /framework/src/onos/apps/flowanalyzer
parentee93993458266114c29271a481ef9ce7ce621b2a (diff)
ONOSFW-171
O/S-SFC-ONOS scenario documentation Change-Id: I51ae1cf736ea24ab6680f8edca1b2bf5dd598365 Signed-off-by: CNlucius <lukai1@huawei.com>
Diffstat (limited to 'framework/src/onos/apps/flowanalyzer')
-rw-r--r--framework/src/onos/apps/flowanalyzer/pom.xml77
-rw-r--r--framework/src/onos/apps/flowanalyzer/src/main/java/org/onosproject/flowanalyzer/FlowAnalysisCommand.java33
-rw-r--r--framework/src/onos/apps/flowanalyzer/src/main/java/org/onosproject/flowanalyzer/FlowAnalyzer.java270
-rw-r--r--framework/src/onos/apps/flowanalyzer/src/main/java/org/onosproject/flowanalyzer/package-info.java20
-rw-r--r--framework/src/onos/apps/flowanalyzer/src/main/resources/OSGI-INF/blueprint/shell-config.xml23
-rw-r--r--framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/DefaultMutableTopologyGraph.java28
-rw-r--r--framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/FlowAnalyzerTest.java120
-rw-r--r--framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/MockFlowRuleService.java103
-rw-r--r--framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/MockLinkService.java183
-rw-r--r--framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/MockTopologyService.java21
10 files changed, 0 insertions, 878 deletions
diff --git a/framework/src/onos/apps/flowanalyzer/pom.xml b/framework/src/onos/apps/flowanalyzer/pom.xml
deleted file mode 100644
index 1981bff9..00000000
--- a/framework/src/onos/apps/flowanalyzer/pom.xml
+++ /dev/null
@@ -1,77 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
- ~ Copyright 2014 Open Networking Laboratory
- ~
- ~ Licensed under the Apache License, Version 2.0 (the "License");
- ~ you may not use this file except in compliance with the License.
- ~ You may obtain a copy of the License at
- ~
- ~ http://www.apache.org/licenses/LICENSE-2.0
- ~
- ~ Unless required by applicable law or agreed to in writing, software
- ~ distributed under the License is distributed on an "AS IS" BASIS,
- ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- ~ See the License for the specific language governing permissions and
- ~ limitations under the License.
- -->
-<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/maven-v4_0_0.xsd">
- <modelVersion>4.0.0</modelVersion>
-
- <parent>
- <groupId>org.onosproject</groupId>
- <artifactId>onos-apps</artifactId>
- <version>1.4.0-rc1</version>
- <relativePath>../pom.xml</relativePath>
- </parent>
-
- <artifactId>onos-app-flowanalyzer</artifactId>
- <packaging>bundle</packaging>
-
- <description>Simple flow space analyzer</description>
-
- <properties>
- <onos.app.name>org.onosproject.flowanalyzer</onos.app.name>
- </properties>
-
- <dependencies>
- <dependency>
- <groupId>org.osgi</groupId>
- <artifactId>org.osgi.compendium</artifactId>
- </dependency>
- <dependency>
- <groupId>org.onosproject</groupId>
- <artifactId>onlab-junit</artifactId>
- <scope>test</scope>
- </dependency>
-
- <dependency>
- <groupId>org.onosproject</groupId>
- <artifactId>onos-api</artifactId>
- <classifier>tests</classifier>
- <scope>test</scope>
- </dependency>
- <dependency>
- <groupId>org.apache.felix</groupId>
- <artifactId>org.apache.felix.scr.annotations</artifactId>
- </dependency>
-
- <dependency>
- <groupId>org.onosproject</groupId>
- <artifactId>onos-cli</artifactId>
- <version>${project.version}</version>
- </dependency>
- <dependency>
- <groupId>org.osgi</groupId>
- <artifactId>org.osgi.core</artifactId>
- </dependency>
-
- <dependency>
- <groupId>org.apache.karaf.shell</groupId>
- <artifactId>org.apache.karaf.shell.console</artifactId>
- </dependency>
-
- </dependencies>
-
-</project>
diff --git a/framework/src/onos/apps/flowanalyzer/src/main/java/org/onosproject/flowanalyzer/FlowAnalysisCommand.java b/framework/src/onos/apps/flowanalyzer/src/main/java/org/onosproject/flowanalyzer/FlowAnalysisCommand.java
deleted file mode 100644
index 2c61949b..00000000
--- a/framework/src/onos/apps/flowanalyzer/src/main/java/org/onosproject/flowanalyzer/FlowAnalysisCommand.java
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * Copyright 2015 Open Networking Laboratory
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-package org.onosproject.flowanalyzer;
-
-import org.apache.karaf.shell.commands.Command;
-import org.onosproject.cli.AbstractShellCommand;
-
-/**
- * Analyzes flows for cycles and black holes.
- */
-@Command(scope = "onos", name = "flow-analysis",
- description = "Analyzes flows for cycles and black holes")
-public class FlowAnalysisCommand extends AbstractShellCommand {
-
- @Override
- protected void execute() {
- FlowAnalyzer service = get(FlowAnalyzer.class);
- print(service.analyze());
- }
-}
diff --git a/framework/src/onos/apps/flowanalyzer/src/main/java/org/onosproject/flowanalyzer/FlowAnalyzer.java b/framework/src/onos/apps/flowanalyzer/src/main/java/org/onosproject/flowanalyzer/FlowAnalyzer.java
deleted file mode 100644
index 86ab37fa..00000000
--- a/framework/src/onos/apps/flowanalyzer/src/main/java/org/onosproject/flowanalyzer/FlowAnalyzer.java
+++ /dev/null
@@ -1,270 +0,0 @@
-/*
- * Copyright 2015 Open Networking Laboratory
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-package org.onosproject.flowanalyzer;
-
-import org.apache.felix.scr.annotations.Activate;
-import org.apache.felix.scr.annotations.Component;
-import org.apache.felix.scr.annotations.Deactivate;
-import org.apache.felix.scr.annotations.Reference;
-import org.apache.felix.scr.annotations.ReferenceCardinality;
-import org.apache.felix.scr.annotations.Service;
-import org.onosproject.net.ConnectPoint;
-import org.onosproject.net.PortNumber;
-import org.onosproject.net.flow.FlowEntry;
-import org.onosproject.net.flow.FlowRuleService;
-import org.onosproject.net.DeviceId;
-import org.onosproject.net.HostId;
-import org.onosproject.net.flow.criteria.Criteria;
-import org.onosproject.net.flow.criteria.Criterion;
-import org.onosproject.net.flow.criteria.PortCriterion;
-import org.onosproject.net.flow.instructions.Instruction;
-import org.onosproject.net.flow.instructions.Instructions;
-import org.onosproject.net.topology.TopologyService;
-import org.onosproject.net.topology.TopologyGraph;
-import org.onosproject.net.link.LinkService;
-import org.onosproject.net.Link;
-import org.onosproject.net.topology.TopologyVertex;
-import org.osgi.service.component.ComponentContext;
-import org.slf4j.Logger;
-
-import java.util.HashSet;
-import java.util.List;
-import java.util.HashMap;
-import java.util.Map;
-import java.util.Set;
-
-import static org.slf4j.LoggerFactory.getLogger;
-
-/**
- * Simple flow space analyzer app.
- */
-@Component(immediate = true)
-@Service(value = FlowAnalyzer.class)
-public class FlowAnalyzer {
-
- private final Logger log = getLogger(getClass());
-
- @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
- protected FlowRuleService flowRuleService;
-
- @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
- protected TopologyService topologyService;
-
- @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
- protected LinkService linkService;
-
- @Activate
- public void activate(ComponentContext context) {
- log.info("Started");
- }
-
- @Deactivate
- public void deactivate() {
- log.info("Stopped");
- }
-
- TopologyGraph graph;
- Map<FlowEntry, String> label = new HashMap<>();
- Set<FlowEntry> ignoredFlows = new HashSet<>();
-
- /**
- * Analyzes and prints out a report on the status of every flow entry inside
- * the network. The possible states are: Cleared (implying that the entry leads to
- * a host), Cycle (implying that it is part of cycle), and Black Hole (implying
- * that the entry does not lead to a single host).
- *
- * @return result string
- */
- public String analyze() {
- graph = topologyService.getGraph(topologyService.currentTopology());
- for (TopologyVertex v: graph.getVertexes()) {
- DeviceId srcDevice = v.deviceId();
- Iterable<FlowEntry> flowTable = flowRuleService.getFlowEntries(srcDevice);
- for (FlowEntry flow: flowTable) {
- dfs(flow);
- }
- }
-
- //analyze the cycles to look for "critical flows" that can be removed
- //to break the cycle
- Set<FlowEntry> critpts = new HashSet<>();
- for (FlowEntry flow: label.keySet()) {
- if ("Cycle".equals(label.get(flow))) {
- Map<FlowEntry, String> labelSaved = label;
- label = new HashMap<FlowEntry, String>();
- ignoredFlows.add(flow);
- for (TopologyVertex v: graph.getVertexes()) {
- DeviceId srcDevice = v.deviceId();
- Iterable<FlowEntry> flowTable = flowRuleService.getFlowEntries(srcDevice);
- for (FlowEntry flow1: flowTable) {
- dfs(flow1);
- }
- }
-
- boolean replacable = true;
- for (FlowEntry flow2: label.keySet()) {
- if ("Cleared".equals(labelSaved.get(flow2)) && !("Cleared".equals(label.get(flow2)))) {
- replacable = false;
- }
- }
- if (replacable) {
- critpts.add(flow);
- }
- label = labelSaved;
- }
- }
-
- for (FlowEntry flow: critpts) {
- label.put(flow, "Cycle Critical Point");
- }
-
- String s = "\n";
- for (FlowEntry flow: label.keySet()) {
- s += ("Flow Rule: " + flowEntryRepresentation(flow) + "\n");
- s += ("Analysis: " + label.get(flow) + "!\n\n");
- }
- s += ("Analyzed " + label.keySet().size() + " flows.");
- //log.info(s);
- return s;
- }
-
- public Map<FlowEntry, String> calcLabels() {
- analyze();
- return label;
- }
- public String analysisOutput() {
- analyze();
- String s = "\n";
- for (FlowEntry flow: label.keySet()) {
- s += ("Flow Rule: " + flowEntryRepresentation(flow) + "\n");
- s += ("Analysis: " + label.get(flow) + "!\n\n");
- }
- return s;
- }
-
- private boolean dfs(FlowEntry flow) {
- if (ignoredFlows.contains(flow)) {
- return false;
- }
- if ("Cycle".equals(label.get(flow)) ||
- "Black Hole".equals(label.get(flow)) ||
- "Cleared".equals(label.get(flow)) ||
- "NA".equals(label.get(flow)) ||
- "Cycle Critical Point".equals(label.get(flow))) {
-
- // This flow has already been analyzed and there is no need to analyze it further
- return !"Black Hole".equals(label.get(flow));
- }
-
- if ("Visiting".equals(label.get(flow))) {
- //you've detected a cycle because you reached the same entry again during your dfs
- //let it continue so you can label the whole cycle
- label.put(flow, "Cycle");
- } else {
- //otherwise, mark off the current flow entry as currently being visited
- label.put(flow, "Visiting");
- }
-
- boolean pointsToLiveEntry = false;
-
- List<Instruction> instructions = flow.treatment().allInstructions();
- for (Instruction i: instructions) {
- if (i instanceof Instructions.OutputInstruction) {
- pointsToLiveEntry |= analyzeInstruction(i, flow);
- }
- if ("NA".equals(label.get(flow))) {
- return pointsToLiveEntry;
- }
- }
-
- if (!pointsToLiveEntry) {
- //this entry does not point to any "live" entries thus must be a black hole
- label.put(flow, "Black Hole");
- } else if ("Visiting".equals(label.get(flow))) {
- //the flow is not in a cycle or in a black hole
- label.put(flow, "Cleared");
- }
- return pointsToLiveEntry;
- }
-
- private boolean analyzeInstruction(Instruction i, FlowEntry flow) {
- boolean pointsToLiveEntry = false;
- Instructions.OutputInstruction output = (Instructions.OutputInstruction) i;
- PortNumber port = output.port();
- PortNumber outPort = null;
-
- DeviceId egress = null;
- boolean hasHost = false;
-
- ConnectPoint portPt = new ConnectPoint(flow.deviceId(), port);
- for (Link l: linkService.getEgressLinks(portPt)) {
- if (l.dst().elementId() instanceof DeviceId) {
- egress = l.dst().deviceId();
- outPort = l.dst().port();
- } else if (l.dst().elementId() instanceof HostId) {
- //the port leads to a host: therefore it is not a dead link
- pointsToLiveEntry = true;
- hasHost = true;
- }
- }
- if (!topologyService.isInfrastructure(topologyService.currentTopology(), portPt) && egress == null) {
- pointsToLiveEntry = true;
- hasHost = true;
- }
- if (hasHost) {
- return pointsToLiveEntry;
- }
- if (egress == null) {
- //the port that the flow instructions tells you to send the packet
- //to doesn't exist or is a controller port
- label.put(flow, "NA");
- return pointsToLiveEntry;
- }
-
- Iterable<FlowEntry> dstFlowTable = flowRuleService.getFlowEntries(egress);
-
- Set<Criterion> flowCriteria = flow.selector().criteria();
-
- //filter the criteria in order to remove port dependency
- Set<Criterion> filteredCriteria = new HashSet<>();
- for (Criterion criterion : flowCriteria) {
- if (!(criterion instanceof PortCriterion)) {
- filteredCriteria.add(criterion);
- }
- }
-
- //ensure that the in port is equal to the port that it is coming in from
- filteredCriteria.add(Criteria.matchInPort(outPort));
-
- for (FlowEntry entry: dstFlowTable) {
- if (ignoredFlows.contains(entry)) {
- continue;
- }
- if (filteredCriteria.containsAll(entry.selector().criteria())) {
- dfs(entry);
-
- if (!"Black Hole".equals(label.get(entry))) {
- //this entry is "live" i.e not a black hole
- pointsToLiveEntry = true;
- }
- }
- }
- return pointsToLiveEntry;
- }
- public String flowEntryRepresentation(FlowEntry flow) {
- return "Device: " + flow.deviceId() + ", " + flow.selector().criteria() + ", " + flow.treatment().immediate();
- }
-}
diff --git a/framework/src/onos/apps/flowanalyzer/src/main/java/org/onosproject/flowanalyzer/package-info.java b/framework/src/onos/apps/flowanalyzer/src/main/java/org/onosproject/flowanalyzer/package-info.java
deleted file mode 100644
index 5572f8c8..00000000
--- a/framework/src/onos/apps/flowanalyzer/src/main/java/org/onosproject/flowanalyzer/package-info.java
+++ /dev/null
@@ -1,20 +0,0 @@
-/*
- * Copyright 2015 Open Networking Laboratory
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-/**
- * Prototype application for scanning the flow space for cycles and black holes.
- */
-package org.onosproject.flowanalyzer; \ No newline at end of file
diff --git a/framework/src/onos/apps/flowanalyzer/src/main/resources/OSGI-INF/blueprint/shell-config.xml b/framework/src/onos/apps/flowanalyzer/src/main/resources/OSGI-INF/blueprint/shell-config.xml
deleted file mode 100644
index 93cb27ee..00000000
--- a/framework/src/onos/apps/flowanalyzer/src/main/resources/OSGI-INF/blueprint/shell-config.xml
+++ /dev/null
@@ -1,23 +0,0 @@
-<!--
- ~ Copyright 2015 Open Networking Laboratory
- ~
- ~ Licensed under the Apache License, Version 2.0 (the "License");
- ~ you may not use this file except in compliance with the License.
- ~ You may obtain a copy of the License at
- ~
- ~ http://www.apache.org/licenses/LICENSE-2.0
- ~
- ~ Unless required by applicable law or agreed to in writing, software
- ~ distributed under the License is distributed on an "AS IS" BASIS,
- ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- ~ See the License for the specific language governing permissions and
- ~ limitations under the License.
- -->
-<blueprint xmlns="http://www.osgi.org/xmlns/blueprint/v1.0.0">
- <command-bundle xmlns="http://karaf.apache.org/xmlns/shell/v1.1.0">
- <command>
- <action class="org.onosproject.flowanalyzer.FlowAnalysisCommand"/>
- </command>
-
- </command-bundle>
-</blueprint>
diff --git a/framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/DefaultMutableTopologyGraph.java b/framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/DefaultMutableTopologyGraph.java
deleted file mode 100644
index 4ea3aa48..00000000
--- a/framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/DefaultMutableTopologyGraph.java
+++ /dev/null
@@ -1,28 +0,0 @@
-package org.onosproject.flowanalyzer;
-
-import org.onlab.graph.MutableAdjacencyListsGraph;
-import org.onosproject.net.topology.TopologyEdge;
-import org.onosproject.net.topology.TopologyGraph;
-import org.onosproject.net.topology.TopologyVertex;
-
-import java.util.Set;
-
-/**
- * Default implementation of an immutable topology graph based on a generic
- * implementation of adjacency lists graph.
- */
-public class DefaultMutableTopologyGraph
- extends MutableAdjacencyListsGraph<TopologyVertex, TopologyEdge>
- implements TopologyGraph {
-
- /**
- * Creates a topology graph comprising of the specified vertexes and edges.
- *
- * @param vertexes set of graph vertexes
- * @param edges set of graph edges
- */
- public DefaultMutableTopologyGraph(Set<TopologyVertex> vertexes, Set<TopologyEdge> edges) {
- super(vertexes, edges);
- }
-
-}
diff --git a/framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/FlowAnalyzerTest.java b/framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/FlowAnalyzerTest.java
deleted file mode 100644
index faa2f5f9..00000000
--- a/framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/FlowAnalyzerTest.java
+++ /dev/null
@@ -1,120 +0,0 @@
-/*
- * Copyright 2015 Open Networking Laboratory
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-package org.onosproject.flowanalyzer;
-
-import org.junit.Ignore;
-import org.junit.Test;
-
-import org.onosproject.core.DefaultApplicationId;
-import org.onosproject.net.DeviceId;
-import org.onosproject.net.PortNumber;
-import org.onosproject.net.flow.DefaultFlowRule;
-import org.onosproject.net.flow.DefaultTrafficSelector;
-import org.onosproject.net.flow.DefaultTrafficTreatment;
-import org.onosproject.net.flow.FlowRule;
-import org.onosproject.net.flow.FlowRuleExtPayLoad;
-import org.onosproject.net.flow.FlowRuleService;
-import org.onosproject.net.flow.TrafficSelector;
-import org.onosproject.net.flow.TrafficTreatment;
-import org.onosproject.net.flow.instructions.Instructions;
-import org.onosproject.net.topology.TopologyService;
-
-import java.util.Arrays;
-import java.util.TreeSet;
-
-import static org.junit.Assert.assertEquals;
-
-
-/**
- * Created by nikcheerla on 7/20/15.
- */
-public class FlowAnalyzerTest {
-
- FlowRuleService flowRuleService = new MockFlowRuleService();
- TopologyService topologyService;
- MockLinkService linkService = new MockLinkService();
-
- @Test
- @Ignore("This needs to be reworked to be more robust")
- public void basic() {
- flowRuleService = new MockFlowRuleService();
- flowRuleService.applyFlowRules(genFlow("ATL-001", 110, 90));
- flowRuleService.applyFlowRules(genFlow("ATL-001", 110, 100));
- flowRuleService.applyFlowRules(genFlow("ATL-001", 110, 150));
- flowRuleService.applyFlowRules(genFlow("ATL-002", 80, 70));
- flowRuleService.applyFlowRules(genFlow("ATL-003", 120, 130));
- flowRuleService.applyFlowRules(genFlow("ATL-004", 50));
- flowRuleService.applyFlowRules(genFlow("ATL-005", 140, 10));
-
- linkService.addLink("H00:00:00:00:00:0660", 160, "ATL-005", 140);
- linkService.addLink("ATL-005", 10, "ATL-004", 40);
- linkService.addLink("ATL-004", 50, "ATL-002", 80);
- linkService.addLink("ATL-002", 70, "ATL-001", 110);
- linkService.addLink("ATL-001", 150, "H00:00:00:00:00:0770", 170);
- linkService.addLink("ATL-001", 90, "ATL-004", 30);
- linkService.addLink("ATL-001", 100, "ATL-003", 120);
- linkService.addLink("ATL-003", 130, "ATL-005", 20);
-
- topologyService = new MockTopologyService(linkService.createdGraph);
-
- FlowAnalyzer flowAnalyzer = new FlowAnalyzer();
- flowAnalyzer.flowRuleService = flowRuleService;
- flowAnalyzer.linkService = linkService;
- flowAnalyzer.topologyService = topologyService;
-
- String labels = flowAnalyzer.analysisOutput();
- String correctOutput = "Flow Rule: Device: atl-005, [IN_PORT{port=140}], [OUTPUT{port=10}]\n" +
- "Analysis: Cleared!\n" +
- "\n" +
- "Flow Rule: Device: atl-003, [IN_PORT{port=120}], [OUTPUT{port=130}]\n" +
- "Analysis: Black Hole!\n" +
- "\n" +
- "Flow Rule: Device: atl-001, [IN_PORT{port=110}], [OUTPUT{port=90}]\n" +
- "Analysis: Cycle Critical Point!\n" +
- "\n" +
- "Flow Rule: Device: atl-004, [], [OUTPUT{port=50}]\n" +
- "Analysis: Cycle!\n" +
- "\n" +
- "Flow Rule: Device: atl-001, [IN_PORT{port=110}], [OUTPUT{port=150}]\n" +
- "Analysis: Cleared!\n" +
- "\n" +
- "Flow Rule: Device: atl-001, [IN_PORT{port=110}], [OUTPUT{port=100}]\n" +
- "Analysis: Black Hole!\n" +
- "\n" +
- "Flow Rule: Device: atl-002, [IN_PORT{port=80}], [OUTPUT{port=70}]\n" +
- "Analysis: Cycle!\n";
- assertEquals("Wrong labels", new TreeSet(Arrays.asList(labels.replaceAll("\\s+", "").split("!"))),
- new TreeSet(Arrays.asList(correctOutput.replaceAll("\\s+", "").split("!"))));
- }
-
- public FlowRule genFlow(String d, long inPort, long outPort) {
- DeviceId device = DeviceId.deviceId(d);
- TrafficSelector ts = DefaultTrafficSelector.builder().matchInPort(PortNumber.portNumber(inPort)).build();
- TrafficTreatment tt = DefaultTrafficTreatment.builder()
- .add(Instructions.createOutput(PortNumber.portNumber(outPort))).build();
- return new DefaultFlowRule(device, ts, tt, 1, new DefaultApplicationId(5000, "of"),
- 50000, true, FlowRuleExtPayLoad.flowRuleExtPayLoad(new byte[5]));
- }
- public FlowRule genFlow(String d, long outPort) {
- DeviceId device = DeviceId.deviceId(d);
- TrafficSelector ts = DefaultTrafficSelector.builder().build();
- TrafficTreatment tt = DefaultTrafficTreatment.builder()
- .add(Instructions.createOutput(PortNumber.portNumber(outPort))).build();
- return new DefaultFlowRule(device, ts, tt, 1, new DefaultApplicationId(5000, "of"),
- 50000, true, FlowRuleExtPayLoad.flowRuleExtPayLoad(new byte[5]));
- }
-
-}
diff --git a/framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/MockFlowRuleService.java b/framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/MockFlowRuleService.java
deleted file mode 100644
index 40bb0043..00000000
--- a/framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/MockFlowRuleService.java
+++ /dev/null
@@ -1,103 +0,0 @@
-package org.onosproject.flowanalyzer;
-
-import com.google.common.collect.Sets;
-import org.onosproject.core.ApplicationId;
-import org.onosproject.net.DeviceId;
-import org.onosproject.net.flow.DefaultFlowEntry;
-import org.onosproject.net.flow.FlowEntry;
-import org.onosproject.net.flow.FlowRule;
-import org.onosproject.net.flow.FlowRuleOperations;
-import org.onosproject.net.flow.FlowRuleServiceAdapter;
-
-import java.util.Set;
-import java.util.concurrent.atomic.AtomicBoolean;
-import java.util.stream.Collectors;
-
-/**
- * Created by nikcheerla on 7/20/15.
- */
-
-public class MockFlowRuleService extends FlowRuleServiceAdapter {
-
- final Set<FlowRule> flows = Sets.newHashSet();
- boolean success;
-
- int errorFlow = -1;
- public void setErrorFlow(int errorFlow) {
- this.errorFlow = errorFlow;
- }
-
- public void setFuture(boolean success) {
- this.success = success;
- }
-
- @Override
- public void apply(FlowRuleOperations ops) {
- AtomicBoolean thisSuccess = new AtomicBoolean(success);
- ops.stages().forEach(stage -> stage.forEach(flow -> {
- if (errorFlow == flow.rule().id().value()) {
- thisSuccess.set(false);
- } else {
- switch (flow.type()) {
- case ADD:
- case MODIFY: //TODO is this the right behavior for modify?
- flows.add(flow.rule());
- break;
- case REMOVE:
- flows.remove(flow.rule());
- break;
- default:
- break;
- }
- }
- }));
- if (thisSuccess.get()) {
- ops.callback().onSuccess(ops);
- } else {
- ops.callback().onError(ops);
- }
- }
-
- @Override
- public int getFlowRuleCount() {
- return flows.size();
- }
-
- @Override
- public Iterable<FlowEntry> getFlowEntries(DeviceId deviceId) {
- return flows.stream()
- .filter(flow -> flow.deviceId().equals(deviceId))
- .map(DefaultFlowEntry::new)
- .collect(Collectors.toList());
- }
-
- @Override
- public void applyFlowRules(FlowRule... flowRules) {
- for (FlowRule flow : flowRules) {
- flows.add(flow);
- }
- }
-
- @Override
- public void removeFlowRules(FlowRule... flowRules) {
- for (FlowRule flow : flowRules) {
- flows.remove(flow);
- }
- }
-
- @Override
- public Iterable<FlowRule> getFlowRulesById(ApplicationId id) {
- return flows.stream()
- .filter(flow -> flow.appId() == id.id())
- .collect(Collectors.toList());
- }
-
- @Override
- public Iterable<FlowRule> getFlowRulesByGroupId(ApplicationId appId, short groupId) {
- return flows.stream()
- .filter(flow -> flow.appId() == appId.id() && flow.groupId().id() == groupId)
- .collect(Collectors.toList());
- }
-}
-
-
diff --git a/framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/MockLinkService.java b/framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/MockLinkService.java
deleted file mode 100644
index 2171c6f8..00000000
--- a/framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/MockLinkService.java
+++ /dev/null
@@ -1,183 +0,0 @@
-package org.onosproject.flowanalyzer;
-
-import org.onosproject.net.PortNumber;
-import org.onosproject.net.link.LinkServiceAdapter;
-import org.onosproject.net.topology.TopologyEdge;
-import org.onosproject.net.ConnectPoint;
-import org.onosproject.net.DeviceId;
-import org.onosproject.net.ElementId;
-import org.onosproject.net.HostId;
-import org.onosproject.net.Link;
-import org.onosproject.net.Annotations;
-import org.onosproject.net.provider.ProviderId;
-import org.onosproject.net.topology.TopologyVertex;
-
-import java.util.Set;
-import java.util.ArrayList;
-import java.util.List;
-import java.util.HashSet;
-
-import static org.onosproject.net.Link.State.ACTIVE;
-
-
-/**
- * Created by nikcheerla on 7/21/15.
- */
-public class MockLinkService extends LinkServiceAdapter {
- DefaultMutableTopologyGraph createdGraph = new DefaultMutableTopologyGraph(new HashSet<>(), new HashSet<>());
- List<Link> links = new ArrayList<>();
-
- @Override
- public int getLinkCount() {
- return links.size();
- }
-
- @Override
- public Iterable<Link> getLinks() {
- return links;
- }
-
- @Override
- public Set<Link> getDeviceLinks(DeviceId deviceId) {
- Set<Link> egress = getDeviceEgressLinks(deviceId);
- egress.addAll(getDeviceIngressLinks(deviceId));
- return egress;
- }
-
- @Override
- public Set<Link> getDeviceEgressLinks(DeviceId deviceId) {
- Set<Link> setL = new HashSet<>();
- for (Link l: links) {
- if (l.src().elementId() instanceof DeviceId && l.src().deviceId().equals(deviceId)) {
- setL.add(l);
- }
- }
- return setL;
- }
-
- @Override
- public Set<Link> getDeviceIngressLinks(DeviceId deviceId) {
- Set<Link> setL = new HashSet<>();
- for (Link l: links) {
- if (l.dst().elementId() instanceof DeviceId && l.dst().deviceId().equals(deviceId)) {
- setL.add(l);
- }
- }
- return setL;
- }
-
-
- @Override
- public Set<Link> getEgressLinks(ConnectPoint pt) {
- Set<Link> setL = new HashSet<>();
- for (Link l: links) {
- if (l.src().equals(pt)) {
- setL.add(l);
- }
- }
- return setL;
- }
-
- @Override
- public Set<Link> getIngressLinks(ConnectPoint pt) {
- Set<Link> setL = new HashSet<>();
- for (Link l: links) {
- if (l.dst().equals(pt)) {
- setL.add(l);
- }
- }
- return setL;
- }
-
- @Override
- public Set<Link> getLinks(ConnectPoint pt) {
- Set<Link> setL = new HashSet<>();
- for (Link l: links) {
- if (l.src().equals(pt) || l.dst().equals(pt)) {
- setL.add(l);
- }
- }
- return setL;
- }
-
- public void addLink(String device, long port, String device2, long port2) {
- ElementId d1;
- if (device.charAt(0) == 'H') {
- device = device.substring(1, device.length());
- d1 = HostId.hostId(device);
- } else {
- d1 = DeviceId.deviceId(device);
- }
-
- ElementId d2;
- if (device2.charAt(0) == 'H') {
- d2 = HostId.hostId(device2.substring(1, device2.length()));
- } else {
- d2 = DeviceId.deviceId(device2);
- }
-
- ConnectPoint src = new ConnectPoint(d1, PortNumber.portNumber(port));
- ConnectPoint dst = new ConnectPoint(d2, PortNumber.portNumber(port2));
- Link curLink;
- curLink = new Link() {
- @Override
- public ConnectPoint src() {
- return src;
- }
-
- @Override
- public ConnectPoint dst() {
- return dst;
- }
-
- @Override
- public boolean isDurable() {
- return true;
- }
-
- @Override
- public Annotations annotations() {
- return null;
- }
-
- @Override
- public Type type() {
- return null;
- }
-
- @Override
- public ProviderId providerId() {
- return null;
- }
-
- @Override
- public State state() {
- return ACTIVE;
- }
- };
- links.add(curLink);
- if (d1 instanceof DeviceId && d2 instanceof DeviceId) {
- TopologyVertex v1 = () -> (DeviceId) d1, v2 = () -> (DeviceId) d2;
- createdGraph.addVertex(v1);
- createdGraph.addVertex(v2);
- createdGraph.addEdge(new TopologyEdge() {
- @Override
- public Link link() {
- return curLink;
- }
-
- @Override
- public TopologyVertex src() {
- return v1;
- }
-
- @Override
- public TopologyVertex dst() {
- return v2;
- }
- });
- }
- }
-
-
-}
diff --git a/framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/MockTopologyService.java b/framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/MockTopologyService.java
deleted file mode 100644
index 0d25c977..00000000
--- a/framework/src/onos/apps/flowanalyzer/src/test/java/org/onosproject/flowanalyzer/MockTopologyService.java
+++ /dev/null
@@ -1,21 +0,0 @@
-package org.onosproject.flowanalyzer;
-import org.onosproject.net.topology.Topology;
-import org.onosproject.net.topology.TopologyGraph;
-import org.onosproject.net.topology.TopologyServiceAdapter;
-
-
-/**
- * Created by nikcheerla on 7/20/15.
- */
-public class MockTopologyService extends TopologyServiceAdapter {
- TopologyGraph cur;
-
- public MockTopologyService(TopologyGraph g) {
- cur = g;
- }
-
- @Override
- public TopologyGraph getGraph(Topology topology) {
- return cur;
- }
-}