blob: 5d3a2770e1d4fced22e626170b409659731ca8d0 [file] [log] [blame]
/*
* Copyright 2014-present Open Networking Foundation
*
* 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.cli.net;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import org.apache.karaf.shell.api.action.Argument;
import org.apache.karaf.shell.api.action.Command;
import org.apache.karaf.shell.api.action.lifecycle.Service;
import org.onosproject.cli.AbstractShellCommand;
import org.onosproject.core.ApplicationId;
import org.onosproject.core.CoreService;
import org.onosproject.net.Host;
import org.onosproject.net.host.HostService;
import org.onosproject.net.intent.HostToHostIntent;
import org.onosproject.net.intent.Intent;
import org.onosproject.net.intent.IntentService;
import com.google.common.collect.Lists;
/**
* Installs bulk host-to-host intents between hosts of the network.
*/
@Service
@Command(scope = "onos", name = "push-random-intents",
description = "It installs random intents to test throughput. The " +
"maximum number of intents is determined by the number of " +
"hosts in the network. The command will push an intent for " +
"each unordered pair of hosts. The maximum intent number " +
"will be n(n-1)/2, where n represents the number of hosts " +
"present")
public class RandomIntentCommand extends AbstractShellCommand {
@Argument(index = 0, name = "count",
description = "Max number of intents to push. The value will " +
"not be taken into account if it exceeds the maximum " +
"number of intents the command can push",
required = true, multiValued = false)
String countString = null;
private IntentService service;
private HostService hostService;
private int count;
@Override
protected void doExecute() {
service = get(IntentService.class);
hostService = get(HostService.class);
count = Integer.parseInt(countString);
if (count > 0) {
Collection<Intent> intents = generateIntents();
submitIntents(intents);
} else {
withdrawIntents();
}
}
private Collection<Intent> generateIntents() {
List<Host> hosts = Lists.newArrayList(hostService.getHosts());
List<Intent> fullMesh = Lists.newArrayList();
for (int i = 0; i < hosts.size(); i++) {
for (int j = i + 1; j < hosts.size(); j++) {
fullMesh.add(HostToHostIntent.builder()
.appId(appId())
.one(hosts.get(i).id())
.two(hosts.get(j).id())
.build());
}
}
Collections.shuffle(fullMesh);
return fullMesh.subList(0, Math.min(count, fullMesh.size()));
}
private void submitIntents(Collection<Intent> intents) {
for (Intent intent : intents) {
service.submit(intent);
}
print("Submitted %d host to host intents.", intents.size());
}
private void withdrawIntents() {
for (Intent intent : service.getIntents()) {
if (appId().equals(intent.appId())) {
service.withdraw(intent);
}
}
print("Withdrew all randomly generated host to host intents.");
}
@Override
protected ApplicationId appId() {
return get(CoreService.class).registerApplication("org.onosproject.cli-random");
}
}