Cperf: Add debug messages to execution
[releng.git] / jjb / cperf / cperf-robot-netvirt-csit.sh
1 #!/usr/bin/env bash
2
3 set -o errexit
4 set -o nounset
5 set -o pipefail
6
7 if [ "$OS_VERSION" == 'master' ]; then
8   FULL_OS_VER='master'
9 else
10   FULL_OS_VER="stable/${OS_VERSION}"
11 fi
12
13 if [ "$ODL_BRANCH" == 'master' ]; then
14   ODL_STREAM='flourine'
15 else
16   ODL_STREAM=${ODL_BRANCH}
17 fi
18
19 echo "ODL Branch set: ${ODL_BRANCH} and OS Version is ${FULL_OS_VER}"
20
21 git clone https://gerrit.opnfv.org/gerrit/releng.git
22 REL_PATH='releng/jjb/cperf'
23
24 # NOTE: sourcing overcloudrc unsets any variable with OS_ prefix
25 source ${WORKSPACE}/overcloudrc
26 # note SDN_CONTROLLER_IP is set in overcloudrc, which is the VIP
27 # for admin/public network (since we are running single network deployment)
28
29 NUM_CONTROL_NODES=$(python ${REL_PATH}/parse-node-yaml.py num_nodes --file $NODE_FILE_PATH)
30 NUM_COMPUTE_NODES=$(python ${REL_PATH}/parse-node-yaml.py num_nodes --node-type compute --file $NODE_FILE_PATH)
31
32 echo "Number of Control nodes found: ${NUM_CONTROL_NODES}"
33 echo "Number of Compute nodes found: ${NUM_COMPUTE_NODES}"
34
35 idx=1
36 EXTRA_ROBOT_ARGS=""
37 for idx in `seq 1 $NUM_CONTROL_NODES`; do
38   CONTROLLER_IP=$(python ${REL_PATH}/parse-node-yaml.py get_value -k address --node-number ${idx} --file $NODE_FILE_PATH)
39   EXTRA_ROBOT_ARGS+=" -v ODL_SYSTEM_${idx}_IP:${CONTROLLER_IP} \
40                       -v OS_CONTROL_NODE_${idx}_IP:${CONTROLLER_IP} \
41                       -v ODL_SYSTEM_${idx}_IP:${CONTROLLER_IP} \
42                       -v HA_PROXY_${idx}_IP:${SDN_CONTROLLER_IP}"
43 done
44
45 idx=1
46 for idx in `seq 1 $NUM_COMPUTE_NODES`; do
47   COMPUTE_IP=$(python ${REL_PATH}/parse-node-yaml.py get_value -k address --node-type compute --node-number ${idx} --file $NODE_FILE_PATH)
48   EXTRA_ROBOT_ARGS+=" -v OS_COMPUTE_${idx}_IP:${COMPUTE_IP}"
49 done
50
51 CONTROLLER_1_IP=$(python ${REL_PATH}/parse-node-yaml.py get_value -k address --node-number 1 --file $NODE_FILE_PATH)
52
53 if [ "$ODL_CONTAINERIZED" == 'false' ]; then
54   EXTRA_ROBOT_ARGS+=" -v NODE_KARAF_COUNT_COMMAND:'ps axf | grep org.apache.karaf | grep -v grep | wc -l || echo 0' \
55                       -v NODE_START_COMMAND:'sudo systemctl start opendaylight_api' \
56                       -v NODE_KILL_COMMAND:'sudo systemctl stop opendaylight_api' \
57                       -v NODE_STOP_COMMAND:'sudo systemctl stop opendaylight_api' \
58                       -v NODE_FREEZE_COMMAND:'sudo systemctl stop opendaylight_api' "
59 else
60   EXTRA_ROBOT_ARGS+=" -v NODE_KARAF_COUNT_COMMAND:\"sudo docker exec opendaylight_api /bin/bash -c 'ps axf | \
61                                 grep org.apache.karaf | grep -v grep | wc -l' || echo 0\" \
62                       -v NODE_START_COMMAND:\"sudo docker start opendaylight_api\" \
63                       -v NODE_KILL_COMMAND:\"sudo docker stop opendaylight_api\" \
64                       -v NODE_STOP_COMMAND:\"sudo docker stop opendaylight_api\" \
65                       -v NODE_FREEZE_COMMAND:\"sudo docker stop opendaylight_api\" "
66 fi
67
68 robot_cmd="pybot \
69   --removekeywords wuks \
70   --xunit robotxunit.xml \
71   -c critical \
72   -e exclude \
73   -d /tmp/robot_results \
74   -v BUNDLEFOLDER:/opt/opendaylight \
75   -v CONTROLLER_USER:heat-admin \
76   -v DEFAULT_LINUX_PROMPT:\$ \
77   -v DEFAULT_LINUX_PROMPT_STRICT:]\$ \
78   -v DEFAULT_USER:heat-admin \
79   -v DEVSTACK_DEPLOY_PATH:/tmp \
80   -v HA_PROXY_IP:$SDN_CONTROLLER_IP \
81   -v NUM_ODL_SYSTEM:$NUM_CONTROL_NODES \
82   -v NUM_OS_SYSTEM:$NUM_CONTROL_NODES \
83   -v NUM_TOOLS_SYSTEM:0 \
84   -v ODL_SNAT_MODE:conntrack \
85   -v ODL_STREAM:$ODL_STREAM \
86   -v ODL_SYSTEM_IP: $CONTROLLER_1_IP \
87   -v OS_CONTROL_NODE_IP:$CONTROLLER_1_IP \
88   -v OPENSTACK_BRANCH:$FULL_OS_VER \
89   -v OS_USER:heat-admin \
90   -v ODL_ENABLE_L3_FWD:yes \
91   -v ODL_SYSTEM_USER:heat-admin \
92   -v ODL_SYSTEM_PROMPT:\$ \
93   -v PRE_CLEAN_OPENSTACK_ALL:True \
94   -v PUBLIC_PHYSICAL_NETWORK:datacentre \
95   -v RESTCONFPORT:8081 \
96   -v ODL_RESTCONF_USER:admin \
97   -v ODL_RESTCONF_PASSWORD:admin \
98   -v KARAF_PROMPT_LOGIN:'opendaylight-user' \
99   -v KARAF_PROMPT:'opendaylight-user.*root.*>' \
100   -v SECURITY_GROUP_MODE:stateful \
101   -v USER:heat-admin \
102   -v USER_HOME:\$HOME \
103   -v TOOLS_SYSTEM_IP:'' \
104   -v NODE_ROLE_INDEX_START:0 \
105   -v WORKSPACE:/tmp  \
106   $EXTRA_ROBOT_ARGS \
107   -v of_port:6653 "
108
109 echo "Robot command set: ${robot_cmd}"
110 echo "Running robot..."
111 docker run -i --net=host \
112   -v ${WORKSPACE}/id_rsa:/tmp/id_rsa \
113   -v ${WORKSPACE}/overcloudrc:/tmp/overcloudrc \
114   opnfv/cperf:$DOCKER_TAG \
115   /bin/bash -c "source /tmp/overcloudrc; mkdir -p \$HOME/.ssh; cp /tmp/id_rsa \$HOME/.ssh; \
116   $robot_cmd /home/opnfv/repos/odl_test/csit/suites/openstack/connectivity/l2.robot;"