10205e8daSAndrew Geissler#!/bin/bash -xe
274d2aba9SAlanny Lopez###############################################################################
30205e8daSAndrew Geissler#
474d2aba9SAlanny Lopez# This script is for starting QEMU against the input build and running the
574d2aba9SAlanny Lopez# robot CI test suite against it.(ROBOT CI TEST CURRENTLY WIP)
674d2aba9SAlanny Lopez#
774d2aba9SAlanny Lopez###############################################################################
874d2aba9SAlanny Lopez#
974d2aba9SAlanny Lopez# Parameters used by the script:
1074d2aba9SAlanny Lopez#  UPSTREAM_WORKSPACE = The directory from which the QEMU components are being
1174d2aba9SAlanny Lopez#                       imported from. Generally, this is the build directory
1274d2aba9SAlanny Lopez#                       that is generated by the OpenBMC build-setup.sh script
1374d2aba9SAlanny Lopez#                       when run with "target=qemu".
1474d2aba9SAlanny Lopez#                       Example: /home/builder/workspace/openbmc-build/build.
1574d2aba9SAlanny Lopez#
1674d2aba9SAlanny Lopez# Optional Variables:
1774d2aba9SAlanny Lopez#
1874d2aba9SAlanny Lopez#  WORKSPACE          = Path of the workspace directory where some intermediate
1974d2aba9SAlanny Lopez#                       files will be saved to.
2074d2aba9SAlanny Lopez#  QEMU_RUN_TIMER     = Defaults to 300, a timer for the QEMU container.
2127876c51SAndrew Geissler#  QEMU_LOGIN_TIMER   = Defaults to 180, a timer for the QEMU container to reach
2227876c51SAndrew Geissler#                       login.
2374d2aba9SAlanny Lopez#  DOCKER_IMG_NAME    = Defaults to openbmc/ubuntu-robot-qemu, the name the
2474d2aba9SAlanny Lopez#                       Docker image will be tagged with when built.
2574d2aba9SAlanny Lopez#  OBMC_BUILD_DIR     = Defaults to /tmp/openbmc/build, the path to the
2674d2aba9SAlanny Lopez#                       directory where the UPSTREAM_WORKSPACE build files will
2774d2aba9SAlanny Lopez#                       be mounted to. Since the build containers have been
2874d2aba9SAlanny Lopez#                       changed to use /tmp as the parent directory for their
2974d2aba9SAlanny Lopez#                       builds, move the mounting location to be the same to
3074d2aba9SAlanny Lopez#                       resolve issues with file links or referrals to exact
3174d2aba9SAlanny Lopez#                       paths in the original build directory. If the build
3274d2aba9SAlanny Lopez#                       directory was changed in the build-setup.sh run, this
3374d2aba9SAlanny Lopez#                       variable should also be changed. Otherwise, the default
3474d2aba9SAlanny Lopez#                       should be used.
3507b4d5b2SAlanny Lopez#  LAUNCH             = Used to determine how to launch the qemu robot test
3607b4d5b2SAlanny Lopez#                       containers. The options are "local", and "k8s". It will
3707b4d5b2SAlanny Lopez#                       default to local which will launch a single container
3807b4d5b2SAlanny Lopez#                       to do the runs. If specified k8s will launch a group of
3907b4d5b2SAlanny Lopez#                       containers into a kubernetes cluster using the helper
4007b4d5b2SAlanny Lopez#                       script.
417a88f29eSAndrew Geissler#  QEMU_BIN           = Location of qemu-system-arm binary to use when starting
427a88f29eSAndrew Geissler#                       QEMU relative to upstream workspace.  Default is
437a88f29eSAndrew Geissler#                       ./tmp/sysroots/${QEMU_ARCH}/usr/bin/qemu-system-arm
447a88f29eSAndrew Geissler#                       which is the default location when doing a bitbake
457a88f29eSAndrew Geissler#                       of obmc-phosphor-image
4674d2aba9SAlanny Lopez#
47f9dbc8d9SAndrew Geissler#  MACHINE            = Machine to run test against. The options are "witherspoon",
48f9dbc8d9SAndrew Geissler#                       "palmetto", "romulus", or undefined (default).  Default
49f9dbc8d9SAndrew Geissler#                       will use the versatilepb model.
5074d2aba9SAlanny Lopez###############################################################################
510205e8daSAndrew Geissler
520205e8daSAndrew Geisslerset -uo pipefail
530205e8daSAndrew Geissler
5474d2aba9SAlanny LopezQEMU_RUN_TIMER=${QEMU_RUN_TIMER:-300}
5527876c51SAndrew GeisslerQEMU_LOGIN_TIMER=${QEMU_LOGIN_TIMER:-180}
561df680a1SAndrew GeisslerWORKSPACE=${WORKSPACE:-${HOME}/${RANDOM}${RANDOM}}
5774d2aba9SAlanny LopezDOCKER_IMG_NAME=${DOCKER_IMG_NAME:-openbmc/ubuntu-robot-qemu}
5874d2aba9SAlanny LopezOBMC_BUILD_DIR=${OBMC_BUILD_DIR:-/tmp/openbmc/build}
5974d2aba9SAlanny LopezUPSTREAM_WORKSPACE=${UPSTREAM_WORKSPACE:-${1}}
6007b4d5b2SAlanny LopezLAUNCH=${LAUNCH:-local}
610c63ce1bSAndrew GeisslerDEFAULT_MACHINE=versatilepb
620c63ce1bSAndrew GeisslerMACHINE=${MACHINE:-${DEFAULT_MACHINE}}
630c63ce1bSAndrew Geissler
640c63ce1bSAndrew Geissler# The automated test suite needs a real machine type so
650c63ce1bSAndrew Geissler# if we're using versatilepb for our qemu start parameter
660c63ce1bSAndrew Geissler# then we need to just let our run-robot use the default
67*384d741bSPatrick Williamsif [[ "$MACHINE" == "$DEFAULT_MACHINE" ]]; then
680c63ce1bSAndrew Geissler    MACHINE_QEMU=
690c63ce1bSAndrew Geisslerelse
700c63ce1bSAndrew Geissler    MACHINE_QEMU=${MACHINE}
710c63ce1bSAndrew Geisslerfi
720205e8daSAndrew Geissler
7374d2aba9SAlanny Lopez# Determine the architecture
7474d2aba9SAlanny LopezARCH=$(uname -m)
750205e8daSAndrew Geissler
7674d2aba9SAlanny Lopez# Determine the prefix of the Dockerfile's base image and the QEMU_ARCH variable
7774d2aba9SAlanny Lopezcase ${ARCH} in
7874d2aba9SAlanny Lopez  "ppc64le")
790205e8daSAndrew Geissler    QEMU_ARCH="ppc64le-linux"
8074d2aba9SAlanny Lopez    ;;
8174d2aba9SAlanny Lopez  "x86_64")
820205e8daSAndrew Geissler    QEMU_ARCH="x86_64-linux"
8374d2aba9SAlanny Lopez    ;;
8474d2aba9SAlanny Lopez  *)
8574d2aba9SAlanny Lopez    echo "Unsupported system architecture(${ARCH}) found for docker image"
8674d2aba9SAlanny Lopez    exit 1
8774d2aba9SAlanny Lopezesac
880205e8daSAndrew Geissler
897a88f29eSAndrew Geissler# Set the location of the qemu binary relative to UPSTREAM_WORKSPACE
907a88f29eSAndrew GeisslerQEMU_BIN=${QEMU_BIN:-./tmp/sysroots/${QEMU_ARCH}/usr/bin/qemu-system-arm}
917a88f29eSAndrew Geissler
9274d2aba9SAlanny Lopez# Get the base directory of the openbmc-build-scripts repo so we can return
9374d2aba9SAlanny LopezDIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
9474d2aba9SAlanny Lopez
9574d2aba9SAlanny Lopez# Create the base Docker image for QEMU and Robot
96*384d741bSPatrick Williams# shellcheck source=scripts/build-qemu-robot-docker.sh
970205e8daSAndrew Geissler. "$DIR/scripts/build-qemu-robot-docker.sh" "$DOCKER_IMG_NAME"
980205e8daSAndrew Geissler
990205e8daSAndrew Geissler# Copy the scripts to start and verify QEMU in the workspace
100*384d741bSPatrick Williamscp "$DIR"/scripts/boot-qemu* "${UPSTREAM_WORKSPACE}"
1010205e8daSAndrew Geissler
10207b4d5b2SAlanny Lopez################################################################################
10307b4d5b2SAlanny Lopez
10407b4d5b2SAlanny Lopezif [[ ${LAUNCH} == "local" ]]; then
10574d2aba9SAlanny Lopez
1060205e8daSAndrew Geissler  # Start QEMU docker instance
1070205e8daSAndrew Geissler  # root in docker required to open up the https/ssh ports
10810a193c9SLeonel Gonzalez  obmc_qemu_docker=$(docker run --detach \
109f2e658bbSLei YU                                --rm \
1100205e8daSAndrew Geissler                                --user root \
111*384d741bSPatrick Williams                                --env HOME="${OBMC_BUILD_DIR}" \
112*384d741bSPatrick Williams                                --env QEMU_RUN_TIMER="${QEMU_RUN_TIMER}" \
113*384d741bSPatrick Williams                                --env QEMU_ARCH="${QEMU_ARCH}" \
114*384d741bSPatrick Williams                                --env QEMU_BIN="${QEMU_BIN}" \
115*384d741bSPatrick Williams                                --env MACHINE="${MACHINE}" \
11674d2aba9SAlanny Lopez                                --workdir "${OBMC_BUILD_DIR}"           \
11774d2aba9SAlanny Lopez                                --volume "${UPSTREAM_WORKSPACE}":"${OBMC_BUILD_DIR}" \
1180205e8daSAndrew Geissler                                --tty \
119*384d741bSPatrick Williams                                "${DOCKER_IMG_NAME}" "${OBMC_BUILD_DIR}"/boot-qemu-test.exp)
12074d2aba9SAlanny Lopez
1210205e8daSAndrew Geissler  # We can use default ports because we're going to have the 2
1220205e8daSAndrew Geissler  # docker instances talk over their private network
1230205e8daSAndrew Geissler  DOCKER_SSH_PORT=22
1240205e8daSAndrew Geissler  DOCKER_HTTPS_PORT=443
1259d913febSAndrew Geissler
1269d913febSAndrew Geissler  # This docker command intermittently asserts a SIGPIPE which
1279d913febSAndrew Geissler  # causes the whole script to fail. The IP address comes through
1289d913febSAndrew Geissler  # fine on these errors so just ignore the SIGPIPE
1299d913febSAndrew Geissler  trap '' PIPE
1309d913febSAndrew Geissler
131*384d741bSPatrick Williams  DOCKER_QEMU_IP_ADDR="$(docker inspect "$obmc_qemu_docker" |  \
1325b4a0d27SAndrew Geissler                       grep "IPAddress\":" | tail -n1 | cut -d '"' -f 4)"
1330205e8daSAndrew Geissler
13474d2aba9SAlanny Lopez  #Now wait for the OpenBMC QEMU Docker instance to get to standby
13527876c51SAndrew Geissler  delay=5
136*384d741bSPatrick Williams  attempt=$(( QEMU_LOGIN_TIMER / delay ))
1370205e8daSAndrew Geissler  while [ $attempt -gt 0 ]; do
138*384d741bSPatrick Williams    attempt=$(( attempt - 1 ))
1390205e8daSAndrew Geissler    echo "Waiting for qemu to get to standby (attempt: $attempt)..."
140*384d741bSPatrick Williams    result=$(docker logs "$obmc_qemu_docker")
141*384d741bSPatrick Williams    if grep -q 'OPENBMC-READY' <<< "$result" ; then
1420205e8daSAndrew Geissler      echo "QEMU is ready!"
14311a6e9e8SGeorge Keishing      # Give QEMU a few secs to stabilize
14427876c51SAndrew Geissler      sleep $delay
1450205e8daSAndrew Geissler      break
1460205e8daSAndrew Geissler    fi
14727876c51SAndrew Geissler      sleep $delay
1480205e8daSAndrew Geissler  done
1490205e8daSAndrew Geissler
1500205e8daSAndrew Geissler  if [ "$attempt" -eq 0 ]; then
1510205e8daSAndrew Geissler    echo "Timed out waiting for QEMU, exiting"
1520205e8daSAndrew Geissler    exit 1
1530205e8daSAndrew Geissler  fi
1540205e8daSAndrew Geissler
15507b4d5b2SAlanny Lopez  # Now run the Robot test (Tests commented out until they are working again)
1560205e8daSAndrew Geissler
1570205e8daSAndrew Geissler  # Timestamp for job
1580c63ce1bSAndrew Geissler  echo "Robot Test started, $(date)"
1590205e8daSAndrew Geissler
160*384d741bSPatrick Williams  mkdir -p "${WORKSPACE}"
161*384d741bSPatrick Williams  cd "${WORKSPACE}"
1620205e8daSAndrew Geissler
16374d2aba9SAlanny Lopez  # Copy in the script which will execute the Robot tests
164*384d741bSPatrick Williams  cp "$DIR"/scripts/run-robot.sh "${WORKSPACE}"
1650205e8daSAndrew Geissler
16674d2aba9SAlanny Lopez  # Run the Docker container to execute the Robot test cases
1670205e8daSAndrew Geissler  # The test results will be put in ${WORKSPACE}
1680c63ce1bSAndrew Geissler  docker run --rm \
1690c63ce1bSAndrew Geissler             --user root \
170*384d741bSPatrick Williams             --env HOME="${HOME}" \
171*384d741bSPatrick Williams             --env IP_ADDR="${DOCKER_QEMU_IP_ADDR}" \
172*384d741bSPatrick Williams             --env SSH_PORT="${DOCKER_SSH_PORT}" \
173*384d741bSPatrick Williams             --env HTTPS_PORT="${DOCKER_HTTPS_PORT}" \
174*384d741bSPatrick Williams             --env MACHINE="${MACHINE_QEMU}" \
175*384d741bSPatrick Williams             --workdir "${HOME}" \
176*384d741bSPatrick Williams             --volume "${WORKSPACE}":"${HOME}" \
1770c63ce1bSAndrew Geissler             --tty \
178*384d741bSPatrick Williams             "${DOCKER_IMG_NAME}" "${HOME}"/run-robot.sh
1790205e8daSAndrew Geissler
18074d2aba9SAlanny Lopez  # Now stop the QEMU Docker image
181*384d741bSPatrick Williams  docker stop "$obmc_qemu_docker"
18207b4d5b2SAlanny Lopez
18307b4d5b2SAlanny Lopezelif [[ ${LAUNCH} == "k8s" ]]; then
18407b4d5b2SAlanny Lopez  # Package the Upstream into an image based off the one created by the build-qemu-robot.sh
18507b4d5b2SAlanny Lopez  # Dockerfile = $( cat << EOF
186*384d741bSPatrick Williams  # shellcheck disable=SC2034
187*384d741bSPatrick Williams  imgname="$DOCKER_IMG_NAME"
188*384d741bSPatrick Williams  cd "$DIR"
18907b4d5b2SAlanny Lopez  source ./kubernetes/kubernetes-launch.sh QEMU-launch false false deployment
19007b4d5b2SAlanny Lopez
19107b4d5b2SAlanny Lopez  # Xcat Launch (NYI)
19207b4d5b2SAlanny Lopez
19307b4d5b2SAlanny Lopez  # source ./kubernetes/kubernetes-launch.sh XCAT-launch true true
19407b4d5b2SAlanny Lopez
19507b4d5b2SAlanny Lopezelse
19607b4d5b2SAlanny Lopez  echo "LAUNCH variable invalid, Exiting"
19707b4d5b2SAlanny Lopez  exit 1
19807b4d5b2SAlanny Lopezfi
199