blob: c3d67d9e5b74b7ce71b0814e73afb52b8e17c126 [file] [log] [blame]
#!/bin/bash -x
#
# Copyright 2016-2017 Huawei Technologies Co., Ltd.
# Modification Copyright 2019 © Samsung Electronics Co., Ltd.
# Modification Copyright 2021 © AT&T Intellectual Property.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# $1 functionality
# $2 robot options
#
# functions
#
function on_exit(){
rc=$?
if [[ ${WORKSPACE} ]]; then
if [[ ${WORKDIR} ]]; then
rsync -av "$WORKDIR/" "$WORKSPACE/csit/archives/$TESTPLAN"
fi
# Record list of active docker containers
docker ps --format "{{.Image}}" > "$WORKSPACE/csit/archives/$TESTPLAN/_docker-images.log"
# show memory consumption after all docker instances initialized
docker_stats | tee "$WORKSPACE/csit/archives/$TESTPLAN/_sysinfo-2-after-robot.txt"
fi
# Run teardown script plan if it exists
cd "${TESTPLANDIR}/csit/plans/"
TEARDOWN="${TESTPLANDIR}/csit/plans/teardown.sh"
if [ -f "${TEARDOWN}" ]; then
echo "Running teardown script ${TEARDOWN}"
source_safely "${TEARDOWN}"
fi
# TODO: do something with the output
exit $rc
}
# ensure that teardown and other finalizing steps are always executed
trap on_exit EXIT
function docker_stats(){
#General memory details
echo "> top -bn1 | head -3"
top -bn1 | head -3
echo
echo "> free -h"
free -h
echo
#Memory details per Docker
echo "> docker ps"
docker ps
echo
echo "> docker stats --no-stream"
docker stats --no-stream
echo
}
# save current set options
function save_set() {
RUN_CSIT_SAVE_SET="$-"
RUN_CSIT_SHELLOPTS="$SHELLOPTS"
}
# load the saved set options
function load_set() {
_setopts="$-"
# bash shellopts
for i in $(echo "$SHELLOPTS" | tr ':' ' ') ; do
set +o ${i}
done
for i in $(echo "$RUN_CSIT_SHELLOPTS" | tr ':' ' ') ; do
set -o ${i}
done
# other options
for i in $(echo "$_setopts" | sed 's/./& /g') ; do
set +${i}
done
set -${RUN_CSIT_SAVE_SET}
}
# set options for quick bailout when error
function harden_set() {
set -xeo pipefail
set +u # enabled it would probably fail too many often
}
# relax set options so the sourced file will not fail
# the responsibility is shifted to the sourced file...
function relax_set() {
set +e
set +o pipefail
}
# wrapper for sourcing a file
function source_safely() {
[ -z "$1" ] && return 1
relax_set
. "$1"
load_set
}
#
# main
#
# set and save options for quick failure
harden_set && save_set
if [ $# -eq 0 ]
then
echo
echo "Usage: $0 <project> [<robot-options>]"
echo
echo " <project> <robot-options>: "
echo
exit 1
fi
if [ -z "$WORKSPACE" ]; then
export WORKSPACE=$(git rev-parse --show-toplevel)
fi
# Add csit scripts to PATH
export PATH="${PATH}:${WORKSPACE}/csit:${WORKSPACE}/scripts:${ROBOT_VENV}/bin"
export SCRIPTS="${WORKSPACE}/csit"
export ROBOT_VARIABLES=
# get the plan from git clone
source ${SCRIPTS}/get-branch-mariadb.sh
export PROJECT="${1}"
rm -rf ${WORKSPACE}/${PROJECT}
mkdir ${WORKSPACE}/${PROJECT}
cd ${WORKSPACE}
# get the plan from git clone
if ! `git clone -b ${GERRIT_BRANCH} --single-branch git://gerrit-mirror-ap.onap.org/mirror/policy/${PROJECT}.git` ; then
echo "repo not found: policy/${PROJECT}"
exit 1
fi
if [ -f "${WORKSPACE}/${1}/csit/plans/testplan.txt" ]; then
export TESTPLAN="${1}"
else
echo "testplan not found: ${WORKSPACE}/${1}/csit/plans/testplan.txt"
exit 2
fi
export TESTOPTIONS="${2}"
rm -rf "$WORKSPACE/csit/archives/$TESTPLAN"
mkdir -p "$WORKSPACE/csit/archives/$TESTPLAN"
TESTPLANDIR="${WORKSPACE}/${TESTPLAN}"
# Run installation of prerequired libraries
source_safely "${SCRIPTS}/prepare-csit.sh"
# Activate the virtualenv containing all the required libraries installed by prepare-csit.sh
source_safely "${ROBOT_VENV}/bin/activate"
WORKDIR=$(mktemp -d --suffix=-robot-workdir)
cd "${WORKDIR}"
# Sign in to nexus3 docker repo
docker login -u docker -p docker nexus3.onap.org:10001
# Generate keystore to be used by repos
${SCRIPTS}/gen_keystore.sh
cp ${SCRIPTS}/config/ks.jks ${SCRIPTS}/config/drools/custom/policy-keystore
cp ${SCRIPTS}/config/ks.jks ${SCRIPTS}/config/drools-apps/custom/policy-keystore
# Run setup script plan if it exists
cd "${TESTPLANDIR}/csit/plans/"
SETUP="${TESTPLANDIR}/csit/plans/setup.sh"
if [ -f "${SETUP}" ]; then
echo "Running setup script ${SETUP}"
source_safely "${SETUP}"
fi
# show memory consumption after all docker instances initialized
docker_stats | tee "$WORKSPACE/csit/archives/$TESTPLAN/_sysinfo-1-after-setup.txt"
# Run test plan
cd "$WORKDIR"
echo "Reading the testplan:"
cat "${TESTPLANDIR}/csit/plans/testplan.txt" | egrep -v '(^[[:space:]]*#|^[[:space:]]*$)' | sed "s|^|${TESTPLANDIR}/csit/tests/|" > testplan.txt
cat testplan.txt
SUITES=$( xargs -a testplan.txt )
echo ROBOT_VARIABLES="${ROBOT_VARIABLES}"
echo "Starting Robot test suites ${SUITES} ..."
relax_set
python -m robot.run -N ${TESTPLAN} -v WORKSPACE:/tmp ${ROBOT_VARIABLES} ${SUITES}
RESULT=$?
load_set
echo "RESULT: $RESULT"
# Note that the final steps are done in on_exit function after this exit!
exit $RESULT