#!/bin/bash
INSTALL_DIR=/var/opt/ONAP
#####################################################################
# Start display on 256 if it has not already been started...
# This will stay up and be used for all soak tests
# Tried this once and got an unexpected error so restored the start/kill
# pattern for each test for now.
# Perhaps the error was unrelated to the using the same display for
# all tests. Preserve this just in case....
function start_display_if
{
export DISPLAY=:256
xdpyinfo -display $DISPLAY >/dev/null 2>&1
while [ $? = 1 ]
do
# Start Xvfb
echo -e "Starting Xvfb on display ${DISPLAY} with res ${RES}"
Xvfb ${DISPLAY} -ac -screen 0 ${RES} +extension RANDR &
disown
done
}
#####################################################################
function start_display
{
export DISPLAY=:$(( $TEST_NUMBER % 256 ))
xdpyinfo -display $DISPLAY >/dev/null 2>&1
while [ $? = 0 ]
do
DISPLAY=$(( $RANDOM % 1000 ))
xdpyinfo -display $DISPLAY >/dev/null 2>&1
done
# Start Xvfb
echo -e "Starting Xvfb on display ${DISPLAY} with res ${RES}"
Xvfb ${DISPLAY} -ac -screen 0 ${RES} +extension RANDR &
XVFBPID=$!
disown
echo ${DISPLAY} > /tmp/robotDisplay.$TEST_NUMBER
# Get and save pid of this spawned process to make sure we kill the correct process later
}
#####################################################################
function kill_display
{
xdpyinfo -display $DISPLAY >/dev/null 2>&1
if [ $? = 0 ]; then
kill -9 $XVFBPID >/dev/null 2>&1
fi
rm -rf /tmp/robotDisplay.$TEST_NUMBER
}
#####################################################################
# main
#####################################################################
export ROBOT_TAG=$1
export TEST_NUMBER=$2
if [ "$TEST_NUMBER" = "" ];then
TEST_NUMBER=$$
fi
# Use default if none specified as env var
DEFAULT_LOG_LEVEL="INFO" # Available levels: TRACE, DEBUG, INFO (default), WARN, NONE (no logging)
LOG_LEVEL=${LOG_LEVEL:-$DEFAULT_LOG_LEVEL}
# To mitigate the chromedriver hanging issue
export DBUS_SESSION_BUS_ADDRESS=/dev/null
RES="1280x1024x24"
OUTPUT_FOLDER=/share/logs/${SOAKSUBFOLDER}runEteTag_$TEST_NUMBER
mkdir -p $OUTPUT_FOLDER
INSTALL_DIR="/var/opt/ONAP"
ROBOT_LIBS=./robot/library:./robot/library/ONAPLibrary:./robot/library/heatbridge
VARIABLEFILES="-V /share/config/vm_properties.py -V /share/config/integration_robot_properties.py -V /share/config/integration_preload_parameters.py"
VARIABLES="-v GLOBAL_BUILD_NUMBER:$TEST_NUMBER"
LISTENERS=
start_display
# Execute tests
echo -e "Executing robot test ${ROBOT_TAG} at log level ${LOG_LEVEL}"
cd ${INSTALL_DIR}
python -m robot.run -L ${LOG_LEVEL} -d ${OUTPUT_FOLDER} ${VARIABLEFILES} ${VARIABLES} ${LISTENERS} -P ${ROBOT_LIBS} -i ${ROBOT_TAG} $(pwd) > ${OUTPUT_FOLDER}/robot.out 2>&1
####################################################################
# Stop Xvfb we started earlier
kill_display