| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175 |
- #!/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
- # Copy app list json files to build path
- mv ${BUILD_PATH}/${IDF_TARGET}/*.json ${BUILD_PATH}
- fi
|