blob: f148739550aed1d70fd7081bad328671d1e84c04 [file] [log] [blame]
Tom Rinid2244b92019-06-19 09:25:17 -04001# SPDX-License-Identifier: GPL-2.0+
2
3# Grab our configured image. The source for this is found at:
4# https://gitlab.denx.de/u-boot/gitlab-ci-runner
Tom Rini3c396bc2020-04-10 15:53:01 -04005image: trini/u-boot-gitlab-ci-runner:bionic-20200311-10Apr2020
Tom Rinid2244b92019-06-19 09:25:17 -04006
7# We run some tests in different order, to catch some failures quicker.
8stages:
Tom Rinid2244b92019-06-19 09:25:17 -04009 - testsuites
Tom Rini1cdb1822019-07-24 13:09:31 -040010 - test.py
Tom Rinid2244b92019-06-19 09:25:17 -040011 - world build
12
13.buildman_and_testpy_template: &buildman_and_testpy_dfn
14 tags: [ 'all' ]
15 stage: test.py
16 before_script:
17 # Clone uboot-test-hooks
18 - git clone --depth=1 git://github.com/swarren/uboot-test-hooks.git /tmp/uboot-test-hooks
19 - ln -s travis-ci /tmp/uboot-test-hooks/bin/`hostname`
20 - ln -s travis-ci /tmp/uboot-test-hooks/py/`hostname`
Tom Rini6ad26042019-10-04 12:12:54 -040021 - grub-mkimage --prefix="" -o ~/grub_x86.efi -O i386-efi normal echo lsefimmap lsefi lsefisystab efinet tftp minicmd
22 - grub-mkimage --prefix="" -o ~/grub_x64.efi -O x86_64-efi normal echo lsefimmap lsefi lsefisystab efinet tftp minicmd
Heinrich Schuchardt159b0ab2019-12-19 13:30:32 +010023 - cp /opt/grub/grubriscv64.efi ~/grub_riscv64.efi
Bin Mengaeb3ea42020-03-28 07:25:27 -070024 - cp /opt/grub/grubriscv32.efi ~/grub_riscv32.efi
Heinrich Schuchardt159b0ab2019-12-19 13:30:32 +010025 - cp /opt/grub/grubaa64.efi ~/grub_arm64.efi
26 - cp /opt/grub/grubarm.efi ~/grub_arm.efi
Bin Mengb68d9d62020-03-28 07:25:29 -070027 - if [[ "${TEST_PY_BD}" == "qemu-riscv32_spl" ]]; then
28 wget -O - https://github.com/riscv/opensbi/releases/download/v0.6/opensbi-0.6-rv32-bin.tar.xz | tar -C /tmp -xJ;
29 export OPENSBI=/tmp/opensbi-0.6-rv32-bin/platform/qemu/virt/firmware/fw_dynamic.bin;
30 fi
31 - if [[ "${TEST_PY_BD}" == "qemu-riscv64_spl" ]]; then
32 wget -O - https://github.com/riscv/opensbi/releases/download/v0.6/opensbi-0.6-rv64-bin.tar.xz | tar -C /tmp -xJ;
33 export OPENSBI=/tmp/opensbi-0.6-rv64-bin/platform/qemu/virt/firmware/fw_dynamic.bin;
34 fi
Tom Rini1cdb1822019-07-24 13:09:31 -040035
Tom Rinid2244b92019-06-19 09:25:17 -040036 after_script:
Heinrich Schuchardt159b0ab2019-12-19 13:30:32 +010037 - rm -rf /tmp/uboot-test-hooks /tmp/venv
Tom Rinid2244b92019-06-19 09:25:17 -040038 script:
39 # From buildman, exit code 129 means warnings only. If we've been asked to
40 # use clang only do one configuration.
Simon Glass41e8fbe2020-03-18 09:42:52 -060041 - if [[ "${TEST_PY_BD}" != "" ]]; then
Tom Rinid2244b92019-06-19 09:25:17 -040042 ret=0;
Simon Glass41e8fbe2020-03-18 09:42:52 -060043 tools/buildman/buildman -o /tmp -P -E --board ${TEST_PY_BD} ${OVERRIDE}
Simon Glassb49bfe72020-03-18 09:42:51 -060044 || ret=$?;
Tom Rinid2244b92019-06-19 09:25:17 -040045 if [[ $ret -ne 0 && $ret -ne 129 ]]; then
Simon Glassad8eaed2020-03-18 09:42:53 -060046 tools/buildman/buildman -o /tmp -seP --board ${TEST_PY_BD};
Tom Rinid2244b92019-06-19 09:25:17 -040047 exit $ret;
48 fi;
49 fi
50 # "not a_test_which_does_not_exist" is a dummy -k parameter which will
51 # never prevent any test from running. That way, we can always pass
52 # "-k something" even when $TEST_PY_TEST_SPEC doesnt need a custom
53 # value.
Tom Riniebcd2142019-10-24 11:59:27 -040054 - virtualenv -p /usr/bin/python3 /tmp/venv
55 - . /tmp/venv/bin/activate
56 - pip install -r test/py/requirements.txt
Tom Rini254b98e2019-10-04 12:12:53 -040057 - export UBOOT_TRAVIS_BUILD_DIR=/tmp/.bm-work/${TEST_PY_BD};
Tom Rini3fcb3f52019-10-24 11:59:17 -040058 export PATH=/opt/qemu/bin:/tmp/uboot-test-hooks/bin:${PATH};
Tom Rinid2244b92019-06-19 09:25:17 -040059 export PYTHONPATH=/tmp/uboot-test-hooks/py/travis-ci;
60 if [[ "${TEST_PY_BD}" != "" ]]; then
61 ./test/py/test.py --bd ${TEST_PY_BD} ${TEST_PY_ID}
62 -k "${TEST_PY_TEST_SPEC:-not a_test_which_does_not_exist}"
63 --build-dir "$UBOOT_TRAVIS_BUILD_DIR";
64 ret=$?;
65 if [[ $ret -ne 0 ]]; then
66 exit $ret;
67 fi;
68 fi;
69
Heinrich Schuchardt8e8e1cc2019-10-06 12:26:16 +020070build all 32bit ARM platforms:
Tom Rinid2244b92019-06-19 09:25:17 -040071 tags: [ 'all' ]
72 stage: world build
73 script:
74 - ret=0;
Tom Rini70c63a52019-10-24 11:59:16 -040075 ./tools/buildman/buildman -o /tmp -P -E arm -x aarch64 || ret=$?;
76 if [[ $ret -ne 0 && $ret -ne 129 ]]; then
Simon Glassad8eaed2020-03-18 09:42:53 -060077 ./tools/buildman/buildman -o /tmp -seP;
Tom Rini70c63a52019-10-24 11:59:16 -040078 exit $ret;
79 fi;
Tom Rini372c6972019-07-17 17:51:28 -040080
Heinrich Schuchardt8e8e1cc2019-10-06 12:26:16 +020081build all 64bit ARM platforms:
Tom Rini372c6972019-07-17 17:51:28 -040082 tags: [ 'all' ]
83 stage: world build
84 script:
Tom Rini6c883102020-02-11 12:41:14 -050085 - virtualenv -p /usr/bin/python3 /tmp/venv
Tom Rini7faea832019-07-18 07:28:36 -040086 - . /tmp/venv/bin/activate
87 - pip install pyelftools
Tom Rini372c6972019-07-17 17:51:28 -040088 - ret=0;
Tom Rini70c63a52019-10-24 11:59:16 -040089 ./tools/buildman/buildman -o /tmp -P -E aarch64 || ret=$?;
90 if [[ $ret -ne 0 && $ret -ne 129 ]]; then
Simon Glassad8eaed2020-03-18 09:42:53 -060091 ./tools/buildman/buildman -o /tmp -seP;
Tom Rini70c63a52019-10-24 11:59:16 -040092 exit $ret;
93 fi;
Tom Rini372c6972019-07-17 17:51:28 -040094
Heinrich Schuchardt8e8e1cc2019-10-06 12:26:16 +020095build all PowerPC platforms:
Tom Rini372c6972019-07-17 17:51:28 -040096 tags: [ 'all' ]
97 stage: world build
98 script:
99 - ret=0;
Tom Rini70c63a52019-10-24 11:59:16 -0400100 ./tools/buildman/buildman -o /tmp -P -E powerpc || ret=$?;
101 if [[ $ret -ne 0 && $ret -ne 129 ]]; then
Simon Glassad8eaed2020-03-18 09:42:53 -0600102 ./tools/buildman/buildman -o /tmp -seP;
Tom Rini70c63a52019-10-24 11:59:16 -0400103 exit $ret;
104 fi;
Tom Rini372c6972019-07-17 17:51:28 -0400105
Heinrich Schuchardt8e8e1cc2019-10-06 12:26:16 +0200106build all other platforms:
Tom Rini372c6972019-07-17 17:51:28 -0400107 tags: [ 'all' ]
108 stage: world build
109 script:
110 - ret=0;
Tom Rini70c63a52019-10-24 11:59:16 -0400111 ./tools/buildman/buildman -o /tmp -P -E -x arm,powerpc || ret=$?;
112 if [[ $ret -ne 0 && $ret -ne 129 ]]; then
Simon Glassad8eaed2020-03-18 09:42:53 -0600113 ./tools/buildman/buildman -o /tmp -seP;
Tom Rini70c63a52019-10-24 11:59:16 -0400114 exit $ret;
115 fi;
Tom Rinid2244b92019-06-19 09:25:17 -0400116
117# QA jobs for code analytics
118# static code analysis with cppcheck (we can add --enable=all later)
119cppcheck:
120 tags: [ 'all' ]
121 stage: testsuites
122 script:
123 - cppcheck --force --quiet --inline-suppr .
124
125# search for TODO within source tree
126grep TODO/FIXME/HACK:
127 tags: [ 'all' ]
128 stage: testsuites
129 script:
130 - grep -r TODO .
131 - grep -r FIXME .
132 # search for HACK within source tree and ignore HACKKIT board
133 - grep -r HACK . | grep -v HACKKIT
134
Heinrich Schuchardtbccdb652020-02-21 18:24:01 +0100135# build HTML documentation
136htmldocs:
137 tags: [ 'all' ]
138 stage: testsuites
139 script:
140 - make htmldocs
141
Tom Rinid2244b92019-06-19 09:25:17 -0400142# some statistics about the code base
143sloccount:
144 tags: [ 'all' ]
145 stage: testsuites
146 script:
147 - sloccount .
148
149# ensure all configs have MAINTAINERS entries
150Check for configs without MAINTAINERS entry:
151 tags: [ 'all' ]
152 stage: testsuites
153 script:
154 - if [ `./tools/genboardscfg.py -f 2>&1 | wc -l` -ne 0 ]; then exit 1; fi
155
156# Ensure host tools build
157Build tools-only:
158 tags: [ 'all' ]
159 stage: testsuites
160 script:
161 - make tools-only_config tools-only -j$(nproc)
162
Pierre-Jean Texier6812f5e2019-08-26 13:06:18 +0200163# Ensure env tools build
164Build envtools:
165 tags: [ 'all' ]
166 stage: testsuites
167 script:
168 - make tools-only_config envtools -j$(nproc)
169
Tom Rini0b3e0c42020-03-11 18:11:15 -0400170Run binman, buildman, dtoc, Kconfig and patman testsuites:
Tom Rinid2244b92019-06-19 09:25:17 -0400171 tags: [ 'all' ]
172 stage: testsuites
173 script:
Tom Rini0b6e1032019-08-12 10:09:08 -0400174 - git config --global user.name "GitLab CI Runner";
175 git config --global user.email trini@konsulko.com;
176 export USER=gitlab;
Tom Rini6c883102020-02-11 12:41:14 -0500177 virtualenv -p /usr/bin/python3 /tmp/venv;
Tom Rini0b6e1032019-08-12 10:09:08 -0400178 . /tmp/venv/bin/activate;
Tom Rini0b3e0c42020-03-11 18:11:15 -0400179 pip install pyelftools pytest;
Simon Glass9e589c02020-03-18 09:42:50 -0600180 export UBOOT_TRAVIS_BUILD_DIR=/tmp/sandbox_spl;
Tom Rini0b6e1032019-08-12 10:09:08 -0400181 export PYTHONPATH="${UBOOT_TRAVIS_BUILD_DIR}/scripts/dtc/pylibfdt";
182 export PATH="${UBOOT_TRAVIS_BUILD_DIR}/scripts/dtc:${PATH}";
Simon Glass9e589c02020-03-18 09:42:50 -0600183 ./tools/buildman/buildman -o ${UBOOT_TRAVIS_BUILD_DIR} -w sandbox_spl;
Tom Rini0b6e1032019-08-12 10:09:08 -0400184 ./tools/binman/binman --toolpath ${UBOOT_TRAVIS_BUILD_DIR}/tools test;
185 ./tools/buildman/buildman -t;
186 ./tools/dtoc/dtoc -t;
Tom Rini0b3e0c42020-03-11 18:11:15 -0400187 ./tools/patman/patman --test;
188 make testconfig
Tom Rinid2244b92019-06-19 09:25:17 -0400189
190# Test sandbox with test.py
191sandbox test.py:
192 tags: [ 'all' ]
193 variables:
194 TEST_PY_BD: "sandbox"
Tom Rinid2244b92019-06-19 09:25:17 -0400195 <<: *buildman_and_testpy_dfn
196
Tom Rini99a1bb32019-11-06 19:30:47 -0500197sandbox with clang test.py:
198 tags: [ 'all' ]
199 variables:
200 TEST_PY_BD: "sandbox"
Tom Rini99a1bb32019-11-06 19:30:47 -0500201 OVERRIDE: "-O clang-7"
202 <<: *buildman_and_testpy_dfn
203
Tom Rinid2244b92019-06-19 09:25:17 -0400204sandbox_spl test.py:
205 tags: [ 'all' ]
206 variables:
207 TEST_PY_BD: "sandbox_spl"
Tom Rinid2244b92019-06-19 09:25:17 -0400208 TEST_PY_TEST_SPEC: "test_ofplatdata"
209 <<: *buildman_and_testpy_dfn
210
Tom Rini0008b882019-07-17 16:06:57 -0400211evb-ast2500 test.py:
212 tags: [ 'all' ]
213 variables:
214 TEST_PY_BD: "evb-ast2500"
215 TEST_PY_ID: "--id qemu"
Tom Rini0008b882019-07-17 16:06:57 -0400216 <<: *buildman_and_testpy_dfn
217
Tom Rinid2244b92019-06-19 09:25:17 -0400218sandbox_flattree test.py:
219 tags: [ 'all' ]
220 variables:
221 TEST_PY_BD: "sandbox_flattree"
Tom Rinid2244b92019-06-19 09:25:17 -0400222 <<: *buildman_and_testpy_dfn
223
224vexpress_ca15_tc2 test.py:
225 tags: [ 'all' ]
226 variables:
227 TEST_PY_BD: "vexpress_ca15_tc2"
228 TEST_PY_ID: "--id qemu"
Tom Rinid2244b92019-06-19 09:25:17 -0400229 <<: *buildman_and_testpy_dfn
230
231vexpress_ca9x4 test.py:
232 tags: [ 'all' ]
233 variables:
234 TEST_PY_BD: "vexpress_ca9x4"
235 TEST_PY_ID: "--id qemu"
Tom Rinid2244b92019-06-19 09:25:17 -0400236 <<: *buildman_and_testpy_dfn
237
238integratorcp_cm926ejs test.py:
239 tags: [ 'all' ]
240 variables:
241 TEST_PY_BD: "integratorcp_cm926ejs"
242 TEST_PY_TEST_SPEC: "not sleep"
243 TEST_PY_ID: "--id qemu"
Tom Rinid2244b92019-06-19 09:25:17 -0400244 <<: *buildman_and_testpy_dfn
245
246qemu_arm test.py:
247 tags: [ 'all' ]
248 variables:
249 TEST_PY_BD: "qemu_arm"
250 TEST_PY_TEST_SPEC: "not sleep"
Tom Rinid2244b92019-06-19 09:25:17 -0400251 <<: *buildman_and_testpy_dfn
252
253qemu_arm64 test.py:
254 tags: [ 'all' ]
255 variables:
256 TEST_PY_BD: "qemu_arm64"
257 TEST_PY_TEST_SPEC: "not sleep"
Tom Rinid2244b92019-06-19 09:25:17 -0400258 <<: *buildman_and_testpy_dfn
259
260qemu_mips test.py:
261 tags: [ 'all' ]
262 variables:
263 TEST_PY_BD: "qemu_mips"
264 TEST_PY_TEST_SPEC: "not sleep"
Tom Rinid2244b92019-06-19 09:25:17 -0400265 <<: *buildman_and_testpy_dfn
266
267qemu_mipsel test.py:
268 tags: [ 'all' ]
269 variables:
270 TEST_PY_BD: "qemu_mipsel"
271 TEST_PY_TEST_SPEC: "not sleep"
Tom Rinid2244b92019-06-19 09:25:17 -0400272 <<: *buildman_and_testpy_dfn
273
274qemu_mips64 test.py:
275 tags: [ 'all' ]
276 variables:
277 TEST_PY_BD: "qemu_mips64"
278 TEST_PY_TEST_SPEC: "not sleep"
Tom Rinid2244b92019-06-19 09:25:17 -0400279 <<: *buildman_and_testpy_dfn
280
281qemu_mips64el test.py:
282 tags: [ 'all' ]
283 variables:
284 TEST_PY_BD: "qemu_mips64el"
285 TEST_PY_TEST_SPEC: "not sleep"
Tom Rinid2244b92019-06-19 09:25:17 -0400286 <<: *buildman_and_testpy_dfn
287
288qemu-ppce500 test.py:
289 tags: [ 'all' ]
290 variables:
291 TEST_PY_BD: "qemu-ppce500"
292 TEST_PY_TEST_SPEC: "not sleep"
Tom Rinid2244b92019-06-19 09:25:17 -0400293 <<: *buildman_and_testpy_dfn
294
Bin Mengaeb3ea42020-03-28 07:25:27 -0700295qemu-riscv32 test.py:
296 tags: [ 'all' ]
297 variables:
298 TEST_PY_BD: "qemu-riscv32"
299 TEST_PY_TEST_SPEC: "not sleep"
Bin Mengaeb3ea42020-03-28 07:25:27 -0700300 <<: *buildman_and_testpy_dfn
301
Tom Rinic8c320e2019-08-02 11:32:37 -0400302qemu-riscv64 test.py:
303 tags: [ 'all' ]
304 variables:
305 TEST_PY_BD: "qemu-riscv64"
306 TEST_PY_TEST_SPEC: "not sleep"
Tom Rinic8c320e2019-08-02 11:32:37 -0400307 <<: *buildman_and_testpy_dfn
308
Bin Mengb68d9d62020-03-28 07:25:29 -0700309qemu-riscv32_spl test.py:
310 tags: [ 'all' ]
311 variables:
312 TEST_PY_BD: "qemu-riscv32_spl"
313 TEST_PY_TEST_SPEC: "not sleep"
Bin Mengb68d9d62020-03-28 07:25:29 -0700314 <<: *buildman_and_testpy_dfn
315
316qemu-riscv64_spl test.py:
317 tags: [ 'all' ]
318 variables:
319 TEST_PY_BD: "qemu-riscv64_spl"
320 TEST_PY_TEST_SPEC: "not sleep"
Bin Mengb68d9d62020-03-28 07:25:29 -0700321 <<: *buildman_and_testpy_dfn
322
Tom Rinid2244b92019-06-19 09:25:17 -0400323qemu-x86 test.py:
324 tags: [ 'all' ]
325 variables:
326 TEST_PY_BD: "qemu-x86"
327 TEST_PY_TEST_SPEC: "not sleep"
Tom Rinid2244b92019-06-19 09:25:17 -0400328 <<: *buildman_and_testpy_dfn
329
330qemu-x86_64 test.py:
331 tags: [ 'all' ]
332 variables:
333 TEST_PY_BD: "qemu-x86_64"
334 TEST_PY_TEST_SPEC: "not sleep"
Tom Rinid2244b92019-06-19 09:25:17 -0400335 <<: *buildman_and_testpy_dfn
336
Michal Simekf8834fd2020-02-13 15:03:29 +0100337xilinx_zynq_virt test.py:
Tom Rinid2244b92019-06-19 09:25:17 -0400338 tags: [ 'all' ]
339 variables:
Michal Simekf8834fd2020-02-13 15:03:29 +0100340 TEST_PY_BD: "xilinx_zynq_virt"
Tom Rinid2244b92019-06-19 09:25:17 -0400341 TEST_PY_TEST_SPEC: "not sleep"
Tom Rinid2244b92019-06-19 09:25:17 -0400342 TEST_PY_ID: "--id qemu"
Tom Rinid2244b92019-06-19 09:25:17 -0400343 <<: *buildman_and_testpy_dfn
344
345xilinx_versal_virt test.py:
346 tags: [ 'all' ]
347 variables:
348 TEST_PY_BD: "xilinx_versal_virt"
349 TEST_PY_TEST_SPEC: "not sleep"
Tom Rinid2244b92019-06-19 09:25:17 -0400350 TEST_PY_ID: "--id qemu"
Tom Rinid2244b92019-06-19 09:25:17 -0400351 <<: *buildman_and_testpy_dfn
352
353xtfpga test.py:
354 tags: [ 'all' ]
355 variables:
356 TEST_PY_BD: "xtfpga"
357 TEST_PY_TEST_SPEC: "not sleep"
Tom Rinid2244b92019-06-19 09:25:17 -0400358 TEST_PY_ID: "--id qemu"
Tom Rinid2244b92019-06-19 09:25:17 -0400359 <<: *buildman_and_testpy_dfn