From 595587d31bb9c162d26bff3d318a12f4be44984f Mon Sep 17 00:00:00 2001 From: blsaws Date: Thu, 8 Sep 2016 23:38:34 -0700 Subject: Fix line endings JIRA: MODELS-23 Change-Id: I594cafd7773dcffc5683a0839e3b8b9d9c6d9a5e Signed-off-by: blsaws --- tests/vHello_Tacker.sh | 358 ++++++++++++++++++++++++------------------------- 1 file changed, 179 insertions(+), 179 deletions(-) (limited to 'tests/vHello_Tacker.sh') diff --git a/tests/vHello_Tacker.sh b/tests/vHello_Tacker.sh index c3335c3..5d57bcf 100644 --- a/tests/vHello_Tacker.sh +++ b/tests/vHello_Tacker.sh @@ -1,179 +1,179 @@ -#!/bin/bash -# Copyright 2016 AT&T Intellectual Property, Inc -# -# 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. -# -# What this is: Deployment test for the Tacker Hello World blueprint. -# -# Status: this is a work in progress, under test. -# -# How to use: -# $ git clone https://gerrit.opnfv.org/gerrit/models -# $ cd models/tests -# $ bash vHello_Tacker.sh [tacker-cli|tacker-api] [setup|start|clean] -# tacker-cli: use Tacker CLI -# tacker-api: use Tacker RESTful API (not yet implemented) -# setup: setup test environment -# start: run test -# clean: cleanup after test - -set -x - -pass() { - echo "Hooray!" - set +x #echo off - exit 0 -} - -# Use this to trigger fail() at the right places -# if [ "$RESULT" == "Test Failed!" ]; then fail; fi -fail() { - echo "Test Failed!" - set +x - exit 1 -} - -function get_floating_net () { - network_ids=($(neutron net-list|grep -v "+"|grep -v name|awk '{print $2}')) - for id in ${network_ids[@]}; do - [[ $(neutron net-show ${id}|grep 'router:external'|grep -i "true") != "" ]] && floating_network_id=${id} - done - if [[ $floating_network_id ]]; then - floating_network_name=$(openstack network show $floating_network_id | awk "/ name / { print \$4 }") - else - echo "$0: Floating network not found" - exit 1 - fi -} - -start() { - echo "$0: reset blueprints folder" - if [[ -d /tmp/tacker/blueprints/tosca-vnfd-hello-world-tacker ]]; then rm -rf /tmp/tacker/blueprints/tosca-vnfd-hello-world-tacker; fi - mkdir -p /tmp/tacker/blueprints/tosca-vnfd-hello-world-tacker - - echo "$0: copy tosca-vnfd-hello-world-tacker to blueprints folder" - cp -r blueprints/tosca-vnfd-hello-world-tacker /tmp/tacker/blueprints - cd /tmp/tacker/blueprints/tosca-vnfd-hello-world-tacker - - echo "$0: setup OpenStack CLI environment" - source /tmp/tacker/admin-openrc.sh - - echo "$0: Setup image_id" - image_id=$(openstack image list | awk "/ models-xenial-server / { print \$2 }") - if [ $image ]; then glance image-delete $image_id; fi - glance --os-image-api-version 1 image-create --name models-xenial-server --disk-format qcow2 --location http://bkaj.net/opnfv/xenial-server-cloudimg-amd64-disk1.img --container-format bare - - if [[ "$1" == "tacker-api" ]]; then - echo "$0: Tacker API use is not yet implemented" - else - # Tacker CLI use - echo "$0: Get external network for Floating IP allocations" - -# echo "$0: Create Nova key pair" -# mkdir -p ~/.ssh -# nova keypair-delete vHello -# nova keypair-add vHello > ~/.ssh/vHello.pem -# chmod 600 ~/.ssh/vHello.pem - - echo "$0: create VNFD" - tacker vnfd-create --vnfd-file tosca-vnfd-hello-world-tacker.yaml --name hello-world-tacker - if [ $? -eq 1 ]; then fail; fi - - echo "$0: create VNF" - tacker vnf-create --vnfd-name hello-world-tacker --name hello-world-tacker - if [ $? -eq 1 ]; then fail; fi - fi - - echo "$0: directly set port security on ports (bug/unsupported in Mitaka Tacker?)" - HEAT_ID=$(tacker vnf-show hello-world-tacker | awk "/instance_id/ { print \$4 }") - SERVER_ID=$(openstack stack resource list $HEAT_ID | awk "/VDU1 / { print \$4 }") - id=($(neutron port-list|grep -v "+"|grep -v name|awk '{print $2}')) - for id in ${id[@]}; do - if [[ $(neutron port-show $id|grep $SERVER_ID) ]]; then neutron port-update ${id} --port-security-enabled=True; fi - done - - echo "$0: directly assign security group (unsupported in Mitaka Tacker)" - if [[ $(neutron security-group-list | awk "/ vHello / { print \$2 }") ]]; then neutron security-group-delete vHello; fi - neutron security-group-create vHello - neutron security-group-rule-create --direction ingress --protocol=TCP --port-range-min=22 --port-range-max=22 vHello - neutron security-group-rule-create --direction ingress --protocol=TCP --port-range-min=80 --port-range-max=80 vHello - openstack server add security group $SERVER_ID vHello - openstack server add security group $SERVER_ID default - - echo "$0: associate floating IP" - get_floating_net - fip=$(neutron floatingip-create $floating_network_name | awk "/floating_ip_address/ { print \$4 }") - nova floating-ip-associate $SERVER_ID $fip - - echo "$0: get vHello server address" - SERVER_IP=$(openstack server show $SERVER_ID | awk "/ addresses / { print \$6 }") - SERVER_URL="http://$SERVER_IP" - - echo "$0: start vHello web server" - scp -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no start.sh opnfv:opnfv@$SERVER_IP:/home/opnfv - ssh -x -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no opnfv:opnfv@$SERVER_IP "bash start.sh; exit" - - echo "$0: verify vHello server is running" - if [[ $(curl $SERVER_URL | grep -c "Hello, World!") != 1 ]]; then fail; fi - - pass -} - -clean() { - echo "$0: setup OpenStack CLI environment" - source /tmp/tacker/admin-openrc.sh - - if [[ "$1" == "tacker-api" ]]; then - echo "$0: Tacker API use is not yet implemented" - else - echo "$0: uninstall vHello blueprint via CLI" - tacker vnf-delete tosca-hello-world - if [ $? -eq 1 ]; then fail; fi - tacker vnfd-delete tosca-hello-world - if [ $? -eq 1 ]; then fail; fi - neutron security-group-delete vHello - if [ $? -eq 1 ]; then fail; fi - fip=($(neutron floatingip-list|grep -v "+"|grep -v id|awk '{print $2}')); for id in ${fip[@]}; do neutron floatingip-delete ${id}; done - if [ $? -eq 1 ]; then fail; fi - fi - pass -} - -if [[ "$2" == "setup" ]]; then - echo "$0: Setup temp test folder /tmp/tacker and copy this script there" - mkdir /tmp/tacker - chmod 777 /tmp/tacker/ - cp $0 /tmp/tacker/. - chmod 755 /tmp/tacker/*.sh - - echo "$0: tacker-setup part 1" - bash utils/tacker-setup.sh $1 init - - echo "$0: tacker-setup part 2" - CONTAINER=$(sudo docker ps -l | awk "/tacker/ { print \$1 }") - sudo docker exec $CONTAINER /tmp/tacker/tacker-setup.sh $1 setup - if [ $? -eq 1 ]; then fail; fi - pass -else - if [[ $# -eq 3 ]]; then - # running inside the tacker container, ready to go - if [[ "$3" == "start" ]]; then start $1; fi - if [[ "$3" == "clean" ]]; then clean $1; fi - else - echo "$0: pass $2 command to vHello.sh in tacker container" - CONTAINER=$(sudo docker ps -a | awk "/tacker/ { print \$1 }") - sudo docker exec $CONTAINER /tmp/tacker/vHello.sh $1 $2 $2 - if [ $? -eq 1 ]; then fail; fi - pass - fi -fi +#!/bin/bash +# Copyright 2016 AT&T Intellectual Property, Inc +# +# 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. +# +# What this is: Deployment test for the Tacker Hello World blueprint. +# +# Status: this is a work in progress, under test. +# +# How to use: +# $ git clone https://gerrit.opnfv.org/gerrit/models +# $ cd models/tests +# $ bash vHello_Tacker.sh [tacker-cli|tacker-api] [setup|start|clean] +# tacker-cli: use Tacker CLI +# tacker-api: use Tacker RESTful API (not yet implemented) +# setup: setup test environment +# start: run test +# clean: cleanup after test + +set -x + +pass() { + echo "Hooray!" + set +x #echo off + exit 0 +} + +# Use this to trigger fail() at the right places +# if [ "$RESULT" == "Test Failed!" ]; then fail; fi +fail() { + echo "Test Failed!" + set +x + exit 1 +} + +function get_floating_net () { + network_ids=($(neutron net-list|grep -v "+"|grep -v name|awk '{print $2}')) + for id in ${network_ids[@]}; do + [[ $(neutron net-show ${id}|grep 'router:external'|grep -i "true") != "" ]] && floating_network_id=${id} + done + if [[ $floating_network_id ]]; then + floating_network_name=$(openstack network show $floating_network_id | awk "/ name / { print \$4 }") + else + echo "$0: Floating network not found" + exit 1 + fi +} + +start() { + echo "$0: reset blueprints folder" + if [[ -d /tmp/tacker/blueprints/tosca-vnfd-hello-world-tacker ]]; then rm -rf /tmp/tacker/blueprints/tosca-vnfd-hello-world-tacker; fi + mkdir -p /tmp/tacker/blueprints/tosca-vnfd-hello-world-tacker + + echo "$0: copy tosca-vnfd-hello-world-tacker to blueprints folder" + cp -r blueprints/tosca-vnfd-hello-world-tacker /tmp/tacker/blueprints + cd /tmp/tacker/blueprints/tosca-vnfd-hello-world-tacker + + echo "$0: setup OpenStack CLI environment" + source /tmp/tacker/admin-openrc.sh + + echo "$0: Setup image_id" + image_id=$(openstack image list | awk "/ models-xenial-server / { print \$2 }") + if [ $image ]; then glance image-delete $image_id; fi + glance --os-image-api-version 1 image-create --name models-xenial-server --disk-format qcow2 --location http://bkaj.net/opnfv/xenial-server-cloudimg-amd64-disk1.img --container-format bare + + if [[ "$1" == "tacker-api" ]]; then + echo "$0: Tacker API use is not yet implemented" + else + # Tacker CLI use + echo "$0: Get external network for Floating IP allocations" + +# echo "$0: Create Nova key pair" +# mkdir -p ~/.ssh +# nova keypair-delete vHello +# nova keypair-add vHello > ~/.ssh/vHello.pem +# chmod 600 ~/.ssh/vHello.pem + + echo "$0: create VNFD" + tacker vnfd-create --vnfd-file tosca-vnfd-hello-world-tacker.yaml --name hello-world-tacker + if [ $? -eq 1 ]; then fail; fi + + echo "$0: create VNF" + tacker vnf-create --vnfd-name hello-world-tacker --name hello-world-tacker + if [ $? -eq 1 ]; then fail; fi + fi + + echo "$0: directly set port security on ports (bug/unsupported in Mitaka Tacker?)" + HEAT_ID=$(tacker vnf-show hello-world-tacker | awk "/instance_id/ { print \$4 }") + SERVER_ID=$(openstack stack resource list $HEAT_ID | awk "/VDU1 / { print \$4 }") + id=($(neutron port-list|grep -v "+"|grep -v name|awk '{print $2}')) + for id in ${id[@]}; do + if [[ $(neutron port-show $id|grep $SERVER_ID) ]]; then neutron port-update ${id} --port-security-enabled=True; fi + done + + echo "$0: directly assign security group (unsupported in Mitaka Tacker)" + if [[ $(neutron security-group-list | awk "/ vHello / { print \$2 }") ]]; then neutron security-group-delete vHello; fi + neutron security-group-create vHello + neutron security-group-rule-create --direction ingress --protocol=TCP --port-range-min=22 --port-range-max=22 vHello + neutron security-group-rule-create --direction ingress --protocol=TCP --port-range-min=80 --port-range-max=80 vHello + openstack server add security group $SERVER_ID vHello + openstack server add security group $SERVER_ID default + + echo "$0: associate floating IP" + get_floating_net + fip=$(neutron floatingip-create $floating_network_name | awk "/floating_ip_address/ { print \$4 }") + nova floating-ip-associate $SERVER_ID $fip + + echo "$0: get vHello server address" + SERVER_IP=$(openstack server show $SERVER_ID | awk "/ addresses / { print \$6 }") + SERVER_URL="http://$SERVER_IP" + + echo "$0: start vHello web server" + scp -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no start.sh opnfv:opnfv@$SERVER_IP:/home/opnfv + ssh -x -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no opnfv:opnfv@$SERVER_IP "bash start.sh; exit" + + echo "$0: verify vHello server is running" + if [[ $(curl $SERVER_URL | grep -c "Hello, World!") != 1 ]]; then fail; fi + + pass +} + +clean() { + echo "$0: setup OpenStack CLI environment" + source /tmp/tacker/admin-openrc.sh + + if [[ "$1" == "tacker-api" ]]; then + echo "$0: Tacker API use is not yet implemented" + else + echo "$0: uninstall vHello blueprint via CLI" + tacker vnf-delete tosca-hello-world + if [ $? -eq 1 ]; then fail; fi + tacker vnfd-delete tosca-hello-world + if [ $? -eq 1 ]; then fail; fi + neutron security-group-delete vHello + if [ $? -eq 1 ]; then fail; fi + fip=($(neutron floatingip-list|grep -v "+"|grep -v id|awk '{print $2}')); for id in ${fip[@]}; do neutron floatingip-delete ${id}; done + if [ $? -eq 1 ]; then fail; fi + fi + pass +} + +if [[ "$2" == "setup" ]]; then + echo "$0: Setup temp test folder /tmp/tacker and copy this script there" + mkdir /tmp/tacker + chmod 777 /tmp/tacker/ + cp $0 /tmp/tacker/. + chmod 755 /tmp/tacker/*.sh + + echo "$0: tacker-setup part 1" + bash utils/tacker-setup.sh $1 init + + echo "$0: tacker-setup part 2" + CONTAINER=$(sudo docker ps -l | awk "/tacker/ { print \$1 }") + sudo docker exec $CONTAINER /tmp/tacker/tacker-setup.sh $1 setup + if [ $? -eq 1 ]; then fail; fi + pass +else + if [[ $# -eq 3 ]]; then + # running inside the tacker container, ready to go + if [[ "$3" == "start" ]]; then start $1; fi + if [[ "$3" == "clean" ]]; then clean $1; fi + else + echo "$0: pass $2 command to vHello.sh in tacker container" + CONTAINER=$(sudo docker ps -a | awk "/tacker/ { print \$1 }") + sudo docker exec $CONTAINER /tmp/tacker/vHello.sh $1 $2 $2 + if [ $? -eq 1 ]; then fail; fi + pass + fi +fi -- cgit 1.2.3-korg