| #!/usr/bin/env bash | 
 | # | 
 | # Copyright 2012, Cisco Systems | 
 | # Copyright 2012, VMware, Inc. | 
 | # Copyright 2012, NTT MCL, Inc. | 
 | # | 
 | # Please direct any questions to dedutta@cisco.com, dwendlandt@vmware.com, nachi@nttmcl.com | 
 | # | 
 | # **neutron-adv-test.sh** | 
 |  | 
 | # Perform integration testing of Nova and other components with Neutron. | 
 |  | 
 | echo "*********************************************************************" | 
 | echo "Begin DevStack Exercise: $0" | 
 | echo "*********************************************************************" | 
 |  | 
 | # This script exits on an error so that errors don't compound and you see | 
 | # only the first error that occurred. | 
 |  | 
 | set -o errtrace | 
 |  | 
 | # Print the commands being run so that we can see the command that triggers | 
 | # an error.  It is also useful for following allowing as the install occurs. | 
 | set -o xtrace | 
 |  | 
 | # Environment | 
 | # ----------- | 
 |  | 
 | # Keep track of the current directory | 
 | EXERCISE_DIR=$(cd $(dirname "$0") && pwd) | 
 | TOP_DIR=$(cd $EXERCISE_DIR/..; pwd) | 
 |  | 
 | # Import common functions | 
 | source $TOP_DIR/functions | 
 |  | 
 | # Import configuration | 
 | source $TOP_DIR/openrc | 
 |  | 
 | # Import neutron functions | 
 | source $TOP_DIR/lib/neutron-legacy | 
 |  | 
 | # If neutron is not enabled we exit with exitcode 55, which means exercise is skipped. | 
 | neutron_plugin_check_adv_test_requirements || exit 55 | 
 |  | 
 | # Import exercise configuration | 
 | source $TOP_DIR/exerciserc | 
 |  | 
 | # Neutron Settings | 
 | # ---------------- | 
 |  | 
 | TENANTS="DEMO1" | 
 | # TODO (nati)_Test public network | 
 | #TENANTS="DEMO1,DEMO2" | 
 |  | 
 | PUBLIC_NAME="admin" | 
 | DEMO1_NAME="demo1" | 
 | DEMO2_NAME="demo2" | 
 |  | 
 | PUBLIC_NUM_NET=1 | 
 | DEMO1_NUM_NET=1 | 
 | DEMO2_NUM_NET=2 | 
 |  | 
 | PUBLIC_NET1_CIDR="200.0.0.0/24" | 
 | DEMO1_NET1_CIDR="10.10.0.0/24" | 
 | DEMO2_NET1_CIDR="10.20.0.0/24" | 
 | DEMO2_NET2_CIDR="10.20.1.0/24" | 
 |  | 
 | PUBLIC_NET1_GATEWAY="200.0.0.1" | 
 | DEMO1_NET1_GATEWAY="10.10.0.1" | 
 | DEMO2_NET1_GATEWAY="10.20.0.1" | 
 | DEMO2_NET2_GATEWAY="10.20.1.1" | 
 |  | 
 | PUBLIC_NUM_VM=1 | 
 | DEMO1_NUM_VM=1 | 
 | DEMO2_NUM_VM=2 | 
 |  | 
 | PUBLIC_VM1_NET='admin-net1' | 
 | DEMO1_VM1_NET='demo1-net1' | 
 | # Multinic settings. But this is fail without nic setting in OS image | 
 | DEMO2_VM1_NET='demo2-net1' | 
 | DEMO2_VM2_NET='demo2-net2' | 
 |  | 
 | PUBLIC_NUM_ROUTER=1 | 
 | DEMO1_NUM_ROUTER=1 | 
 | DEMO2_NUM_ROUTER=1 | 
 |  | 
 | PUBLIC_ROUTER1_NET="admin-net1" | 
 | DEMO1_ROUTER1_NET="demo1-net1" | 
 | DEMO2_ROUTER1_NET="demo2-net1" | 
 |  | 
 | # Various functions | 
 | # ----------------- | 
 |  | 
 | function foreach_tenant { | 
 |     COMMAND=$1 | 
 |     for TENANT in ${TENANTS//,/ };do | 
 |         eval ${COMMAND//%TENANT%/$TENANT} | 
 |     done | 
 | } | 
 |  | 
 | function foreach_tenant_resource { | 
 |     COMMAND=$1 | 
 |     RESOURCE=$2 | 
 |     for TENANT in ${TENANTS//,/ };do | 
 |         eval 'NUM=$'"${TENANT}_NUM_$RESOURCE" | 
 |         for i in `seq $NUM`;do | 
 |             local COMMAND_LOCAL=${COMMAND//%TENANT%/$TENANT} | 
 |             COMMAND_LOCAL=${COMMAND_LOCAL//%NUM%/$i} | 
 |             eval $COMMAND_LOCAL | 
 |         done | 
 |     done | 
 | } | 
 |  | 
 | function foreach_tenant_vm { | 
 |     COMMAND=$1 | 
 |     foreach_tenant_resource "$COMMAND" 'VM' | 
 | } | 
 |  | 
 | function foreach_tenant_net { | 
 |     COMMAND=$1 | 
 |     foreach_tenant_resource "$COMMAND" 'NET' | 
 | } | 
 |  | 
 | function get_image_id { | 
 |     local IMAGE_ID | 
 |     IMAGE_ID=$(openstack image list | egrep " $DEFAULT_IMAGE_NAME " | get_field 1) | 
 |     die_if_not_set $LINENO IMAGE_ID "Failure retrieving IMAGE_ID" | 
 |     echo "$IMAGE_ID" | 
 | } | 
 |  | 
 | function get_tenant_id { | 
 |     local TENANT_NAME=$1 | 
 |     local TENANT_ID | 
 |     TENANT_ID=`openstack project list | grep " $TENANT_NAME " | head -n 1 | get_field 1` | 
 |     die_if_not_set $LINENO TENANT_ID "Failure retrieving TENANT_ID for $TENANT_NAME" | 
 |     echo "$TENANT_ID" | 
 | } | 
 |  | 
 | function get_user_id { | 
 |     local USER_NAME=$1 | 
 |     local USER_ID | 
 |     USER_ID=`openstack user list | grep $USER_NAME | awk '{print $2}'` | 
 |     die_if_not_set $LINENO USER_ID "Failure retrieving USER_ID for $USER_NAME" | 
 |     echo "$USER_ID" | 
 | } | 
 |  | 
 | function get_role_id { | 
 |     local ROLE_NAME=$1 | 
 |     local ROLE_ID | 
 |     ROLE_ID=`openstack role list | grep $ROLE_NAME | awk '{print $2}'` | 
 |     die_if_not_set $LINENO ROLE_ID "Failure retrieving ROLE_ID for $ROLE_NAME" | 
 |     echo "$ROLE_ID" | 
 | } | 
 |  | 
 | function get_network_id { | 
 |     local NETWORK_NAME="$1" | 
 |     local NETWORK_ID | 
 |     NETWORK_ID=`neutron net-list -F id  -- --name=$NETWORK_NAME | awk "NR==4" | awk '{print $2}'` | 
 |     echo $NETWORK_ID | 
 | } | 
 |  | 
 | function get_flavor_id { | 
 |     local INSTANCE_TYPE=$1 | 
 |     local FLAVOR_ID | 
 |     FLAVOR_ID=`nova flavor-list | grep $INSTANCE_TYPE | awk '{print $2}'` | 
 |     die_if_not_set $LINENO FLAVOR_ID "Failure retrieving FLAVOR_ID for $INSTANCE_TYPE" | 
 |     echo "$FLAVOR_ID" | 
 | } | 
 |  | 
 | function confirm_server_active { | 
 |     local VM_UUID=$1 | 
 |     if ! timeout $ACTIVE_TIMEOUT sh -c "while ! nova show $VM_UUID | grep status | grep -q ACTIVE; do sleep 1; done"; then | 
 |         echo "server '$VM_UUID' did not become active!" | 
 |         false | 
 |     fi | 
 | } | 
 |  | 
 | function neutron_debug_admin { | 
 |     local os_username=$OS_USERNAME | 
 |     local os_tenant_id=$OS_TENANT_ID | 
 |     source $TOP_DIR/openrc admin admin | 
 |     neutron-debug $@ | 
 |     source $TOP_DIR/openrc $os_username $os_tenant_id | 
 | } | 
 |  | 
 | function add_tenant { | 
 |     openstack project create $1 | 
 |     openstack user create $2 --password ${ADMIN_PASSWORD} --project $1 | 
 |     openstack role add Member --project $1 --user $2 | 
 | } | 
 |  | 
 | function remove_tenant { | 
 |     local TENANT=$1 | 
 |     local TENANT_ID | 
 |     TENANT_ID=$(get_tenant_id $TENANT) | 
 |     openstack project delete $TENANT_ID | 
 | } | 
 |  | 
 | function remove_user { | 
 |     local USER=$1 | 
 |     local USER_ID | 
 |     USER_ID=$(get_user_id $USER) | 
 |     openstack user delete $USER_ID | 
 | } | 
 |  | 
 | function create_tenants { | 
 |     source $TOP_DIR/openrc admin admin | 
 |     add_tenant demo1 demo1 demo1 | 
 |     add_tenant demo2 demo2 demo2 | 
 |     source $TOP_DIR/openrc demo demo | 
 | } | 
 |  | 
 | function delete_tenants_and_users { | 
 |     source $TOP_DIR/openrc admin admin | 
 |     remove_user demo1 | 
 |     remove_tenant demo1 | 
 |     remove_user demo2 | 
 |     remove_tenant demo2 | 
 |     echo "removed all tenants" | 
 |     source $TOP_DIR/openrc demo demo | 
 | } | 
 |  | 
 | function create_network { | 
 |     local TENANT=$1 | 
 |     local GATEWAY=$2 | 
 |     local CIDR=$3 | 
 |     local NUM=$4 | 
 |     local EXTRA=$5 | 
 |     local NET_NAME="${TENANT}-net$NUM" | 
 |     local ROUTER_NAME="${TENANT}-router${NUM}" | 
 |     source $TOP_DIR/openrc admin admin | 
 |     local TENANT_ID | 
 |     TENANT_ID=$(get_tenant_id $TENANT) | 
 |     source $TOP_DIR/openrc $TENANT $TENANT | 
 |     local NET_ID | 
 |     NET_ID=$(neutron net-create --tenant-id $TENANT_ID $NET_NAME $EXTRA| grep ' id ' | awk '{print $4}' ) | 
 |     die_if_not_set $LINENO NET_ID "Failure creating NET_ID for $TENANT_ID $NET_NAME $EXTRA" | 
 |     neutron subnet-create --ip-version 4 --tenant-id $TENANT_ID --gateway $GATEWAY $NET_ID $CIDR | 
 |     neutron_debug_admin probe-create --device-owner compute $NET_ID | 
 |     source $TOP_DIR/openrc demo demo | 
 | } | 
 |  | 
 | function create_networks { | 
 |     foreach_tenant_net 'create_network ${%TENANT%_NAME} ${%TENANT%_NET%NUM%_GATEWAY} ${%TENANT%_NET%NUM%_CIDR} %NUM% ${%TENANT%_NET%NUM%_EXTRA}' | 
 |     #TODO(nati) test security group function | 
 |     # allow ICMP for both tenant's security groups | 
 |     #source $TOP_DIR/openrc demo1 demo1 | 
 |     #$NOVA secgroup-add-rule default icmp -1 -1 0.0.0.0/0 | 
 |     #source $TOP_DIR/openrc demo2 demo2 | 
 |     #$NOVA secgroup-add-rule default icmp -1 -1 0.0.0.0/0 | 
 | } | 
 |  | 
 | function create_vm { | 
 |     local TENANT=$1 | 
 |     local NUM=$2 | 
 |     local NET_NAMES=$3 | 
 |     source $TOP_DIR/openrc $TENANT $TENANT | 
 |     local NIC="" | 
 |     for NET_NAME in ${NET_NAMES//,/ };do | 
 |         NIC="$NIC --nic net-id="`get_network_id $NET_NAME` | 
 |     done | 
 |     #TODO (nati) Add multi-nic test | 
 |     #TODO (nati) Add public-net test | 
 |     local VM_UUID | 
 |     VM_UUID=`nova boot --flavor $(get_flavor_id m1.tiny) \ | 
 |         --image $(get_image_id) \ | 
 |         $NIC \ | 
 |         $TENANT-server$NUM | grep ' id ' | cut -d"|" -f3 | sed 's/ //g'` | 
 |     die_if_not_set $LINENO VM_UUID "Failure launching $TENANT-server$NUM" | 
 |     confirm_server_active $VM_UUID | 
 | } | 
 |  | 
 | function create_vms { | 
 |     foreach_tenant_vm 'create_vm ${%TENANT%_NAME} %NUM% ${%TENANT%_VM%NUM%_NET}' | 
 | } | 
 |  | 
 | function ping_ip { | 
 |     # Test agent connection.  Assumes namespaces are disabled, and | 
 |     # that DHCP is in use, but not L3 | 
 |     local VM_NAME=$1 | 
 |     local NET_NAME=$2 | 
 |     IP=$(get_instance_ip $VM_NAME $NET_NAME) | 
 |     ping_check $IP $BOOT_TIMEOUT $NET_NAME | 
 | } | 
 |  | 
 | function check_vm { | 
 |     local TENANT=$1 | 
 |     local NUM=$2 | 
 |     local VM_NAME="$TENANT-server$NUM" | 
 |     local NET_NAME=$3 | 
 |     source $TOP_DIR/openrc $TENANT $TENANT | 
 |     ping_ip $VM_NAME $NET_NAME | 
 |     # TODO (nati) test ssh connection | 
 |     # TODO (nati) test inter connection between vm | 
 |     # TODO (nati) test dhcp host routes | 
 |     # TODO (nati) test multi-nic | 
 | } | 
 |  | 
 | function check_vms { | 
 |     foreach_tenant_vm 'check_vm ${%TENANT%_NAME} %NUM% ${%TENANT%_VM%NUM%_NET}' | 
 | } | 
 |  | 
 | function shutdown_vm { | 
 |     local TENANT=$1 | 
 |     local NUM=$2 | 
 |     source $TOP_DIR/openrc $TENANT $TENANT | 
 |     VM_NAME=${TENANT}-server$NUM | 
 |     nova delete $VM_NAME | 
 | } | 
 |  | 
 | function shutdown_vms { | 
 |     foreach_tenant_vm 'shutdown_vm ${%TENANT%_NAME} %NUM%' | 
 |     if ! timeout $TERMINATE_TIMEOUT sh -c "while nova list | grep -q ACTIVE; do sleep 1; done"; then | 
 |         die $LINENO "Some VMs failed to shutdown" | 
 |     fi | 
 | } | 
 |  | 
 | function delete_network { | 
 |     local TENANT=$1 | 
 |     local NUM=$2 | 
 |     local NET_NAME="${TENANT}-net$NUM" | 
 |     source $TOP_DIR/openrc admin admin | 
 |     local TENANT_ID | 
 |     TENANT_ID=$(get_tenant_id $TENANT) | 
 |     #TODO(nati) comment out until l3-agent merged | 
 |     #for res in port subnet net router;do | 
 |     for net_id in `neutron net-list -c id -c name | grep $NET_NAME | awk '{print $2}'`;do | 
 |         delete_probe $net_id | 
 |         neutron subnet-list | grep $net_id | awk '{print $2}' | xargs -I% neutron subnet-delete % | 
 |         neutron net-delete $net_id | 
 |     done | 
 |     source $TOP_DIR/openrc demo demo | 
 | } | 
 |  | 
 | function delete_networks { | 
 |     foreach_tenant_net 'delete_network ${%TENANT%_NAME} %NUM%' | 
 |     # TODO(nati) add secuirty group check after it is implemented | 
 |     # source $TOP_DIR/openrc demo1 demo1 | 
 |     # nova secgroup-delete-rule default icmp -1 -1 0.0.0.0/0 | 
 |     # source $TOP_DIR/openrc demo2 demo2 | 
 |     # nova secgroup-delete-rule default icmp -1 -1 0.0.0.0/0 | 
 | } | 
 |  | 
 | function create_all { | 
 |     create_tenants | 
 |     create_networks | 
 |     create_vms | 
 | } | 
 |  | 
 | function delete_all { | 
 |     shutdown_vms | 
 |     delete_networks | 
 |     delete_tenants_and_users | 
 | } | 
 |  | 
 | function all { | 
 |     create_all | 
 |     check_vms | 
 |     delete_all | 
 | } | 
 |  | 
 | # Test functions | 
 | # -------------- | 
 |  | 
 | function test_functions { | 
 |     IMAGE=$(get_image_id) | 
 |     echo $IMAGE | 
 |  | 
 |     TENANT_ID=$(get_tenant_id demo) | 
 |     echo $TENANT_ID | 
 |  | 
 |     FLAVOR_ID=$(get_flavor_id m1.tiny) | 
 |     echo $FLAVOR_ID | 
 |  | 
 |     NETWORK_ID=$(get_network_id admin) | 
 |     echo $NETWORK_ID | 
 | } | 
 |  | 
 | # Usage and main | 
 | # -------------- | 
 |  | 
 | function usage { | 
 |     echo "$0: [-h]" | 
 |     echo "  -h, --help              Display help message" | 
 |     echo "  -t, --tenant            Create tenants" | 
 |     echo "  -n, --net               Create networks" | 
 |     echo "  -v, --vm                Create vms" | 
 |     echo "  -c, --check             Check connection" | 
 |     echo "  -x, --delete-tenants    Delete tenants" | 
 |     echo "  -y, --delete-nets       Delete networks" | 
 |     echo "  -z, --delete-vms        Delete vms" | 
 |     echo "  -T, --test              Test functions" | 
 | } | 
 |  | 
 | function main { | 
 |  | 
 |     echo Description | 
 |  | 
 |     if [ $# -eq 0 ] ; then | 
 |         # if no args are provided, run all tests | 
 |         all | 
 |     else | 
 |  | 
 |         while [ "$1" != "" ]; do | 
 |             case $1 in | 
 |                 -h | --help )   usage | 
 |                                 exit | 
 |                                 ;; | 
 |                 -n | --net )    create_networks | 
 |                                 exit | 
 |                                 ;; | 
 |                 -v | --vm )     create_vms | 
 |                                 exit | 
 |                                 ;; | 
 |                 -t | --tenant ) create_tenants | 
 |                                 exit | 
 |                                 ;; | 
 |                 -c | --check )   check_vms | 
 |                                 exit | 
 |                                 ;; | 
 |                 -T | --test )   test_functions | 
 |                                 exit | 
 |                                 ;; | 
 |                 -x | --delete-tenants ) delete_tenants_and_users | 
 |                                 exit | 
 |                                 ;; | 
 |                 -y | --delete-nets ) delete_networks | 
 |                                 exit | 
 |                                 ;; | 
 |                 -z | --delete-vms ) shutdown_vms | 
 |                                 exit | 
 |                                 ;; | 
 |                 -a | --all )    all | 
 |                                 exit | 
 |                                 ;; | 
 |                 * )             usage | 
 |                                 exit 1 | 
 |             esac | 
 |             shift | 
 |         done | 
 |     fi | 
 | } | 
 |  | 
 | trap failed ERR | 
 | function failed { | 
 |     local r=$? | 
 |     set +o errtrace | 
 |     set +o xtrace | 
 |     echo "Failed to execute" | 
 |     echo "Starting cleanup..." | 
 |     delete_all | 
 |     echo "Finished cleanup" | 
 |     exit $r | 
 | } | 
 |  | 
 | # Kick off script | 
 | # --------------- | 
 |  | 
 | echo $* | 
 | main $* | 
 |  | 
 | set +o xtrace | 
 | echo "*********************************************************************" | 
 | echo "SUCCESS: End DevStack Exercise: $0" | 
 | echo "*********************************************************************" |