From 69425942978407247eea2c6f2ee23b3c7cb947af Mon Sep 17 00:00:00 2001 From: Elian Kraja Date: Tue, 17 Sep 2019 17:11:24 +0200 Subject: [PATCH 1/4] Added DockerFile and scripts necessary to validate robot test suites --- .jenkins.sh | 14 +++++++++++ scripts/build-container.sh | 36 ++++++++++++++++++++++++++ scripts/docker/Dockerfile | 49 ++++++++++++++++++++++++++++++++++++ scripts/launch-validation.sh | 0 scripts/run-all.bash | 15 +++++++++-- scripts/run-container.sh | 15 +++++++++++ 6 files changed, 127 insertions(+), 2 deletions(-) create mode 100644 .jenkins.sh create mode 100755 scripts/build-container.sh create mode 100644 scripts/docker/Dockerfile mode change 100644 => 100755 scripts/launch-validation.sh mode change 100644 => 100755 scripts/run-all.bash create mode 100755 scripts/run-container.sh diff --git a/.jenkins.sh b/.jenkins.sh new file mode 100644 index 0000000..51ad691 --- /dev/null +++ b/.jenkins.sh @@ -0,0 +1,14 @@ +#!/bin/bash +# Copyright ETSI 2018 +# See: https://forge.etsi.org/etsi-forge-copyright-statement.txt + +#set -vx +#set -e + +cd "$(dirname "$0")" + +run_dir="$(pwd)" + +./scripts/build-container.sh +./scripts/run-container.sh "${run_dir}" + diff --git a/scripts/build-container.sh b/scripts/build-container.sh new file mode 100755 index 0000000..df57c1f --- /dev/null +++ b/scripts/build-container.sh @@ -0,0 +1,36 @@ +#!/bin/bash +# Copyright ETSI 2019 +# See: https://forge.etsi.org/etsi-forge-copyright-statement.txt + +#set -e +set -vx + +DOCKER_FILE=./scripts/docker/Dockerfile +if [ -f ${DOCKER_FILE} ] +then + #check and build stf569-rf image + DOCKER_ID=`docker ps -a | grep -e stf569-rf | awk '{ print $1 }'` + if [ ! -z "${DOCKER_ID}" ] + then + docker rm --force stf569-rf + fi + docker build --tag stf569-rf --force-rm -f ${DOCKER_FILE} . + if [ "$?" != "0" ] + then + echo "Docker build failed: $?" + exit -1 + fi + docker image ls -a + docker inspect stf569-rf:latest + if [ "$?" != "0" ] + then + echo "Docker inspect failed: $?" + exit -2 + fi +else + exit -3 +fi + +# That's all Floks +exit 0 + diff --git a/scripts/docker/Dockerfile b/scripts/docker/Dockerfile new file mode 100644 index 0000000..d770424 --- /dev/null +++ b/scripts/docker/Dockerfile @@ -0,0 +1,49 @@ +FROM ubuntu:16.04 + +MAINTAINER ETSI STF 569 + +LABEL description="SFT569 Robot Framework Docker Image" + +ENV TERM=xterm +ENV HOSTNAME docker-robot-STF569 + + +ARG ssh_prv_key + + + +RUN DEBIAN_FRONTEND=noninteractive apt update \ + && apt install python3 -y \ + && apt install python3-pip -y \ + && apt install openssh-server -y \ + && DEBIAN_FRONTEND=noninteractive apt-get autoremove --purge -y \ + && DEBIAN_FRONTEND=noninteractive apt-get autoclean \ + && rm -rf /var/lib/apt/lists/* + + +RUN echo "docker-robot-STF569" > /etc/hostname \ + && echo "root:etsi" | chpasswd + +RUN useradd --create-home --shell /bin/bash --user-group etsi --groups sudo \ + && echo "etsi:etsi" | chpasswd \ + && adduser etsi sudo \ + && echo "etsi ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers + + +RUN DEBIAN_FRONTEND=noninteractive \ + && mkdir -p /home/etsi/dev/robot \ + && cd /home/etsi/dev/robot + + +ADD . /home/etsi/dev/robot + +RUN pip3 install robotframework + +RUN DEBIAN_FRONTEND=noninteractive \ + && cd /home/etsi/dev/robot \ + && pip3 install -r requirements.txt \ + && chmod +x /home/etsi/dev/robot/scripts/* + +CMD tail -f /dev/null + + diff --git a/scripts/launch-validation.sh b/scripts/launch-validation.sh old mode 100644 new mode 100755 diff --git a/scripts/run-all.bash b/scripts/run-all.bash old mode 100644 new mode 100755 index 310b9d4..47b81f1 --- a/scripts/run-all.bash +++ b/scripts/run-all.bash @@ -2,7 +2,9 @@ ## Launch robot tests validator -/bin/bash /scripts/launch-validation.sh > logs/robot_stdout.log 2> logs/robot_stderr.log +mkdir logs + +/bin/bash scripts/launch-validation.sh > logs/robot_stdout.log 2> logs/robot_stderr.log ## Filter failed Keywords grep -r10n "| FAIL |" logs/robot_stdout.log | grep -v "Output:" | grep -v "Log:" | grep -v "Report:" > logs/failures.log @@ -18,4 +20,13 @@ ERRORS=`awk 'END{print NR}' logs/errors.log logs/failures.log` if [ "${ERRORS}" -eq 0 ]; then rm -f logs/errors.log rm -f logs/failures.log -fi \ No newline at end of file +fi + + +if [ ! -z logs/errors.log ]; then + cat logs/errors.log +fi + +if [ ! -z logs/failures.log ]; then + cat logs/failures.log +fi diff --git a/scripts/run-container.sh b/scripts/run-container.sh new file mode 100755 index 0000000..7eaaadb --- /dev/null +++ b/scripts/run-container.sh @@ -0,0 +1,15 @@ +#!/bin/bash +# Copyright ETSI 2019 +# See: https://forge.etsi.org/etsi-forge-copyright-statement.txt + +#set -e +#set -vx + +docker run stf569-rf:latest "/bin/bash" \ + -c "cd /home/etsi/dev/robot \ + && sh scripts/run-all.bash \ + && ls -ltr logs/" + +# That's all Floks +exit 0 + -- GitLab From bbe1f0a0f8e5923a7f290e496be1b8b486269d72 Mon Sep 17 00:00:00 2001 From: Elian Kraja Date: Tue, 17 Sep 2019 17:56:26 +0200 Subject: [PATCH 2/4] Adding failure logic to the run-all script --- scripts/run-all.bash | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/scripts/run-all.bash b/scripts/run-all.bash index 47b81f1..d10f025 100755 --- a/scripts/run-all.bash +++ b/scripts/run-all.bash @@ -30,3 +30,8 @@ fi if [ ! -z logs/failures.log ]; then cat logs/failures.log fi + +if [ ! -z logs/erros.log ] && [ ! -z logs.failures.log ]; then + exit 250 +fi + -- GitLab From 98bfa65930a5abc8803a30f011c8831296af36f8 Mon Sep 17 00:00:00 2001 From: Elian Kraja Date: Tue, 17 Sep 2019 18:01:10 +0200 Subject: [PATCH 3/4] Adding failure logic to the run-all script --- scripts/run-all.bash | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/scripts/run-all.bash b/scripts/run-all.bash index d10f025..38edbc4 100755 --- a/scripts/run-all.bash +++ b/scripts/run-all.bash @@ -31,7 +31,8 @@ if [ ! -z logs/failures.log ]; then cat logs/failures.log fi -if [ ! -z logs/erros.log ] && [ ! -z logs.failures.log ]; then - exit 250 +if [ ! -z logs/erros.log ] || [ ! -z logs.failures.log ]; then + echo "Errors are found. Job failed" + exit 1 fi -- GitLab From c6659801e10c9867b7d7cbce2d0b8fc12099770c Mon Sep 17 00:00:00 2001 From: Elian Kraja Date: Tue, 17 Sep 2019 18:15:54 +0200 Subject: [PATCH 4/4] Adding failure logic to the jenkins script --- .jenkins.sh | 1 + scripts/run-container.sh | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/.jenkins.sh b/.jenkins.sh index 51ad691..ea4251e 100644 --- a/.jenkins.sh +++ b/.jenkins.sh @@ -12,3 +12,4 @@ run_dir="$(pwd)" ./scripts/build-container.sh ./scripts/run-container.sh "${run_dir}" +exit $? diff --git a/scripts/run-container.sh b/scripts/run-container.sh index 7eaaadb..72b31e0 100755 --- a/scripts/run-container.sh +++ b/scripts/run-container.sh @@ -11,5 +11,5 @@ docker run stf569-rf:latest "/bin/bash" \ && ls -ltr logs/" # That's all Floks -exit 0 +exit $? -- GitLab