Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 1 | #!/bin/bash -x |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 2 | |
| 3 | if [ -z "$WORKSPACE" ]; then |
| 4 | export WORKSPACE=`git rev-parse --show-toplevel` |
| 5 | fi |
| 6 | |
| 7 | if [ "$#" -ne 1 ]; then |
| 8 | echo "Usage: $0 <env-name>" |
| 9 | exit 1 |
| 10 | fi |
| 11 | ENV_FILE=$1 |
| 12 | |
Gary Wu | 808b13d | 2018-02-13 18:28:37 -0800 | [diff] [blame] | 13 | source $WORKSPACE/test/ete/scripts/install_openstack_cli.sh |
| 14 | |
Gary Wu | 11c9874 | 2018-05-02 16:19:04 -0700 | [diff] [blame] | 15 | SO_ENCRYPTION_KEY=aa3871669d893c7fb8abbcda31b88b4f |
| 16 | export OS_PASSWORD_ENCRYPTED=$(echo -n "$OS_PASSWORD" | openssl aes-128-ecb -e -K "$SO_ENCRYPTION_KEY" -nosalt | xxd -c 256 -p) |
| 17 | |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 18 | for n in $(seq 1 5); do |
| 19 | $WORKSPACE/test/ete/scripts/teardown-onap.sh |
| 20 | |
| 21 | cd $WORKSPACE/deployment/heat/onap-oom |
Gary Wu | 374498a | 2018-02-06 17:31:04 -0800 | [diff] [blame] | 22 | envsubst < $ENV_FILE > $ENV_FILE~ |
Gary Wu | d257997 | 2018-05-23 12:36:46 -0700 | [diff] [blame^] | 23 | |
| 24 | if ! openstack stack create -t ./onap-oom.yaml -e $ENV_FILE~ onap-oom; then |
| 25 | break |
| 26 | fi |
| 27 | |
| 28 | while [ "CREATE_IN_PROGRESS" == "$(openstack stack show -c stack_status -f value onap-oom)" ]; do |
| 29 | sleep 20 |
| 30 | done |
| 31 | |
| 32 | STATUS=$(openstack stack show -c stack_status -f value onap-oom) |
| 33 | echo $STATUS |
| 34 | if [ "CREATE_COMPLETE" != "$STATUS" ]; then |
| 35 | break |
| 36 | fi |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 37 | |
Gary Wu | ae7c764 | 2018-04-19 17:22:34 -0700 | [diff] [blame] | 38 | for i in $(seq 1 30); do |
| 39 | sleep 30 |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 40 | RANCHER_IP=$(openstack stack output show onap-oom rancher_vm_ip -c output_value -f value) |
Gary Wu | d257997 | 2018-05-23 12:36:46 -0700 | [diff] [blame^] | 41 | K8S_IP=$(openstack stack output show onap-oom k8s_1_vm_ip -c output_value -f value) |
Gary Wu | 14a6b30 | 2018-05-01 15:59:28 -0700 | [diff] [blame] | 42 | timeout 1 ping -c 1 "$RANCHER_IP" && break |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 43 | done |
| 44 | |
Gary Wu | 14a6b30 | 2018-05-01 15:59:28 -0700 | [diff] [blame] | 45 | timeout 1 ping -c 1 "$RANCHER_IP" && break |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 46 | |
Gary Wu | 14a6b30 | 2018-05-01 15:59:28 -0700 | [diff] [blame] | 47 | echo Error: OpenStack infrastructure issue: unable to reach rancher "$RANCHER_IP" |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 48 | sleep 10 |
| 49 | done |
| 50 | |
Gary Wu | 14a6b30 | 2018-05-01 15:59:28 -0700 | [diff] [blame] | 51 | if ! timeout 1 ping -c 1 "$RANCHER_IP"; then |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 52 | exit 2 |
| 53 | fi |
| 54 | |
Gary Wu | d257997 | 2018-05-23 12:36:46 -0700 | [diff] [blame^] | 55 | ssh -o StrictHostKeychecking=no -i ~/.ssh/onap_key ubuntu@$RANCHER_IP "sed -u '/Cloud-init.*finished/q' <(tail -n+0 -f /var/log/cloud-init-output.log)" |
| 56 | |
Gary Wu | 14a6b30 | 2018-05-01 15:59:28 -0700 | [diff] [blame] | 57 | ssh-keygen -R $RANCHER_IP |
Gary Wu | 5627a69 | 2018-05-08 19:13:59 -0700 | [diff] [blame] | 58 | for n in $(seq 1 6); do |
Gary Wu | d257997 | 2018-05-23 12:36:46 -0700 | [diff] [blame^] | 59 | timeout 15m ssh -i ~/.ssh/onap_key ubuntu@$RANCHER_IP 'sudo su -l root -c "/root/oom/kubernetes/robot/ete-k8s.sh onap health"' |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 60 | RESULT=$? |
| 61 | if [ $RESULT -eq 0 ]; then |
| 62 | break |
| 63 | fi |
| 64 | sleep 15m |
| 65 | done |
Gary Wu | d257997 | 2018-05-23 12:36:46 -0700 | [diff] [blame^] | 66 | ROBOT_POD=$(ssh -i ~/.ssh/onap_key ubuntu@$RANCHER_IP 'sudo su -c "kubectl --namespace onap get pods"' | grep robot | sed 's/ .*//') |
| 67 | if [ "$ROBOT_POD" == "" ]; then |
| 68 | exit 1 |
| 69 | fi |
Gary Wu | 36e42dd | 2018-05-03 07:29:53 -0700 | [diff] [blame] | 70 | |
Gary Wu | d257997 | 2018-05-23 12:36:46 -0700 | [diff] [blame^] | 71 | LOG_DIR=$(echo "kubectl exec -n onap $ROBOT_POD -- ls -1t /share/logs | grep {robot-tag} | head -1" | ssh -i $SSH_KEY ubuntu@$RANCHER_IP sudo su) |
| 72 | if [ "$LOG_DIR" == "" ]; then |
| 73 | exit 1 |
| 74 | fi |
| 75 | |
| 76 | 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 |
| 77 | rsync -e "ssh -i $SSH_KEY" -avtz ubuntu@$RANCHER_IP:/tmp/robot/logs/$LOG_DIR/ $WORKSPACE/archives/ |
| 78 | |
| 79 | echo "Browse Robot results at http://$K8S_IP:30209/logs/$LOG_DIR/" |
| 80 | |
Gary Wu | cbddc2b | 2018-01-22 13:33:21 -0800 | [diff] [blame] | 81 | exit 0 |