cleanup: rm node_ID from yardstick prepare_env file
[yardstick.git] / tests / ci / prepare_env.sh
1 #!/bin/bash
2 ##############################################################################
3 # Copyright (c) 2015 Ericsson AB, Huawei Technologies Co.,Ltd and others.
4 #
5 # All rights reserved. This program and the accompanying materials
6 # are made available under the terms of the Apache License, Version 2.0
7 # which accompanies this distribution, and is available at
8 # http://www.apache.org/licenses/LICENSE-2.0
9 ##############################################################################
10
11 # Perepare the environment to run yardstick ci
12
13 : ${DEPLOY_TYPE:='bm'} # Can be any of 'bm' (Bare Metal) or 'virt' (Virtual)
14 : ${INSTALLER_TYPE:='unknown'}
15 : ${NODE_NAME:='unknown'}
16 : ${EXTERNAL_NETWORK:='admin_floating_net'}
17 : ${USER_NAME:='ubuntu'}
18 : ${SSH_KEY:='/root/.ssh/id_rsa'}
19
20 # Extract network name from EXTERNAL_NETWORK
21 #  e.g. EXTERNAL_NETWORK='ext-net;flat;192.168.0.2;192.168.0.253;192.168.0.1;192.168.0.0/24'
22 export EXTERNAL_NETWORK=$(echo $EXTERNAL_NETWORK | cut -f1 -d \;)
23
24 # Create openstack credentials
25 echo "INFO: Creating openstack credentials .."
26 mkdir -p /etc/yardstick
27 OPENRC=/etc/yardstick/openstack.creds
28 INSTALLERS=(apex compass fuel joid)
29
30 RC_VAR_EXIST=false
31 if [ "${OS_AUTH_URL}" -a "${OS_USERNAME}" -a "${OS_PASSWORD}" -a "${EXTERNAL_NETWORK}" ];then
32     RC_VAR_EXIST=true
33 fi
34
35 if [ "${RC_VAR_EXIST}" = false ]; then
36     if [ ! -f $OPENRC ];then
37         # credentials file is not given, check if environment variables are set
38         # to get the creds using fetch_os_creds.sh later on
39         echo "INFO: Checking environment variables INSTALLER_TYPE and INSTALLER_IP"
40         if [ -z ${INSTALLER_TYPE} ]; then
41             echo "environment variable 'INSTALLER_TYPE' is not defined."
42             exit 1
43         elif [[ ${INSTALLERS[@]} =~ ${INSTALLER_TYPE} ]]; then
44             echo "INSTALLER_TYPE env variable found: ${INSTALLER_TYPE}"
45         else
46             echo "Invalid env variable INSTALLER_TYPE=${INSTALLER_TYPE}"
47             exit 1
48         fi
49
50         if [ "$DEPLOY_TYPE" == "virt" ]; then
51             FETCH_CRED_ARG="-v -d $OPENRC -i ${INSTALLER_TYPE} -a ${INSTALLER_IP}"
52         else
53             FETCH_CRED_ARG="-d $OPENRC -i ${INSTALLER_TYPE} -a ${INSTALLER_IP}"
54         fi
55
56         $RELENG_REPO_DIR/utils/fetch_os_creds.sh $FETCH_CRED_ARG
57     fi
58     source $OPENRC
59 fi
60
61 export EXTERNAL_NETWORK INSTALLER_TYPE DEPLOY_TYPE NODE_NAME
62
63 # Prepare a admin-rc file for StorPerf integration
64 $YARDSTICK_REPO_DIR/tests/ci/prepare_storperf_admin-rc.sh
65
66 # copy Storperf related files to the deployment location
67 if [ "$INSTALLER_TYPE" == "compass" ]; then
68     source $YARDSTICK_REPO_DIR/tests/ci/scp_storperf_files.sh
69 fi
70
71 # Fetching id_rsa file from jump_server..."
72 verify_connectivity() {
73     local ip=$1
74     echo "Verifying connectivity to $ip..."
75     for i in $(seq 0 10); do
76         if ping -c 1 -W 1 $ip > /dev/null; then
77             echo "$ip is reachable!"
78             return 0
79         fi
80         sleep 1
81     done
82     error "Can not talk to $ip."
83 }
84
85 ssh_options="-o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no"
86
87 if [ "$INSTALLER_TYPE" == "fuel" ]; then
88
89     # check the connection
90     verify_connectivity $INSTALLER_IP
91
92     pod_yaml="$YARDSTICK_REPO_DIR/etc/yardstick/nodes/fuel_baremetal/pod.yaml"
93
94     # update "ip" according to the CI env
95     ssh -l ubuntu ${INSTALLER_IP} -i ${SSH_KEY} ${ssh_options} \
96          "sudo salt -C 'ctl* or cmp*' grains.get fqdn_ip4  --out yaml">node_info
97
98     controller_ips=($(cat node_info|awk '/ctl/{getline; print $2}'))
99     compute_ips=($(cat node_info|awk '/cmp/{getline; print $2}'))
100
101     if [[ ${controller_ips[0]} ]]; then
102         sed -i "s|ip1|${controller_ips[0]}|" $pod_yaml;
103     fi
104     if [[ ${controller_ips[1]} ]]; then
105         sed -i "s|ip2|${controller_ips[1]}|" $pod_yaml;
106     fi
107     if [[ ${controller_ips[2]} ]]; then
108         sed -i "s|ip3|${controller_ips[2]}|" $pod_yaml;
109     fi
110     if [[ ${compute_ips[0]} ]]; then
111         sed -i "s|ip4|${compute_ips[0]}|" $pod_yaml;
112     fi
113     if [[ ${compute_ips[1]} ]]; then
114         sed -i "s|ip5|${compute_ips[1]}|" $pod_yaml;
115     fi
116
117     # update 'user' and 'key_filename' according to the CI env
118     sed -i "s|node_username|${USER_NAME}|;s|node_keyfile|${SSH_KEY}|" $pod_yaml;
119
120 fi