From 13d05bc8458758ee39cb829098241e89616717ee Mon Sep 17 00:00:00 2001 From: Ashlee Young Date: Wed, 9 Sep 2015 22:15:21 -0700 Subject: ONOS checkin based on commit tag e796610b1f721d02f9b0e213cf6f7790c10ecd60 Change-Id: Ife8810491034fe7becdba75dda20de4267bd15cd --- framework/src/onos/tools/test/bin/onos-service | 55 ++++++++++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100755 framework/src/onos/tools/test/bin/onos-service (limited to 'framework/src/onos/tools/test/bin/onos-service') diff --git a/framework/src/onos/tools/test/bin/onos-service b/framework/src/onos/tools/test/bin/onos-service new file mode 100755 index 00000000..cc694911 --- /dev/null +++ b/framework/src/onos/tools/test/bin/onos-service @@ -0,0 +1,55 @@ +#!/bin/bash +# ----------------------------------------------------------------------------- +# Remotely administers the ONOS service on the specified node. +# ----------------------------------------------------------------------------- + +[ ! -d "$ONOS_ROOT" ] && echo "ONOS_ROOT is not defined" >&2 && exit 1 +. $ONOS_ROOT/tools/build/envDefaults +. $ONOS_ROOT/tools/test/bin/find-node.sh + +function print_usage { + command_name=`basename $0` + echo "Remotely administer the ONOS service on a single node or the current ONOS cell." + echo + echo "Usage: $command_name [COMMAND]" + echo " $command_name [-h | --help]" + echo "Options:" + echo " TARGET The target of the command" + echo " COMMAND The command to execute. Default value is 'status'" + echo " [-h | --help] Print this help" + echo "" + echo "TARGET: " + echo " hostname Execute on the specified host name" + echo " --cell Execute on the current ONOS cell" + echo "" + echo "COMMAND: [start|stop|restart|status]" + echo "" +} + +# Print usage +if [ "${1}" = "-h" -o "${1}" = "--help" ]; then + print_usage + exit 0 +fi + +case $2 in + start|stop|restart|status) + + # Select the target + if [ "${1}" = "--cell" ]; then + nodes=$(env | sort | egrep "OC[0-9]+" | cut -d= -f2) + else + nodes=$(find_node ${1:-$OCI}) + fi + + # Execute the remote commands + for node in $nodes; do + ssh $ONOS_USER@${node} "sudo ${2:-status} onos" + done + ;; + *) + echo "error: $2 is not a valid command" + echo "" + print_usage + ;; +esac -- cgit 1.2.3-korg