2 * Copyright (c) 2013 Ericsson , Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
9 package org.opendaylight.openflowplugin.droptestkaraf;
11 import java.io.PrintStream;
12 import org.apache.karaf.shell.commands.Argument;
13 import org.apache.karaf.shell.commands.Command;
14 import org.apache.karaf.shell.console.OsgiCommandSupport;
15 import org.opendaylight.openflowplugin.testcommon.DropTestRpcProvider;
17 @Command(scope = "drop-test", name = "dropAllPacketsRpc",
18 description = "drop packet responder involving SalFlowService")
19 public class DropAllPacketsRpcCommandProvider extends OsgiCommandSupport {
21 @Argument(index = 0, name = "on-off",
22 description = "target state of drop responder",
23 required = true, multiValued = false)
24 String targetStateArg;
27 protected Object doExecute() throws Exception {
28 PrintStream out = session.getConsole();
29 final DropTestRpcProvider provider = DropTestProviderImpl.getDropRpcProvider();
31 if ("on".equalsIgnoreCase(targetStateArg)) {
32 if (! provider.isActive()) {
34 out.println("DropAllFlows transitions to on");
36 out.println("DropAllFlows is already on");
38 } else if ("off".equalsIgnoreCase(targetStateArg)) {
39 if (provider.isActive()) {
41 out.println("DropAllFlows transitions to off");
43 out.println("DropAllFlows is already off");
49 //TODO: create commands
50 // public void _showDropStats(final CommandInterpreter ci) {
51 // if (sessionInitiated) {
52 // ci.println("RPC Test Statistics: " + this.rpcProvider.getStats().toString());
53 // ci.println("FRM Test Statistics: " + this.provider.getStats().toString());
55 // ci.println("Session not initiated, try again in a few seconds");
59 // public void _clearDropStats(final CommandInterpreter ci) {
60 // if (sessionInitiated) {
61 // ci.print("Clearing drop statistics... ");
62 // this.rpcProvider.clearStats();
63 // this.provider.clearStats();
64 // ci.println("Done.");
67 // ci.println("Session not initiated, try again in a few seconds");