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