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 13e080fe8bSNan Zhou# when run with "target=qemuarm". 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 45e080fe8bSNan Zhou# of obmc-phosphor-image. If you don't find the sysroots 46e080fe8bSNan Zhou# folder, run `bitbake build-sysroots`. 4774d2aba9SAlanny Lopez# 48f9dbc8d9SAndrew Geissler# MACHINE = Machine to run test against. The options are "witherspoon", 49f9dbc8d9SAndrew Geissler# "palmetto", "romulus", or undefined (default). Default 50f9dbc8d9SAndrew Geissler# will use the versatilepb model. 51*e4146670SNan Zhou# 52*e4146670SNan Zhou# DEFAULT_IMAGE_LOC = The image location of the target MACHINE. Default to 53*e4146670SNan Zhou# "./tmp/deploy/images/" 54*e4146670SNan Zhou# 5574d2aba9SAlanny Lopez############################################################################### 560205e8daSAndrew Geissler 570205e8daSAndrew Geisslerset -uo pipefail 580205e8daSAndrew Geissler 5974d2aba9SAlanny LopezQEMU_RUN_TIMER=${QEMU_RUN_TIMER:-300} 6027876c51SAndrew GeisslerQEMU_LOGIN_TIMER=${QEMU_LOGIN_TIMER:-180} 611df680a1SAndrew GeisslerWORKSPACE=${WORKSPACE:-${HOME}/${RANDOM}${RANDOM}} 6274d2aba9SAlanny LopezDOCKER_IMG_NAME=${DOCKER_IMG_NAME:-openbmc/ubuntu-robot-qemu} 6374d2aba9SAlanny LopezOBMC_BUILD_DIR=${OBMC_BUILD_DIR:-/tmp/openbmc/build} 6474d2aba9SAlanny LopezUPSTREAM_WORKSPACE=${UPSTREAM_WORKSPACE:-${1}} 6507b4d5b2SAlanny LopezLAUNCH=${LAUNCH:-local} 660c63ce1bSAndrew GeisslerDEFAULT_MACHINE=versatilepb 670c63ce1bSAndrew GeisslerMACHINE=${MACHINE:-${DEFAULT_MACHINE}} 68*e4146670SNan ZhouDEFAULT_IMAGE_LOC=${DEFAULT_IMAGE_LOC:-./tmp/deploy/images/} 690c63ce1bSAndrew Geissler 700c63ce1bSAndrew Geissler# The automated test suite needs a real machine type so 710c63ce1bSAndrew Geissler# if we're using versatilepb for our qemu start parameter 720c63ce1bSAndrew Geissler# then we need to just let our run-robot use the default 73384d741bSPatrick Williamsif [[ "$MACHINE" == "$DEFAULT_MACHINE" ]]; then 740c63ce1bSAndrew Geissler MACHINE_QEMU= 750c63ce1bSAndrew Geisslerelse 760c63ce1bSAndrew Geissler MACHINE_QEMU=${MACHINE} 770c63ce1bSAndrew Geisslerfi 780205e8daSAndrew Geissler 7974d2aba9SAlanny Lopez# Determine the architecture 8074d2aba9SAlanny LopezARCH=$(uname -m) 810205e8daSAndrew Geissler 8274d2aba9SAlanny Lopez# Determine the prefix of the Dockerfile's base image and the QEMU_ARCH variable 8374d2aba9SAlanny Lopezcase ${ARCH} in 8474d2aba9SAlanny Lopez "ppc64le") 850205e8daSAndrew Geissler QEMU_ARCH="ppc64le-linux" 8674d2aba9SAlanny Lopez ;; 8774d2aba9SAlanny Lopez "x86_64") 880205e8daSAndrew Geissler QEMU_ARCH="x86_64-linux" 8974d2aba9SAlanny Lopez ;; 90051b05b7SThang Q. Nguyen "aarch64") 91051b05b7SThang Q. Nguyen QEMU_ARCH="arm64-linux" 92051b05b7SThang Q. Nguyen ;; 9374d2aba9SAlanny Lopez *) 9474d2aba9SAlanny Lopez echo "Unsupported system architecture(${ARCH}) found for docker image" 9574d2aba9SAlanny Lopez exit 1 9674d2aba9SAlanny Lopezesac 970205e8daSAndrew Geissler 987a88f29eSAndrew Geissler# Set the location of the qemu binary relative to UPSTREAM_WORKSPACE 997a88f29eSAndrew GeisslerQEMU_BIN=${QEMU_BIN:-./tmp/sysroots/${QEMU_ARCH}/usr/bin/qemu-system-arm} 1007a88f29eSAndrew Geissler 10174d2aba9SAlanny Lopez# Get the base directory of the openbmc-build-scripts repo so we can return 10274d2aba9SAlanny LopezDIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" 10374d2aba9SAlanny Lopez 10474d2aba9SAlanny Lopez# Create the base Docker image for QEMU and Robot 105384d741bSPatrick Williams# shellcheck source=scripts/build-qemu-robot-docker.sh 1060205e8daSAndrew Geissler. "$DIR/scripts/build-qemu-robot-docker.sh" "$DOCKER_IMG_NAME" 1070205e8daSAndrew Geissler 1080205e8daSAndrew Geissler# Copy the scripts to start and verify QEMU in the workspace 109384d741bSPatrick Williamscp "$DIR"/scripts/boot-qemu* "${UPSTREAM_WORKSPACE}" 1100205e8daSAndrew Geissler 11107b4d5b2SAlanny Lopez################################################################################ 11207b4d5b2SAlanny Lopez 11307b4d5b2SAlanny Lopezif [[ ${LAUNCH} == "local" ]]; then 11474d2aba9SAlanny Lopez 1150205e8daSAndrew Geissler # Start QEMU docker instance 1160205e8daSAndrew Geissler # root in docker required to open up the https/ssh ports 11710a193c9SLeonel Gonzalez obmc_qemu_docker=$(docker run --detach \ 118f2e658bbSLei YU --rm \ 119147776e6SAndrew Geissler --user root \ 120384d741bSPatrick Williams --env HOME="${OBMC_BUILD_DIR}" \ 121384d741bSPatrick Williams --env QEMU_RUN_TIMER="${QEMU_RUN_TIMER}" \ 122384d741bSPatrick Williams --env QEMU_ARCH="${QEMU_ARCH}" \ 123384d741bSPatrick Williams --env QEMU_BIN="${QEMU_BIN}" \ 124384d741bSPatrick Williams --env MACHINE="${MACHINE}" \ 125*e4146670SNan Zhou --env DEFAULT_IMAGE_LOC="${DEFAULT_IMAGE_LOC}" \ 12674d2aba9SAlanny Lopez --workdir "${OBMC_BUILD_DIR}" \ 127a8c839d6SPatrick Williams --volume "${UPSTREAM_WORKSPACE}:${OBMC_BUILD_DIR}:ro" \ 1280205e8daSAndrew Geissler --tty \ 129384d741bSPatrick Williams "${DOCKER_IMG_NAME}" "${OBMC_BUILD_DIR}"/boot-qemu-test.exp) 13074d2aba9SAlanny Lopez 1310205e8daSAndrew Geissler # We can use default ports because we're going to have the 2 1320205e8daSAndrew Geissler # docker instances talk over their private network 1330205e8daSAndrew Geissler DOCKER_SSH_PORT=22 1340205e8daSAndrew Geissler DOCKER_HTTPS_PORT=443 1359d913febSAndrew Geissler 1369d913febSAndrew Geissler # This docker command intermittently asserts a SIGPIPE which 1379d913febSAndrew Geissler # causes the whole script to fail. The IP address comes through 1389d913febSAndrew Geissler # fine on these errors so just ignore the SIGPIPE 1399d913febSAndrew Geissler trap '' PIPE 1409d913febSAndrew Geissler 141384d741bSPatrick Williams DOCKER_QEMU_IP_ADDR="$(docker inspect "$obmc_qemu_docker" | \ 1425b4a0d27SAndrew Geissler grep "IPAddress\":" | tail -n1 | cut -d '"' -f 4)" 1430205e8daSAndrew Geissler 14474d2aba9SAlanny Lopez #Now wait for the OpenBMC QEMU Docker instance to get to standby 14527876c51SAndrew Geissler delay=5 146384d741bSPatrick Williams attempt=$(( QEMU_LOGIN_TIMER / delay )) 1470205e8daSAndrew Geissler while [ $attempt -gt 0 ]; do 148384d741bSPatrick Williams attempt=$(( attempt - 1 )) 1490205e8daSAndrew Geissler echo "Waiting for qemu to get to standby (attempt: $attempt)..." 150384d741bSPatrick Williams result=$(docker logs "$obmc_qemu_docker") 151384d741bSPatrick Williams if grep -q 'OPENBMC-READY' <<< "$result" ; then 1520205e8daSAndrew Geissler echo "QEMU is ready!" 15311a6e9e8SGeorge Keishing # Give QEMU a few secs to stabilize 15427876c51SAndrew Geissler sleep $delay 1550205e8daSAndrew Geissler break 1560205e8daSAndrew Geissler fi 15727876c51SAndrew Geissler sleep $delay 1580205e8daSAndrew Geissler done 1590205e8daSAndrew Geissler 1600205e8daSAndrew Geissler if [ "$attempt" -eq 0 ]; then 1610205e8daSAndrew Geissler echo "Timed out waiting for QEMU, exiting" 1620205e8daSAndrew Geissler exit 1 1630205e8daSAndrew Geissler fi 1640205e8daSAndrew Geissler 16507b4d5b2SAlanny Lopez # Now run the Robot test (Tests commented out until they are working again) 1660205e8daSAndrew Geissler 1670205e8daSAndrew Geissler # Timestamp for job 1680c63ce1bSAndrew Geissler echo "Robot Test started, $(date)" 1690205e8daSAndrew Geissler 170384d741bSPatrick Williams mkdir -p "${WORKSPACE}" 171384d741bSPatrick Williams cd "${WORKSPACE}" 1720205e8daSAndrew Geissler 17374d2aba9SAlanny Lopez # Copy in the script which will execute the Robot tests 174384d741bSPatrick Williams cp "$DIR"/scripts/run-robot.sh "${WORKSPACE}" 1750205e8daSAndrew Geissler 17674d2aba9SAlanny Lopez # Run the Docker container to execute the Robot test cases 1770205e8daSAndrew Geissler # The test results will be put in ${WORKSPACE} 1780c63ce1bSAndrew Geissler docker run --rm \ 179384d741bSPatrick Williams --env HOME="${HOME}" \ 180384d741bSPatrick Williams --env IP_ADDR="${DOCKER_QEMU_IP_ADDR}" \ 181384d741bSPatrick Williams --env SSH_PORT="${DOCKER_SSH_PORT}" \ 182384d741bSPatrick Williams --env HTTPS_PORT="${DOCKER_HTTPS_PORT}" \ 183384d741bSPatrick Williams --env MACHINE="${MACHINE_QEMU}" \ 184384d741bSPatrick Williams --workdir "${HOME}" \ 185384d741bSPatrick Williams --volume "${WORKSPACE}":"${HOME}" \ 1860c63ce1bSAndrew Geissler --tty \ 187384d741bSPatrick Williams "${DOCKER_IMG_NAME}" "${HOME}"/run-robot.sh 1880205e8daSAndrew Geissler 18974d2aba9SAlanny Lopez # Now stop the QEMU Docker image 190384d741bSPatrick Williams docker stop "$obmc_qemu_docker" 19107b4d5b2SAlanny Lopez 19207b4d5b2SAlanny Lopezelse 19307b4d5b2SAlanny Lopez echo "LAUNCH variable invalid, Exiting" 19407b4d5b2SAlanny Lopez exit 1 19507b4d5b2SAlanny Lopezfi 196