Matthew Barth | c5dec75 | 2016-11-18 13:14:37 -0600 | [diff] [blame] | 1 | #!/bin/bash -xe |
| 2 | |
| 3 | # This build script is for running the Jenkins unit test builds using docker. |
| 4 | # |
Andrew Geissler | 9f980d7 | 2019-01-03 14:19:43 -0600 | [diff] [blame] | 5 | # This script will build a docker container which will then be used to build |
| 6 | # and test the input UNIT_TEST_PKG. The docker container will be pre-populated |
| 7 | # with the most used OpenBMC repositories (phosphor-dbus-interfaces, sdbusplus, |
| 8 | # phosphor-logging, ...). This allows the use of docker caching |
| 9 | # capabilities so the dependent repositories are only built once per update |
| 10 | # to their corresponding repository. If a BRANCH parameter is input then the |
| 11 | # docker container will be pre-populated with the latest code from that input |
| 12 | # branch. If the branch does not exist in the repository, then master will be |
| 13 | # used. |
| 14 | # |
| 15 | # UNIT_TEST_PKG: Required, repository which has been extracted and is to |
| 16 | # be tested |
| 17 | # WORKSPACE: Required, location of unit test scripts and repository |
| 18 | # code to test |
Andrew Geissler | 9f980d7 | 2019-01-03 14:19:43 -0600 | [diff] [blame] | 19 | # BRANCH: Optional, branch to build from each of the |
| 20 | # openbmc repositories. default is master, which will be |
| 21 | # used if input branch not provided or not found |
Andrew Geissler | 9f980d7 | 2019-01-03 14:19:43 -0600 | [diff] [blame] | 22 | # dbus_sys_config_file: Optional, with the default being |
| 23 | # `/usr/share/dbus-1/system.conf` |
Nan Zhou | 971a697 | 2022-06-14 18:27:53 +0000 | [diff] [blame] | 24 | # TEST_ONLY: Optional, do not run analysis tools |
Lei YU | 7ef9330 | 2019-11-06 13:53:21 +0800 | [diff] [blame] | 25 | # NO_FORMAT_CODE: Optional, do not run format-code.sh |
Brad Bishop | 5d6688c | 2020-08-26 15:44:02 -0400 | [diff] [blame] | 26 | # EXTRA_UNIT_TEST_ARGS: Optional, pass arguments to unit-test.py |
Benjamin Fair | ae58fe7 | 2022-05-17 15:22:24 -0700 | [diff] [blame] | 27 | # INTERACTIVE: Optional, run a bash shell instead of unit-test.py |
Lei YU | b8c7c16 | 2022-07-19 19:40:06 +0800 | [diff] [blame] | 28 | # http_proxy: Optional, run the container with proxy environment |
Matthew Barth | c5dec75 | 2016-11-18 13:14:37 -0600 | [diff] [blame] | 29 | |
| 30 | # Trace bash processing. Set -e so when a step fails, we fail the build |
| 31 | set -uo pipefail |
| 32 | |
| 33 | # Default variables |
Andrew Geissler | a61acb5 | 2019-01-03 16:32:44 -0600 | [diff] [blame] | 34 | BRANCH=${BRANCH:-"master"} |
Matthew Barth | c5dec75 | 2016-11-18 13:14:37 -0600 | [diff] [blame] | 35 | OBMC_BUILD_SCRIPTS="openbmc-build-scripts" |
| 36 | UNIT_TEST_PY_DIR="scripts" |
Manojkiran Eda | 87111bb | 2021-08-14 11:26:16 +0530 | [diff] [blame] | 37 | CONFIG_DIR="config" |
Matthew Barth | c5dec75 | 2016-11-18 13:14:37 -0600 | [diff] [blame] | 38 | UNIT_TEST_PY="unit-test.py" |
Andrew Geissler | a28286d | 2018-01-10 11:00:00 -0800 | [diff] [blame] | 39 | FORMAT_CODE_SH="format-code.sh" |
Manojkiran Eda | e6f120a | 2021-03-20 11:13:43 +0530 | [diff] [blame] | 40 | SPELLINGS_TXT="openbmc-spelling.txt" |
Manojkiran Eda | 87111bb | 2021-08-14 11:26:16 +0530 | [diff] [blame] | 41 | ESLINT_CONFIG="eslint-global-config.json" |
Leonel Gonzalez | 13ca380 | 2017-03-07 14:08:44 -0600 | [diff] [blame] | 42 | DBUS_UNIT_TEST_PY="dbus-unit-test.py" |
William A. Kennington III | 65b37fa | 2019-01-31 15:15:17 -0800 | [diff] [blame] | 43 | TEST_ONLY="${TEST_ONLY:-}" |
Leonel Gonzalez | 13ca380 | 2017-03-07 14:08:44 -0600 | [diff] [blame] | 44 | DBUS_SYS_CONFIG_FILE=${dbus_sys_config_file:-"/usr/share/dbus-1/system.conf"} |
Andrew Jeffery | a153ee3 | 2018-03-09 13:22:04 +1030 | [diff] [blame] | 45 | MAKEFLAGS="${MAKEFLAGS:-""}" |
William A. Kennington III | d70980f | 2018-11-08 15:14:27 -0800 | [diff] [blame] | 46 | DOCKER_WORKDIR="${DOCKER_WORKDIR:-$WORKSPACE}" |
Lei YU | 7ef9330 | 2019-11-06 13:53:21 +0800 | [diff] [blame] | 47 | NO_FORMAT_CODE="${NO_FORMAT_CODE:-}" |
Benjamin Fair | ae58fe7 | 2022-05-17 15:22:24 -0700 | [diff] [blame] | 48 | INTERACTIVE="${INTERACTIVE:-}" |
Lei YU | b8c7c16 | 2022-07-19 19:40:06 +0800 | [diff] [blame] | 49 | http_proxy=${http_proxy:-} |
Matthew Barth | c5dec75 | 2016-11-18 13:14:37 -0600 | [diff] [blame] | 50 | |
| 51 | # Timestamp for job |
| 52 | echo "Unit test build started, $(date)" |
| 53 | |
Matthew Barth | c5dec75 | 2016-11-18 13:14:37 -0600 | [diff] [blame] | 54 | # Check workspace, build scripts, and package to be unit tested exists |
| 55 | if [ ! -d "${WORKSPACE}" ]; then |
| 56 | echo "Workspace(${WORKSPACE}) doesn't exist, exiting..." |
| 57 | exit 1 |
| 58 | fi |
| 59 | if [ ! -d "${WORKSPACE}/${OBMC_BUILD_SCRIPTS}" ]; then |
| 60 | echo "Package(${OBMC_BUILD_SCRIPTS}) not found in ${WORKSPACE}, exiting..." |
| 61 | exit 1 |
| 62 | fi |
Patrick Williams | 384d741 | 2020-11-06 16:15:41 -0600 | [diff] [blame] | 63 | # shellcheck disable=SC2153 # UNIT_TEST_PKG is not misspelled. |
Matthew Barth | c5dec75 | 2016-11-18 13:14:37 -0600 | [diff] [blame] | 64 | if [ ! -d "${WORKSPACE}/${UNIT_TEST_PKG}" ]; then |
| 65 | echo "Package(${UNIT_TEST_PKG}) not found in ${WORKSPACE}, exiting..." |
| 66 | exit 1 |
| 67 | fi |
| 68 | |
| 69 | # Copy unit test script into workspace |
Patrick Williams | 384d741 | 2020-11-06 16:15:41 -0600 | [diff] [blame] | 70 | cp "${WORKSPACE}"/${OBMC_BUILD_SCRIPTS}/${UNIT_TEST_PY_DIR}/${UNIT_TEST_PY} \ |
| 71 | "${WORKSPACE}"/${UNIT_TEST_PY} |
| 72 | chmod a+x "${WORKSPACE}"/${UNIT_TEST_PY} |
Matthew Barth | c5dec75 | 2016-11-18 13:14:37 -0600 | [diff] [blame] | 73 | |
Leonel Gonzalez | 13ca380 | 2017-03-07 14:08:44 -0600 | [diff] [blame] | 74 | # Copy dbus unit test script into workspace |
Patrick Williams | 384d741 | 2020-11-06 16:15:41 -0600 | [diff] [blame] | 75 | cp "${WORKSPACE}"/${OBMC_BUILD_SCRIPTS}/${UNIT_TEST_PY_DIR}/${DBUS_UNIT_TEST_PY} \ |
| 76 | "${WORKSPACE}"/${DBUS_UNIT_TEST_PY} |
| 77 | chmod a+x "${WORKSPACE}"/${DBUS_UNIT_TEST_PY} |
Leonel Gonzalez | 13ca380 | 2017-03-07 14:08:44 -0600 | [diff] [blame] | 78 | |
Andrew Geissler | a28286d | 2018-01-10 11:00:00 -0800 | [diff] [blame] | 79 | # Copy format code script into workspace |
Patrick Williams | 384d741 | 2020-11-06 16:15:41 -0600 | [diff] [blame] | 80 | cp "${WORKSPACE}"/${OBMC_BUILD_SCRIPTS}/${UNIT_TEST_PY_DIR}/${FORMAT_CODE_SH} \ |
| 81 | "${WORKSPACE}"/${FORMAT_CODE_SH} |
| 82 | chmod a+x "${WORKSPACE}"/${FORMAT_CODE_SH} |
Andrew Geissler | a28286d | 2018-01-10 11:00:00 -0800 | [diff] [blame] | 83 | |
Manojkiran Eda | e6f120a | 2021-03-20 11:13:43 +0530 | [diff] [blame] | 84 | # Copy spellings.txt file into workspace |
Patrick Williams | df6170e | 2021-12-21 14:19:50 -0600 | [diff] [blame] | 85 | cp "${WORKSPACE}"/${OBMC_BUILD_SCRIPTS}/${CONFIG_DIR}/${SPELLINGS_TXT} \ |
Manojkiran Eda | e6f120a | 2021-03-20 11:13:43 +0530 | [diff] [blame] | 86 | "${WORKSPACE}"/${SPELLINGS_TXT} |
| 87 | |
Manojkiran Eda | 87111bb | 2021-08-14 11:26:16 +0530 | [diff] [blame] | 88 | # Copy the eslintconfig file into workspce |
| 89 | cp "${WORKSPACE}"/${OBMC_BUILD_SCRIPTS}/${CONFIG_DIR}/${ESLINT_CONFIG} \ |
| 90 | "${WORKSPACE}"/${ESLINT_CONFIG} |
| 91 | |
Matthew Barth | c5dec75 | 2016-11-18 13:14:37 -0600 | [diff] [blame] | 92 | # Configure docker build |
Patrick Williams | 384d741 | 2020-11-06 16:15:41 -0600 | [diff] [blame] | 93 | cd "${WORKSPACE}"/${OBMC_BUILD_SCRIPTS} |
Patrick Williams | 02871c9 | 2021-02-01 20:57:19 -0600 | [diff] [blame] | 94 | echo "Building docker image with build-unit-test-docker" |
Andrew Geissler | a6b93bf | 2019-01-03 10:23:38 -0600 | [diff] [blame] | 95 | # Export input env variables |
Andrew Geissler | a6b93bf | 2019-01-03 10:23:38 -0600 | [diff] [blame] | 96 | export BRANCH |
Patrick Williams | 9b42310 | 2021-03-16 00:07:31 -0500 | [diff] [blame] | 97 | DOCKER_IMG_NAME=$(./scripts/build-unit-test-docker) |
| 98 | export DOCKER_IMG_NAME |
Matthew Barth | c5dec75 | 2016-11-18 13:14:37 -0600 | [diff] [blame] | 99 | |
Brad Bishop | 5d6688c | 2020-08-26 15:44:02 -0400 | [diff] [blame] | 100 | # Allow the user to pass options through to unit-test.py: |
| 101 | # EXTRA_UNIT_TEST_ARGS="-r 100" ... |
| 102 | EXTRA_UNIT_TEST_ARGS="${EXTRA_UNIT_TEST_ARGS:+,${EXTRA_UNIT_TEST_ARGS/ /,}}" |
| 103 | |
Leonel Gonzalez | 13ca380 | 2017-03-07 14:08:44 -0600 | [diff] [blame] | 104 | # Unit test and parameters |
Benjamin Fair | ae58fe7 | 2022-05-17 15:22:24 -0700 | [diff] [blame] | 105 | if [ "${INTERACTIVE}" ]; then |
| 106 | UNIT_TEST="/bin/bash" |
| 107 | else |
| 108 | UNIT_TEST="${DOCKER_WORKDIR}/${UNIT_TEST_PY},-w,${DOCKER_WORKDIR},\ |
Brad Bishop | 5d6688c | 2020-08-26 15:44:02 -0400 | [diff] [blame] | 109 | -p,${UNIT_TEST_PKG},-b,$BRANCH,-v${TEST_ONLY:+,-t}${NO_FORMAT_CODE:+,-n}\ |
| 110 | ${EXTRA_UNIT_TEST_ARGS}" |
Benjamin Fair | ae58fe7 | 2022-05-17 15:22:24 -0700 | [diff] [blame] | 111 | fi |
Leonel Gonzalez | 13ca380 | 2017-03-07 14:08:44 -0600 | [diff] [blame] | 112 | |
Matthew Barth | c5dec75 | 2016-11-18 13:14:37 -0600 | [diff] [blame] | 113 | # Run the docker unit test container with the unit test execution script |
| 114 | echo "Executing docker image" |
Lei YU | b8c7c16 | 2022-07-19 19:40:06 +0800 | [diff] [blame] | 115 | |
| 116 | PROXY_ENV="" |
| 117 | # Set up proxies |
| 118 | if [ -n "${http_proxy}" ]; then |
| 119 | PROXY_ENV=" \ |
| 120 | --env HTTP_PROXY=${http_proxy} \ |
| 121 | --env HTTPS_PROXY=${http_proxy} \ |
| 122 | --env FTP_PROXY=${http_proxy} \ |
| 123 | --env http_proxy=${http_proxy} \ |
| 124 | --env https_proxy=${http_proxy} \ |
| 125 | --env ftp_proxy=${http_proxy}" |
| 126 | fi |
| 127 | |
| 128 | # shellcheck disable=SC2086 # ${PROXY_ENV} is meant to be splitted |
Matthew Barth | c5dec75 | 2016-11-18 13:14:37 -0600 | [diff] [blame] | 129 | docker run --cap-add=sys_admin --rm=true \ |
Leonel Gonzalez | 13ca380 | 2017-03-07 14:08:44 -0600 | [diff] [blame] | 130 | --privileged=true \ |
Lei YU | b8c7c16 | 2022-07-19 19:40:06 +0800 | [diff] [blame] | 131 | ${PROXY_ENV} \ |
William A. Kennington III | be6aab2 | 2018-12-06 15:01:54 -0800 | [diff] [blame] | 132 | -u "$USER" \ |
William A. Kennington III | d70980f | 2018-11-08 15:14:27 -0800 | [diff] [blame] | 133 | -w "${DOCKER_WORKDIR}" -v "${WORKSPACE}":"${DOCKER_WORKDIR}" \ |
Andrew Jeffery | a153ee3 | 2018-03-09 13:22:04 +1030 | [diff] [blame] | 134 | -e "MAKEFLAGS=${MAKEFLAGS}" \ |
Benjamin Fair | ae58fe7 | 2022-05-17 15:22:24 -0700 | [diff] [blame] | 135 | -${INTERACTIVE:+i}t "${DOCKER_IMG_NAME}" \ |
Patrick Williams | 384d741 | 2020-11-06 16:15:41 -0600 | [diff] [blame] | 136 | "${DOCKER_WORKDIR}"/${DBUS_UNIT_TEST_PY} -u "${UNIT_TEST}" \ |
| 137 | -f "${DBUS_SYS_CONFIG_FILE}" |
Matthew Barth | c5dec75 | 2016-11-18 13:14:37 -0600 | [diff] [blame] | 138 | |
| 139 | # Timestamp for build |
| 140 | echo "Unit test build completed, $(date)" |
Zane Shelley | 5ab3e86 | 2019-07-24 13:14:57 -0500 | [diff] [blame] | 141 | |
| 142 | # Clean up copied scripts. |
Patrick Williams | 384d741 | 2020-11-06 16:15:41 -0600 | [diff] [blame] | 143 | rm "${WORKSPACE}"/${UNIT_TEST_PY} |
| 144 | rm "${WORKSPACE}"/${DBUS_UNIT_TEST_PY} |
| 145 | rm "${WORKSPACE}"/${FORMAT_CODE_SH} |
Manojkiran Eda | 87111bb | 2021-08-14 11:26:16 +0530 | [diff] [blame] | 146 | rm "${WORKSPACE}"/${ESLINT_CONFIG} |
Zane Shelley | 5ab3e86 | 2019-07-24 13:14:57 -0500 | [diff] [blame] | 147 | |