#!/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