2020-07-21 04:00:05 -04:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
#
|
|
|
|
# Find apps and build apps for example_test, custom_test, and unit_test
|
|
|
|
#
|
|
|
|
# Runs as part of CI process.
|
|
|
|
#
|
|
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
|
|
# Safety settings (see https://gist.github.com/ilg-ul/383869cbb01f61a51c4d).
|
|
|
|
|
|
|
|
if [[ -n ${DEBUG_SHELL} ]]; then
|
|
|
|
set -x # Activate the expand mode if DEBUG is anything but empty.
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -z ${CI_NODE_TOTAL} ]; then
|
|
|
|
CI_NODE_TOTAL=1
|
|
|
|
echo "Assuming CI_NODE_TOTAL=${CI_NODE_TOTAL}"
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -z ${CI_NODE_INDEX} ]; then
|
|
|
|
# Gitlab uses a 1-based index
|
|
|
|
CI_NODE_INDEX=1
|
|
|
|
echo "Assuming CI_NODE_INDEX=${CI_NODE_INDEX}"
|
|
|
|
fi
|
|
|
|
|
|
|
|
set -o errexit # Exit if command failed.
|
|
|
|
set -o pipefail # Exit if pipe failed.
|
|
|
|
set -o nounset # Exit if variable not set.
|
|
|
|
|
|
|
|
export PATH="$IDF_PATH/tools/ci:$IDF_PATH/tools:$PATH"
|
|
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
die() {
|
|
|
|
echo "${1:-"Unknown Error"}" 1>&2
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
|
|
|
[ -d ${BUILD_PATH} ] || mkdir -p ${BUILD_PATH}
|
|
|
|
[ -d ${LOG_PATH} ] || mkdir -p ${LOG_PATH}
|
|
|
|
[ -f ${SIZE_INFO_LOCATION} ] && rm ${SIZE_INFO_LOCATION}
|
|
|
|
|
|
|
|
export REALPATH=realpath
|
|
|
|
if [ "$(uname -s)" = "Darwin" ]; then
|
|
|
|
export REALPATH=grealpath
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Convert LOG_PATH and BUILD_PATH to relative, to make the json file less verbose.
|
|
|
|
BUILD_PATH=$(${REALPATH} --relative-to ${IDF_PATH} ${BUILD_PATH})
|
|
|
|
LOG_PATH=$(${REALPATH} --relative-to ${IDF_PATH} ${LOG_PATH})
|
|
|
|
|
|
|
|
ALL_BUILD_LIST_JSON="${BUILD_PATH}/list.json"
|
|
|
|
JOB_BUILD_LIST_JSON="${BUILD_PATH}/list_job_${CI_NODE_INDEX}.json"
|
|
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
|
|
# common variables, will specify special cases later
|
|
|
|
WORK_DIR="--work-dir ${BUILD_PATH}/@f/@w/@t"
|
|
|
|
BUILD_DIR="build"
|
|
|
|
BUILD_LOG="${LOG_PATH}/@f_@w.txt"
|
|
|
|
CONFIG="--config sdkconfig.ci=default
|
|
|
|
--config sdkconfig.ci.*=
|
|
|
|
--config =default"
|
|
|
|
|
|
|
|
export EXTRA_CFLAGS="${PEDANTIC_CFLAGS}"
|
|
|
|
export EXTRA_CXXFLAGS="${PEDANTIC_CXXFLAGS}"
|
|
|
|
|
|
|
|
# --config rules above explained:
|
|
|
|
# 1. If sdkconfig.ci exists, use it build the example with configuration name "default"
|
|
|
|
# 2. If sdkconfig.ci.* exists, use it to build the "*" configuration
|
|
|
|
# 3. If none of the above exist, build the default configuration under the name "default"
|
|
|
|
# --work-dir and --build-log above uses "placeholders" @x:
|
|
|
|
# - @f: full path to the test with slashes replaced with underscores
|
|
|
|
# - @w: wildcard used as config name
|
|
|
|
# - @t: target name
|
|
|
|
# so the workdir .../@f/@w/@t would expand to e.g. tools_test_apps_system_startup/default/esp32
|
|
|
|
|
|
|
|
# -----------------------------------------------------------------------------
|
|
|
|
# Example tests specific settings
|
|
|
|
if [ "${TEST_TYPE}" = "example_test" ]; then
|
|
|
|
export EXTRA_CFLAGS="${PEDANTIC_CFLAGS:-}"
|
|
|
|
export EXTRA_CXXFLAGS="${PEDANTIC_CXXFLAGS:-}"
|
|
|
|
|
|
|
|
EXTRA_ARGS="--app-list ${SCAN_TEST_JSON}"
|
|
|
|
# -----------------------------------------------------------------------------
|
|
|
|
# Custom tests specific settings
|
|
|
|
elif [ "${TEST_TYPE}" = "custom_test" ]; then
|
|
|
|
EXTRA_ARGS="--app-list ${SCAN_TEST_JSON}"
|
|
|
|
# -----------------------------------------------------------------------------
|
|
|
|
# Unit tests specific settings
|
|
|
|
elif [ "${TEST_TYPE}" = "unit_test" ]; then
|
|
|
|
ALL_BUILD_LIST_JSON="${BUILD_PATH}/${IDF_TARGET}/list.json"
|
|
|
|
JOB_BUILD_LIST_JSON="${BUILD_PATH}/${IDF_TARGET}/list_job_${CI_NODE_INDEX}.json"
|
|
|
|
|
|
|
|
mkdir -p ${BUILD_PATH}/${IDF_TARGET}
|
|
|
|
mkdir -p ${OUTPUT_PATH}/${IDF_TARGET}
|
|
|
|
|
|
|
|
WORK_DIR=""
|
|
|
|
BUILD_DIR="builds/@t/@w"
|
|
|
|
BUILD_LOG="${LOG_PATH}/@w.txt"
|
|
|
|
|
|
|
|
APP_FOLDER="tools/unit-test-app"
|
|
|
|
|
|
|
|
EXTRA_ARGS="
|
|
|
|
-p ${APP_FOLDER}
|
|
|
|
--build-system ${BUILD_SYSTEM}
|
|
|
|
--target ${IDF_TARGET}
|
|
|
|
--recursive
|
|
|
|
"
|
|
|
|
CONFIG="--config configs/*="
|
|
|
|
# -----------------------------------------------------------------------------
|
|
|
|
else
|
|
|
|
die "TEST_TYPE should only be one of {example_test, custom_test, unit_test}"
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "$TEST_TYPE running for target $IDF_TARGET"
|
|
|
|
cd ${IDF_PATH}
|
|
|
|
|
|
|
|
# This part of the script produces the same result for all the build jobs.
|
|
|
|
#
|
|
|
|
# It may be moved to a separate stage (pre-build) later, then the build jobs
|
|
|
|
# will receive ${BUILD_LIST_JSON} file as an artifact.
|
|
|
|
#
|
|
|
|
# If changing the work-dir or build-dir, remember to update the "artifacts" in
|
|
|
|
# gitlab-ci configs, and IDFApp.py.
|
|
|
|
|
|
|
|
${IDF_PATH}/tools/find_apps.py \
|
|
|
|
-vv \
|
|
|
|
--format json \
|
|
|
|
${WORK_DIR} \
|
|
|
|
--build-dir ${BUILD_DIR} \
|
|
|
|
--build-log ${BUILD_LOG} \
|
|
|
|
--output ${ALL_BUILD_LIST_JSON} \
|
|
|
|
${EXTRA_ARGS} \
|
|
|
|
${CONFIG}
|
|
|
|
|
|
|
|
# The part below is where the actual builds happen
|
|
|
|
|
|
|
|
${IDF_PATH}/tools/build_apps.py \
|
|
|
|
-vv \
|
|
|
|
--format json \
|
|
|
|
--keep-going \
|
|
|
|
--parallel-count ${CI_NODE_TOTAL} \
|
|
|
|
--parallel-index ${CI_NODE_INDEX} \
|
|
|
|
--output-build-list ${JOB_BUILD_LIST_JSON} \
|
|
|
|
--size-info ${SIZE_INFO_LOCATION} \
|
|
|
|
${ALL_BUILD_LIST_JSON}
|
|
|
|
|
|
|
|
# Check for build warnings
|
|
|
|
${IDF_PATH}/tools/ci/check_build_warnings.py -vv ${JOB_BUILD_LIST_JSON}
|
|
|
|
|
|
|
|
if [ "${TEST_TYPE}" = "unit_test" ]; then
|
|
|
|
# Copy build artifacts to output directory
|
|
|
|
build_names=$(
|
|
|
|
cd ${BUILD_PATH}/${IDF_TARGET}
|
|
|
|
find . -maxdepth 1 \! -name . -prune -type d | cut -c 3-
|
|
|
|
)
|
|
|
|
for build_name in $build_names; do
|
|
|
|
src=${BUILD_PATH}/${IDF_TARGET}/${build_name}
|
|
|
|
dst=${OUTPUT_PATH}/${IDF_TARGET}/${build_name}
|
|
|
|
echo "Copying artifacts from ${src} to ${dst}"
|
|
|
|
|
|
|
|
rm -rf ${dst}
|
|
|
|
mkdir -p ${dst}
|
|
|
|
cp ${src}/{*.bin,*.elf,*.map,sdkconfig,flasher_args.json} ${dst}/
|
|
|
|
|
|
|
|
mkdir -p ${dst}/bootloader
|
|
|
|
cp ${src}/bootloader/*.bin ${dst}/bootloader/
|
|
|
|
|
|
|
|
mkdir -p ${dst}/partition_table
|
|
|
|
cp ${src}/partition_table/*.bin ${dst}/partition_table/
|
|
|
|
done
|
2020-07-21 04:59:31 -04:00
|
|
|
|
|
|
|
# Copy app list json files to build path
|
|
|
|
mv ${BUILD_PATH}/${IDF_TARGET}/*.json ${BUILD_PATH}
|
2020-07-21 04:00:05 -04:00
|
|
|
fi
|