eHanan | 97b7a9c | 2018-09-05 14:09:19 +0100 | [diff] [blame] | 1 | #!/bin/bash |
Gary Wu | a3fb86f | 2018-06-04 16:23:54 -0700 | [diff] [blame] | 2 | # |
| 3 | # Copyright 2018 Huawei Technologies Co., Ltd. |
| 4 | # |
| 5 | # Licensed under the Apache License, Version 2.0 (the "License"); |
| 6 | # you may not use this file except in compliance with the License. |
| 7 | # You may obtain a copy of the License at |
| 8 | # |
| 9 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 10 | # |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 11 | |
eHanan | 97b7a9c | 2018-09-05 14:09:19 +0100 | [diff] [blame] | 12 | stack_name="oom" |
eHanan | 58ccb9d | 2018-08-07 14:09:26 +0100 | [diff] [blame] | 13 | full_deletion=false |
| 14 | |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 15 | if [ -z "$WORKSPACE" ]; then |
| 16 | export WORKSPACE=`git rev-parse --show-toplevel` |
| 17 | fi |
| 18 | |
eHanan | 97b7a9c | 2018-09-05 14:09:19 +0100 | [diff] [blame] | 19 | usage() { |
Gary Wu | 03e724f | 2018-09-07 22:03:48 -0700 | [diff] [blame] | 20 | echo "Usage: $0 [ -n <number of VMs {2-15}> ][ -s <stack name> ][ -m <manifest> ][ -r ][ -q ] <env>" 1>&2; |
eHanan | 97b7a9c | 2018-09-05 14:09:19 +0100 | [diff] [blame] | 21 | |
| 22 | echo "n: Set the number of VM's that will be installed. This number must be between 2 and 15" 1>&2; |
| 23 | echo "s: Set the name to be used for stack. This name will be used for naming of resources" 1>&2; |
Gary Wu | 03e724f | 2018-09-07 22:03:48 -0700 | [diff] [blame] | 24 | echo "m: The docker manifest to apply; must be either \"docker-manifest-staging.csv\" or \"docker-manifest.csv\"." 1>&2; |
eHanan | 97b7a9c | 2018-09-05 14:09:19 +0100 | [diff] [blame] | 25 | echo "r: Delete all resources relating to ONAP within enviroment." 1>&2; |
| 26 | echo "q: Quiet Delete of all ONAP resources." 1>&2; |
| 27 | |
| 28 | exit 1; |
| 29 | } |
eHanan | 58ccb9d | 2018-08-07 14:09:26 +0100 | [diff] [blame] | 30 | |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 31 | |
Gary Wu | 03e724f | 2018-09-07 22:03:48 -0700 | [diff] [blame] | 32 | while getopts ":n:s:m:rq" o; do |
eHanan | 58ccb9d | 2018-08-07 14:09:26 +0100 | [diff] [blame] | 33 | case "${o}" in |
eHanan | 97b7a9c | 2018-09-05 14:09:19 +0100 | [diff] [blame] | 34 | n) |
| 35 | if [[ ${OPTARG} =~ ^[0-9]+$ ]];then |
| 36 | if [ ${OPTARG} -ge 2 -a ${OPTARG} -le 15 ]; then |
| 37 | vm_num=${OPTARG} |
| 38 | else |
| 39 | usage |
| 40 | fi |
| 41 | else |
| 42 | usage |
| 43 | fi |
| 44 | ;; |
| 45 | s) |
| 46 | if [[ ! ${OPTARG} =~ ^[0-9]+$ ]];then |
| 47 | stack_name=${OPTARG} |
| 48 | else |
| 49 | usage |
| 50 | fi |
| 51 | ;; |
Gary Wu | 03e724f | 2018-09-07 22:03:48 -0700 | [diff] [blame] | 52 | m) |
| 53 | if [ -f $WORKSPACE/version-manifest/src/main/resources/${OPTARG} ]; then |
| 54 | docker_manifest=${OPTARG} |
| 55 | else |
| 56 | usage |
| 57 | fi |
| 58 | ;; |
eHanan | 58ccb9d | 2018-08-07 14:09:26 +0100 | [diff] [blame] | 59 | r) |
| 60 | echo "The following command will delete all information relating to onap within your enviroment" |
| 61 | read -p "Are you certain this is what you want? (type y to confirm):" answer |
| 62 | |
| 63 | if [ $answer = "y" ] || [ $answer = "Y" ] || [ $answer = "yes" ] || [ $answer = "Yes"]; then |
| 64 | echo "This may delete the work of other colleages within the same enviroment" |
| 65 | read -p "Are you certain this is what you want? (type y to confirm):" answer2 |
Gary Wu | 87aa8b5 | 2018-08-09 08:10:24 -0700 | [diff] [blame] | 66 | |
eHanan | 58ccb9d | 2018-08-07 14:09:26 +0100 | [diff] [blame] | 67 | if [ $answer2 = "y" ] || [ $answer2 = "Y" ] || [ $answer2 = "yes" ] || [ $answer2 = "Yes"]; then |
| 68 | full_deletion=true |
Gary Wu | 87aa8b5 | 2018-08-09 08:10:24 -0700 | [diff] [blame] | 69 | else |
eHanan | 58ccb9d | 2018-08-07 14:09:26 +0100 | [diff] [blame] | 70 | echo "Ending program" |
| 71 | exit 1 |
| 72 | fi |
Gary Wu | 87aa8b5 | 2018-08-09 08:10:24 -0700 | [diff] [blame] | 73 | else |
eHanan | 58ccb9d | 2018-08-07 14:09:26 +0100 | [diff] [blame] | 74 | echo "Ending program" |
| 75 | exit 1 |
| 76 | fi |
| 77 | ;; |
| 78 | q) |
| 79 | full_deletion=true |
| 80 | ;; |
| 81 | *) |
| 82 | usage |
| 83 | ;; |
| 84 | esac |
| 85 | done |
| 86 | shift $((OPTIND-1)) |
| 87 | |
Gary Wu | 87aa8b5 | 2018-08-09 08:10:24 -0700 | [diff] [blame] | 88 | if [ "$#" -ne 1 ]; then |
| 89 | usage |
| 90 | fi |
| 91 | |
| 92 | ENV_FILE=$1 |
| 93 | |
eHanan | 97b7a9c | 2018-09-05 14:09:19 +0100 | [diff] [blame] | 94 | if [ ! -f $ENV_FILE ];then |
| 95 | echo ENV file does not exist or was not given |
| 96 | exit 1 |
| 97 | fi |
| 98 | |
| 99 | set -x |
| 100 | |
Gary Wu | 0d28fe6 | 2018-05-24 20:54:28 -0700 | [diff] [blame] | 101 | SSH_KEY=~/.ssh/onap_key |
| 102 | |
Gary Wu | 808b13d | 2018-02-13 18:28:37 -0800 | [diff] [blame] | 103 | source $WORKSPACE/test/ete/scripts/install_openstack_cli.sh |
| 104 | |
Gary Wu | 11c9874 | 2018-05-02 16:19:04 -0700 | [diff] [blame] | 105 | SO_ENCRYPTION_KEY=aa3871669d893c7fb8abbcda31b88b4f |
| 106 | export OS_PASSWORD_ENCRYPTED=$(echo -n "$OS_PASSWORD" | openssl aes-128-ecb -e -K "$SO_ENCRYPTION_KEY" -nosalt | xxd -c 256 -p) |
| 107 | |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 108 | for n in $(seq 1 5); do |
Gary Wu | 87aa8b5 | 2018-08-09 08:10:24 -0700 | [diff] [blame] | 109 | if [ $full_deletion = true ] ; then |
eHanan | 97b7a9c | 2018-09-05 14:09:19 +0100 | [diff] [blame] | 110 | $WORKSPACE/test/ete/scripts/teardown-onap.sh -n $stack_name -q |
Gary Wu | 87aa8b5 | 2018-08-09 08:10:24 -0700 | [diff] [blame] | 111 | else |
eHanan | 97b7a9c | 2018-09-05 14:09:19 +0100 | [diff] [blame] | 112 | $WORKSPACE/test/ete/scripts/teardown-onap.sh -n $stack_name |
eHanan | 58ccb9d | 2018-08-07 14:09:26 +0100 | [diff] [blame] | 113 | fi |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 114 | |
| 115 | cd $WORKSPACE/deployment/heat/onap-oom |
Gary Wu | 374498a | 2018-02-06 17:31:04 -0800 | [diff] [blame] | 116 | envsubst < $ENV_FILE > $ENV_FILE~ |
eHanan | 97b7a9c | 2018-09-05 14:09:19 +0100 | [diff] [blame] | 117 | if [ -z "$vm_num" ]; then |
| 118 | cp onap-oom.yaml onap-oom.yaml~ |
| 119 | else |
| 120 | ./scripts/gen-onap-oom-yaml.sh $vm_num > onap-oom.yaml~ |
| 121 | fi |
Gary Wu | d257997 | 2018-05-23 12:36:46 -0700 | [diff] [blame] | 122 | |
Gary Wu | 03e724f | 2018-09-07 22:03:48 -0700 | [diff] [blame] | 123 | if ! openstack stack create -t ./onap-oom.yaml~ -e $ENV_FILE~ $stack_name --parameter docker_manifest=$docker_manifest; then |
Gary Wu | d257997 | 2018-05-23 12:36:46 -0700 | [diff] [blame] | 124 | break |
| 125 | fi |
| 126 | |
eHanan | 97b7a9c | 2018-09-05 14:09:19 +0100 | [diff] [blame] | 127 | while [ "CREATE_IN_PROGRESS" == "$(openstack stack show -c stack_status -f value $stack_name)" ]; do |
Gary Wu | d257997 | 2018-05-23 12:36:46 -0700 | [diff] [blame] | 128 | sleep 20 |
| 129 | done |
| 130 | |
eHanan | 97b7a9c | 2018-09-05 14:09:19 +0100 | [diff] [blame] | 131 | STATUS=$(openstack stack show -c stack_status -f value $stack_name) |
Gary Wu | d257997 | 2018-05-23 12:36:46 -0700 | [diff] [blame] | 132 | echo $STATUS |
| 133 | if [ "CREATE_COMPLETE" != "$STATUS" ]; then |
| 134 | break |
| 135 | fi |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 136 | |
Gary Wu | ae7c764 | 2018-04-19 17:22:34 -0700 | [diff] [blame] | 137 | for i in $(seq 1 30); do |
| 138 | sleep 30 |
eHanan | 97b7a9c | 2018-09-05 14:09:19 +0100 | [diff] [blame] | 139 | RANCHER_IP=$(openstack stack output show $stack_name rancher_vm_ip -c output_value -f value) |
Gary Wu | 48a3294 | 2018-11-08 07:34:49 -0800 | [diff] [blame] | 140 | K8S_IP=$(openstack stack output show $stack_name k8s_01_vm_ip -c output_value -f value) |
Gary Wu | 14a6b30 | 2018-05-01 15:59:28 -0700 | [diff] [blame] | 141 | timeout 1 ping -c 1 "$RANCHER_IP" && break |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 142 | done |
| 143 | |
Gary Wu | 14a6b30 | 2018-05-01 15:59:28 -0700 | [diff] [blame] | 144 | timeout 1 ping -c 1 "$RANCHER_IP" && break |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 145 | |
Gary Wu | 14a6b30 | 2018-05-01 15:59:28 -0700 | [diff] [blame] | 146 | echo Error: OpenStack infrastructure issue: unable to reach rancher "$RANCHER_IP" |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 147 | sleep 10 |
| 148 | done |
| 149 | |
Gary Wu | 14a6b30 | 2018-05-01 15:59:28 -0700 | [diff] [blame] | 150 | if ! timeout 1 ping -c 1 "$RANCHER_IP"; then |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 151 | exit 2 |
| 152 | fi |
| 153 | |
Gary Wu | d3337f0 | 2018-05-24 10:51:23 -0700 | [diff] [blame] | 154 | ssh-keygen -R $RANCHER_IP |
| 155 | |
Gary Wu | b0e3650 | 2018-10-16 11:01:07 -0700 | [diff] [blame] | 156 | sleep 2m |
Gary Wu | 0d28fe6 | 2018-05-24 20:54:28 -0700 | [diff] [blame] | 157 | ssh -o StrictHostKeychecking=no -i $SSH_KEY ubuntu@$RANCHER_IP "sed -u '/Cloud-init.*finished/q' <(tail -n+0 -f /var/log/cloud-init-output.log)" |
Gary Wu | d257997 | 2018-05-23 12:36:46 -0700 | [diff] [blame] | 158 | |
Gary Wu | 895a4ac | 2018-10-31 12:30:54 -0700 | [diff] [blame] | 159 | PREV_RESULT=0 |
| 160 | for n in $(seq 1 20); do |
| 161 | RESULT=$(ssh -i $SSH_KEY ubuntu@$RANCHER_IP 'sudo su -c "kubectl -n onap get pods"' | grep -vE 'Running|Complete|NAME' | wc -l) |
| 162 | if [[ $? -eq 0 && ( $RESULT -eq 0 || $RESULT -eq $PREV_RESULT ) ]]; then |
| 163 | break |
| 164 | fi |
| 165 | sleep 15m |
| 166 | PREV_RESULT=$RESULT |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 167 | done |
Gary Wu | 895a4ac | 2018-10-31 12:30:54 -0700 | [diff] [blame] | 168 | |
| 169 | PREV_RESULT=0 |
| 170 | for n in $(seq 1 20); do |
| 171 | echo "Wait for HEALTHCHECK count $n of 10" |
| 172 | ROBOT_POD=$(ssh -i $SSH_KEY ubuntu@$RANCHER_IP 'sudo su -c "kubectl --namespace onap get pods"' | grep robot | sed 's/ .*//') |
| 173 | ssh -i $SSH_KEY ubuntu@$RANCHER_IP 'sudo su -l root -c "/root/oom/kubernetes/robot/ete-k8s.sh onap health"' |
| 174 | RESULT=$? |
| 175 | if [[ $RESULT -lt 10 && ( $RESULT -eq 0 || $RESULT -eq $PREV_RESULT ) ]]; then |
| 176 | break |
| 177 | fi |
| 178 | sleep 15m |
| 179 | PREV_RESULT=$RESULT |
| 180 | done |
Gary Wu | d257997 | 2018-05-23 12:36:46 -0700 | [diff] [blame] | 181 | if [ "$ROBOT_POD" == "" ]; then |
Gary Wu | 895a4ac | 2018-10-31 12:30:54 -0700 | [diff] [blame] | 182 | exit 1 |
Gary Wu | d257997 | 2018-05-23 12:36:46 -0700 | [diff] [blame] | 183 | fi |
Gary Wu | 36e42dd | 2018-05-03 07:29:53 -0700 | [diff] [blame] | 184 | |
Gary Wu | 43159fb | 2018-05-25 08:08:36 -0700 | [diff] [blame] | 185 | LOG_DIR=$(echo "kubectl exec -n onap $ROBOT_POD -- ls -1t /share/logs | grep health | head -1" | ssh -i $SSH_KEY ubuntu@$RANCHER_IP sudo su) |
Gary Wu | d257997 | 2018-05-23 12:36:46 -0700 | [diff] [blame] | 186 | echo "kubectl cp -n onap $ROBOT_POD:share/logs/$LOG_DIR /tmp/robot/logs/$LOG_DIR" | ssh -i $SSH_KEY ubuntu@$RANCHER_IP sudo su |
Gary Wu | d257997 | 2018-05-23 12:36:46 -0700 | [diff] [blame] | 187 | echo "Browse Robot results at http://$K8S_IP:30209/logs/$LOG_DIR/" |
Gary Wu | 895a4ac | 2018-10-31 12:30:54 -0700 | [diff] [blame] | 188 | mkdir -p $WORKSPACE/archives/healthcheck |
| 189 | rsync -e "ssh -i $SSH_KEY" -avtz ubuntu@$RANCHER_IP:/tmp/robot/logs/$LOG_DIR/ $WORKSPACE/archives/healthcheck |
Gary Wu | d257997 | 2018-05-23 12:36:46 -0700 | [diff] [blame] | 190 | |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 191 | exit 0 |