Adding auto-layout to the access-null simulation.
Enhancing the scale test for flows and routes.
Change-Id: Ib91720b409872e44eaff4263cf229bffa2e292fc
diff --git a/providers/null/src/main/java/org/onosproject/provider/nil/NullFlowRuleProvider.java b/providers/null/src/main/java/org/onosproject/provider/nil/NullFlowRuleProvider.java
index beaeb6a..f118f09 100644
--- a/providers/null/src/main/java/org/onosproject/provider/nil/NullFlowRuleProvider.java
+++ b/providers/null/src/main/java/org/onosproject/provider/nil/NullFlowRuleProvider.java
@@ -74,12 +74,18 @@
@Override
public void applyFlowRule(FlowRule... flowRules) {
- throw new UnsupportedOperationException("Cannot apply individual flow rules");
+ for (FlowRule rule : flowRules) {
+ flowTable.getOrDefault(rule.deviceId(), Sets.newConcurrentHashSet())
+ .add(new DefaultFlowEntry(rule));
+ }
}
@Override
public void removeFlowRule(FlowRule... flowRules) {
- throw new UnsupportedOperationException("Cannot remove individual flow rules");
+ for (FlowRule rule : flowRules) {
+ flowTable.getOrDefault(rule.deviceId(), Sets.newConcurrentHashSet())
+ .remove(new DefaultFlowEntry(rule));
+ }
}
@Override
diff --git a/providers/null/src/main/java/org/onosproject/provider/nil/cli/CreateNullHosts.java b/providers/null/src/main/java/org/onosproject/provider/nil/cli/CreateNullHosts.java
index 0495038..c9b9301 100644
--- a/providers/null/src/main/java/org/onosproject/provider/nil/cli/CreateNullHosts.java
+++ b/providers/null/src/main/java/org/onosproject/provider/nil/cli/CreateNullHosts.java
@@ -19,9 +19,12 @@
import org.apache.karaf.shell.commands.Argument;
import org.apache.karaf.shell.commands.Command;
import org.onlab.packet.IpAddress;
+import org.onlab.util.Tools;
import org.onosproject.net.ConnectPoint;
import org.onosproject.net.HostId;
import org.onosproject.net.HostLocation;
+import org.onosproject.net.config.NetworkConfigService;
+import org.onosproject.net.config.basics.BasicHostConfig;
import org.onosproject.provider.nil.CustomTopologySimulator;
import org.onosproject.provider.nil.NullProviders;
import org.onosproject.provider.nil.TopologySimulator;
@@ -35,6 +38,8 @@
description = "Adds a simulated end-station host to the custom topology simulation")
public class CreateNullHosts extends CreateNullEntity {
+ private static final double NONE = -99999999.9999;
+
@Argument(index = 0, name = "deviceName", description = "Name of device where hosts are attached",
required = true)
String deviceName = null;
@@ -47,9 +52,26 @@
required = true)
int hostCount = 0;
+ @Argument(index = 3, name = "gridY", description = "Grid y-coord for top of host block")
+ double gridY = NONE;
+
+ @Argument(index = 4, name = "gridX", description = "Grid X-coord for center of host block")
+ double gridX = NONE;
+
+ @Argument(index = 5, name = "hostsPerRow", description = "Number of hosts to render per row in block")
+ int hostsPerRow = 5;
+
+ @Argument(index = 6, name = "rowGap", description = "Y gap between rows")
+ double rowGap = 70;
+
+ @Argument(index = 7, name = "colGap", description = "X gap between rows")
+ double colGap = 50;
+
+
@Override
protected void execute() {
NullProviders service = get(NullProviders.class);
+ NetworkConfigService cfgService = get(NetworkConfigService.class);
TopologySimulator simulator = service.currentSimulator();
if (!validateSimulator(simulator)) {
@@ -60,10 +82,27 @@
List<ConnectPoint> points = findAvailablePorts(sim.deviceId(deviceName));
String pattern = hostIpPattern.replace("*", "%d");
+ double yStep = rowGap / hostsPerRow;
+ double y = gridY;
+ double x = gridX - (colGap * (hostsPerRow - 1)) / 2;
+
for (int h = 0; h < hostCount; h++) {
HostLocation location = new HostLocation(points.get(h), System.currentTimeMillis());
IpAddress ip = IpAddress.valueOf(String.format(pattern, h));
HostId id = sim.nextHostId();
+
+ if (gridY != NONE) {
+ BasicHostConfig cfg = cfgService.addConfig(id, BasicHostConfig.class);
+ setUiCoordinates(cfg, GRID, y, x);
+ if (((h + 1) % hostsPerRow) == 0) {
+ x = gridX - (colGap * (hostsPerRow - 1)) / 2;
+ } else {
+ x += colGap;
+ y += yStep;
+ }
+ }
+
+ Tools.delay(10);
sim.createHost(id, location, ip);
}
}