X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=.travis.yml;h=3d7fffe0bd3e070a231e1a48a1d1aac3a66ef2d3;hb=bfe279803ff08aba86277ba60890923cd678af7b;hp=d65c5705875fa14e300e2cbbe382556b8499fd7b;hpb=4f892924d238cc415891dbea336a0fdaff2f853b;p=u-boot diff --git a/.travis.yml b/.travis.yml index d65c570587..3d7fffe0bd 100644 --- a/.travis.yml +++ b/.travis.yml @@ -27,6 +27,7 @@ addons: - qemu-system-x86 - gcc-powerpc-linux-gnu - gcc-arm-linux-gnueabihf + - gcc-aarch64-linux-gnu - iasl install: @@ -38,8 +39,7 @@ install: - ln -s travis-ci /tmp/uboot-test-hooks/bin/`hostname` - ln -s travis-ci /tmp/uboot-test-hooks/py/`hostname` # prepare buildman environment - - export BUILDMAN_ROOT="root:" - - echo -e "[toolchain]\n${BUILDMAN_ROOT} /usr" > ~/.buildman + - echo -e "[toolchain]\nroot = /usr" > ~/.buildman - echo -e "\n[toolchain-alias]\nblackfin = bfin\nsh = sh4\nopenrisc = or32" >> ~/.buildman - cat ~/.buildman - virtualenv /tmp/venv @@ -55,7 +55,6 @@ env: before_script: # install toolchains based on TOOLCHAIN} variable - - if [[ "${TOOLCHAIN}" == *aarch64* ]]; then ./tools/buildman/buildman --fetch-arch aarch64 ; fi - if [[ "${TOOLCHAIN}" == *avr32* ]]; then ./tools/buildman/buildman --fetch-arch avr32 ; fi - if [[ "${TOOLCHAIN}" == *bfin* ]]; then ./tools/buildman/buildman --fetch-arch bfin ; fi - if [[ "${TOOLCHAIN}" == *m68k* ]]; then ./tools/buildman/buildman --fetch-arch m68k ; fi @@ -63,19 +62,34 @@ before_script: - if [[ "${TOOLCHAIN}" == *mips* ]]; then ./tools/buildman/buildman --fetch-arch mips ; fi - if [[ "${TOOLCHAIN}" == *or32* ]]; then ./tools/buildman/buildman --fetch-arch or32 ; fi - if [[ "${TOOLCHAIN}" == *sh4* ]]; then ./tools/buildman/buildman --fetch-arch sh4 ; fi - - if [[ "${TOOLCHAIN}" == *x86_64* ]]; then ./tools/buildman/buildman --fetch-arch x86_64 ; fi + - if [[ "${TOOLCHAIN}" == *x86_64* ]]; then + ./tools/buildman/buildman --fetch-arch x86_64; + echo -e "\n[toolchain-prefix]\nx86 = ${HOME}/.buildman-toolchains/gcc-4.9.0-nolibc/x86_64-linux/bin/x86_64-linux-" >> ~/.buildman; + fi - if [[ "${TOOLCHAIN}" == *xtensa* ]]; then ./tools/buildman/buildman --fetch-arch xtensa ; fi script: + # Comments must be outside the command strings below, or the Travis parser + # will get confused. + # # Exit code 129 means warnings only. - if [[ "${BUILDMAN}" != "" ]]; then set +e; - tools/buildman/buildman ${BUILDMAN}; - if [[ "$?" == "0" || "$?" == "129" ]]; then - exit 0; - else - exit $?; - fi + tools/buildman/buildman -P ${BUILDMAN}; + ret=$?; + if [[ $ret -ne 0 && $ret -ne 129 ]]; then + tools/buildman/buildman -sdeP ${BUILDMAN}; + exit $ret; + fi; + fi + # "not a_test_which_does_not_exist" is a dummy -k parameter which will + # never prevent any test from running. That way, we can always pass + # "-k something" even when $TEST_PY_TEST_SPEC doesnt need a custom + # value. + - if [[ "${TEST_PY_BD}" != "" ]]; then + ./test/py/test.py --bd ${TEST_PY_BD} ${TEST_PY_ID} + -k "${TEST_PY_TEST_SPEC:-not a_test_which_does_not_exist}" + --build-dir `cd .. && pwd`/.bm-work/${TEST_PY_BD}; fi matrix: @@ -83,34 +97,53 @@ matrix: # we need to build by vendor due to 50min time limit for builds # each env setting here is a dedicated build - env: - - BUILDMAN="arm1136" + - BUILDMAN="arm11" - env: - - BUILDMAN="arm1136" + - BUILDMAN="arm7" - env: - - BUILDMAN="arm1176" + - BUILDMAN="arm920t" - env: - - BUILDMAN="arm720t" + - JOB="arm926ejs" + BUILDMAN="arm926ejs -x mx,siemens,atmel" - env: - - BUILDMAN="arm920t" + - BUILDMAN="arm946es" - env: - BUILDMAN="atmel -x avr32" - env: - BUILDMAN="avr32" TOOLCHAIN="avr32" - - env: - - BUILDMAN="davinci" - env: - BUILDMAN="denx" - env: - - BUILDMAN="freescale -x powerpc,m68k,aarch64" + - JOB="Freescale ARM" + BUILDMAN="freescale -x powerpc,m68k" + - env: + - JOB="i.MX (non-Freescale)" + BUILDMAN="mx -x freescale" + - env: + - BUILDMAN="sun4i" + - env: + - BUILDMAN="sun5i" + - env: + - BUILDMAN="sun6i" + - env: + - BUILDMAN="sun7i" + - env: + - BUILDMAN="sun8i" + - env: + - BUILDMAN="sun9i" + - env: + - BUILDMAN="sun50i" + - env: + - JOB="Catch-all ARM" + BUILDMAN="arm -x arm11,arm7,arm9,aarch64,atmel,denx,freescale,kirkwood,siemens,tegra,uniphier,mx,sunxi,am33xx,omap3,omap4,omap5,pxa" - env: - BUILDMAN="sandbox x86" TOOLCHAIN="x86_64" - script: - - export BUILDMAN_X86="x86:"; - echo -e "\n[toolchain-prefix]\n${BUILDMAN_X86} ${HOME}/.buildman-toolchains/gcc-4.9.0-nolibc/x86_64-linux/bin/x86_64-linux-" >> ~/.buildman - env: - BUILDMAN="kirkwood" + - env: + - BUILDMAN="pxa" - env: - BUILDMAN="m68k" TOOLCHAIN="m68k" @@ -147,9 +180,20 @@ matrix: - env: - BUILDMAN="siemens" - env: - - BUILDMAN="ti" + - BUILDMAN="tegra" + - env: + - JOB="am33xx" + BUILDMAN="am33xx -x siemens" + - env: + - BUILDMAN="omap3" + - env: + - BUILDMAN="omap4" - env: - - BUILDMAN="aarch64" + - BUILDMAN="omap5" + - env: + - BUILDMAN="uniphier" + - env: + - BUILDMAN="aarch64 -x tegra,freescale,uniphier,sunxi" TOOLCHAIN="aarch64" - env: - BUILDMAN="sh4" @@ -160,46 +204,75 @@ matrix: # QA jobs for code analytics # static code analysis with cppcheck (we can add --enable=all later) - - script: + - env: + - JOB="cppcheck" + script: - cppcheck --force --quiet --inline-suppr . # search for TODO within source tree - - script: + - env: + - JOB="grep TODO" + script: - grep -r TODO . # search for FIXME within source tree - - script: + - env: + - JOB="grep FIXME HACK" + script: - grep -r FIXME . # search for HACK within source tree and ignore HACKKIT board script: - grep -r HACK . | grep -v HACKKIT # some statistics about the code base - - script: + - env: + - JOB="sloccount" + script: - sloccount . + # test/py - - script: - - ./test/py/test.py --bd sandbox --build - env: - - CROSS_COMPILE="/usr/bin/arm-linux-gnueabihf-" - script: - - ./test/py/test.py --bd vexpress_ca15_tc2 --id qemu --build; - ./test/py/test.py --bd vexpress_ca9x4 --id qemu --build; - ./test/py/test.py --bd integratorcp_cm926ejs --id qemu --build; + - TEST_PY_BD="sandbox" + BUILDMAN="^sandbox$" + TOOLCHAIN="x86_64" - env: - - TOOLCHAIN="mips" - CROSS_COMPILE="${HOME}/.buildman-toolchains/gcc-4.9.0-nolibc/mips-linux/bin/mips-linux-" - script: - - ./test/py/test.py --bd qemu_mips --build -k 'not sleep'; - ./test/py/test.py --bd qemu_mipsel --build -k 'not sleep'; - ./test/py/test.py --bd qemu_mips64 --build -k 'not sleep'; - ./test/py/test.py --bd qemu_mips64el --build -k 'not sleep'; + - TEST_PY_BD="vexpress_ca15_tc2" + TEST_PY_ID="--id qemu" + BUILDMAN="^vexpress_ca15_tc2$" - env: - - CROSS_COMPILE="/usr/bin/powerpc-linux-gnu-" - script: - - ./test/py/test.py --bd qemu-ppce500 --build -k 'not sleep' + - TEST_PY_BD="vexpress_ca9x4" + TEST_PY_ID="--id qemu" + BUILDMAN="^vexpress_ca9x4$" - env: - - TOOLCHAIN="x86_64" - BUILD_ROM=yes - CROSS_COMPILE="${HOME}/.buildman-toolchains/gcc-4.9.0-nolibc/x86_64-linux/bin/x86_64-linux-" - script: - - ./test/py/test.py --bd qemu-x86 --build -k 'not sleep' + - TEST_PY_BD="integratorcp_cm926ejs" + TEST_PY_ID="--id qemu" + BUILDMAN="^integratorcp_cm926ejs$" + - env: + - TEST_PY_BD="qemu_mips" + TEST_PY_TEST_SPEC="not sleep" + BUILDMAN="^qemu_mips$" + TOOLCHAIN="mips" + - env: + - TEST_PY_BD="qemu_mipsel" + TEST_PY_TEST_SPEC="not sleep" + BUILDMAN="^qemu_mipsel$" + TOOLCHAIN="mips" + - env: + - TEST_PY_BD="qemu_mips64" + TEST_PY_TEST_SPEC="not sleep" + BUILDMAN="^qemu_mips64$" + TOOLCHAIN="mips" + - env: + - TEST_PY_BD="qemu_mips64el" + TEST_PY_TEST_SPEC="not sleep" + BUILDMAN="^qemu_mips64el$" + TOOLCHAIN="mips" + - env: + - TEST_PY_BD="qemu-ppce500" + TEST_PY_TEST_SPEC="not sleep" + BUILDMAN="^qemu-ppce500$" + - env: + - TEST_PY_BD="qemu-x86" + TEST_PY_TEST_SPEC="not sleep" + BUILDMAN="^qemu-x86$" + TOOLCHAIN="x86_64" + BUILD_ROM="yes" # TODO make it perfect ;-r