Merge changes from topic 'qtip'
[releng.git] / jjb / yardstick / yardstick-daily.sh
1 #!/bin/bash
2 set -e
3 [[ $CI_DEBUG == true ]] && redirect="/dev/stdout" || redirect="/dev/null"
4
5 rc_file_vol=""
6 cacert_file_vol=""
7 sshkey=""
8
9 if [[ ${INSTALLER_TYPE} == 'apex' ]]; then
10     instack_mac=$(sudo virsh domiflist undercloud | grep default | \
11                   grep -Eo "[0-9a-f]+:[0-9a-f]+:[0-9a-f]+:[0-9a-f]+:[0-9a-f]+:[0-9a-f]+")
12     INSTALLER_IP=$(/usr/sbin/arp -e | grep ${instack_mac} | awk {'print $1'})
13     sshkey="-v /root/.ssh/id_rsa:/root/.ssh/id_rsa"
14     if [[ -n $(sudo iptables -L FORWARD |grep "REJECT"|grep "reject-with icmp-port-unreachable") ]]; then
15         #note: this happens only in opnfv-lf-pod1
16         sudo iptables -D FORWARD -o virbr0 -j REJECT --reject-with icmp-port-unreachable
17         sudo iptables -D FORWARD -i virbr0 -j REJECT --reject-with icmp-port-unreachable
18     fi
19 fi
20
21 if [[ "${INSTALLER_TYPE}" == 'fuel' ]]; then
22     sshkey="-v ${SSH_KEY}:/root/.ssh/mcp.rsa"
23 fi
24
25 if [[ ${INSTALLER_TYPE} == 'joid' ]]; then
26     if [[ "${DEPLOY_SCENARIO:0:2}" == "k8" ]];then
27         rc_file_vol="-v /home/ubuntu/config:/etc/yardstick/admin.conf"
28     else
29         # If production lab then creds may be retrieved dynamically
30         # creds are on the jumphost, always in the same folder
31         rc_file_vol="-v $LAB_CONFIG/admin-openrc:/etc/yardstick/openstack.creds"
32         # If dev lab, credentials may not be the default ones, just provide a path to put them into docker
33         # replace the default one by the customized one provided by jenkins config
34     fi
35 elif [[ ${INSTALLER_TYPE} == 'compass' ]]; then
36     cacert_file_vol="-v ${HOME}/os_cacert:/etc/yardstick/os_cacert"
37     echo "export OS_CACERT=/etc/yardstick/os_cacert" >> ${HOME}/opnfv-openrc.sh
38     rc_file_vol="-v ${HOME}/opnfv-openrc.sh:/etc/yardstick/openstack.creds"
39 else
40     rc_file_vol="-v ${HOME}/opnfv-openrc.sh:/etc/yardstick/openstack.creds"
41 fi
42
43 # Set iptables rule to allow forwarding return traffic for container
44 if ! sudo iptables -C FORWARD -j RETURN 2> ${redirect} || ! sudo iptables -L FORWARD | awk 'NR==3' | grep RETURN 2> ${redirect}; then
45     sudo iptables -I FORWARD -j RETURN
46 fi
47
48 opts="--privileged=true --rm"
49 envs="-e INSTALLER_TYPE=${INSTALLER_TYPE} -e INSTALLER_IP=${INSTALLER_IP} \
50     -e NODE_NAME=${NODE_NAME} -e EXTERNAL_NETWORK=${EXTERNAL_NETWORK} \
51     -e YARDSTICK_BRANCH=${BRANCH} -e BRANCH=${BRANCH} \
52     -e DEPLOY_SCENARIO=${DEPLOY_SCENARIO}"
53
54 if [[ "${INSTALLER_TYPE}" == 'fuel' ]]; then
55     envs+=" -e SSH_KEY=/root/.ssh/mcp.rsa"
56 fi
57
58 # Pull the image with correct tag
59 DOCKER_REPO='opnfv/yardstick'
60 if [ "$(uname -m)" = 'aarch64' ]; then
61     DOCKER_REPO="${DOCKER_REPO}_$(uname -m)"
62 fi
63 echo "Yardstick: Pulling image ${DOCKER_REPO}:${DOCKER_TAG}"
64 docker pull ${DOCKER_REPO}:$DOCKER_TAG >$redirect
65
66 # map log directory
67 branch=${BRANCH##*/}
68 dir_result="${HOME}/opnfv/yardstick/results/${branch}"
69 mkdir -p ${dir_result}
70 sudo rm -rf ${dir_result}/*
71 map_log_dir="-v ${dir_result}:/tmp/yardstick"
72
73 # Run docker
74 if [[ ${INSTALLER_TYPE} == "joid" && "${DEPLOY_SCENARIO:0:2}" == "k8" ]];then
75     juju ssh kubernetes-master/0 sudo apt-get install -y docker.io
76     cmd="juju ssh kubernetes-master/0 sudo docker run ${opts} ${envs} ${rc_file_vol} ${cacert_file_vol} ${map_log_dir} ${sshkey} ${DOCKER_REPO}:${DOCKER_TAG} exec_tests.sh ${YARDSTICK_DB_BACKEND} ${YARDSTICK_SCENARIO_SUITE_NAME}"
77 else
78     cmd="sudo docker run ${opts} ${envs} ${rc_file_vol} ${cacert_file_vol} ${map_log_dir} ${sshkey} ${DOCKER_REPO}:${DOCKER_TAG} \
79     exec_tests.sh ${YARDSTICK_DB_BACKEND} ${YARDSTICK_SCENARIO_SUITE_NAME}"
80 fi
81
82 echo "Yardstick: Running docker cmd: ${cmd}"
83 ${cmd}
84
85 echo "Yardstick: done!"