blob: ca9aafadf75ee1b5ca82b8e6aca49e0bb0ed7b03 [file] [log] [blame] [edit]
#!/bin/sh
# Copyright (c) 2020 Wind River Systems, Inc.
#
# SPDX-License-Identifier: GPL-2.0-only
#
# buildall-qemu: a tool for automating build testing of recipes
# TODO: Add support for selecting which qemu architectures to build
# TODO: Add support for queueing up multiple recipe builds
# TODO: Add more logging options (e.g. local.conf info, bitbake env info)
usage ()
{
base=$(basename "$0")
echo "Usage: $base [options] [recipename/target]"
echo "Executes a build of a given target for selected LIBCs. With no options, default to both libc and musl."
echo "Options:"
echo "-l, --libc Specify one of \"glibc\" or \"musl\""
}
buildall ()
{
# Get path to oe-core directory. Since oe-init-build-env prepends $PATH with
# the path to the scripts directory, get it from there
SCRIPTS_PATH="$(echo "$PATH" | cut -d ":" -f 1)"
OE_CORE_PATH=$(echo "$SCRIPTS_PATH" | sed 's|\(.*\)/.*|\1|')
# Get target list and host machine information
TARGET_LIST=$(find "$OE_CORE_PATH"/meta/conf/machine -maxdepth 1 -type f | grep qemu | sed 's|.*/||' | sed -e 's/\.conf//')
# Set LIBC value to use for the builds based on options provided by the user
if [ -n "$2" ]
then
LIBC_LIST="$2"
echo "$LIBC_LIST"
else
LIBC_LIST="glibc musl"
echo "$LIBC_LIST"
fi
START_TIME=$(date "+%Y-%m-%d_%H:%M:%S")
LOG_FILE="$1-buildall.log"
OS_INFO=$(grep "PRETTY_NAME=" /etc/os-release | awk -F "=" '{print $2}' | sed -e 's/^"//' -e 's/"$//')
# Append an existing log file for this build with .old if one exists
if [ -f "${LOG_FILE}" ]
then
mv "${LOG_FILE}" "${LOG_FILE}.old"
else
touch "${LOG_FILE}"
fi
# Fill the log file with build and host info
echo "BUILDALL-QEMU LOG FOR $1" >> "${LOG_FILE}"
echo "START TIME: ${START_TIME}" >> "${LOG_FILE}"
echo "HOSTNAME: $(uname -n)" >> "${LOG_FILE}"
echo "HOST OS: ${OS_INFO}" >> "${LOG_FILE}"
echo "HOST KERNEL: $(uname -r)" >> "${LOG_FILE}"
echo "===============" >> "${LOG_FILE}"
echo "BUILD RESULTS:" >> "${LOG_FILE}"
# start the builds for each MACHINE and TCLIBC
for j in ${LIBC_LIST}
do
echo "[$j]" >> "${LOG_FILE}"
for i in ${TARGET_LIST}
do
echo "$i" "$j"; \
TCLIBC=$j MACHINE=$i bitbake "$1" && echo "PASS: $i" >> "${LOG_FILE}" || echo "FAIL: $i" >> "${LOG_FILE}"
done
done
# Get pass/fail totals and add them to the end of the log
PASSED=$(grep "PASS:" "${LOG_FILE}" | wc -l)
FAILED=$(grep "FAIL:" "${LOG_FILE}" | wc -l)
echo "===============" >> "${LOG_FILE}"
echo "PASSED: ${PASSED}" >> "${LOG_FILE}"
echo "FAILED: ${FAILED}" >> "${LOG_FILE}"
}
# fail entire script if any command fails
set -e
# print usage and exit if not enough args given
[ $# -eq 0 ] && usage && exit 1
# handle arguments
RECIPE=
while [ $# -gt 0 ]
do
arg=$1
case $arg in
-l|--libc)
if [ "$2" = "glibc" ] || [ "$2" = "musl" ]
then
LIBC_LIST="$2"
else
echo "Unrecognized libc option."
usage && exit 1
fi
shift
shift
;;
*)
RECIPE="$1"
shift
;;
esac
done
set -- "$RECIPE"
# run buildall for the given recipe and LIBC
if [ -n "$1" ]
then
buildall "$1" "$LIBC_LIST"
fi