X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=.travis.yml;h=b4ae71a39be0c9a3448625e6237ff0de83bbb16c;hb=15fde0fc11f93f19f40c9cda36e7c8d4848d9c75;hp=845f6cad9400dada7bd76c56983fbd38cd4307c3;hpb=2bb76f33e9ee7ca6f086ee98d6cfbf28b8c8d90a;p=oweals%2Fu-boot.git diff --git a/.travis.yml b/.travis.yml index 845f6cad94..b4ae71a39b 100644 --- a/.travis.yml +++ b/.travis.yml @@ -10,6 +10,8 @@ language: c addons: apt: + sources: + - sourceline: 'ppa:gns3/qemu' packages: - cppcheck - sloccount @@ -19,58 +21,85 @@ addons: - libsdl1.2-dev - python - python-virtualenv - -cache: - - apt + - qemu-system-arm + - qemu-system-mips + - qemu-system-ppc + - qemu-system-x86 + - gcc-powerpc-linux-gnu + - gcc-arm-linux-gnueabihf + - gcc-aarch64-linux-gnu + - iasl + - grub-efi-ia32-bin + - rpm2cpio + - wget install: # install latest device tree compiler - - git clone --depth=1 https://git.kernel.org/pub/scm/utils/dtc/dtc.git /tmp/dtc + - git clone --depth=1 git://git.kernel.org/pub/scm/utils/dtc/dtc.git /tmp/dtc - make -j4 -C /tmp/dtc + # Clone uboot-test-hooks + - git clone --depth=1 git://github.com/swarren/uboot-test-hooks.git /tmp/uboot-test-hooks + - 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:" - - export BUILDMAN_PPC="ppc:" - - export BUILDMAN_ARM="arm:" - - export BUILDMAN_SANDBOX="sandbox:" - - echo -e "[toolchain]\n${BUILDMAN_ROOT} /\n" > ~/.buildman - - echo -e "${BUILDMAN_PPC} /opt/eldk-5.4/powerpc/sysroots/i686-eldk-linux/usr/bin/powerpc-linux/\n" >> ~/.buildman - - echo -e "${BUILDMAN_ARM} /opt/eldk-5.4/armv5te/sysroots/i686-eldk-linux/usr/bin/armv5te-linux-gnueabi/\n" >> ~/.buildman - - echo -e "${BUILDMAN_SANDBOX} /usr/bin/gcc\n" >> ~/.buildman - - export BUILDMAN_ALIAS="x86:" - - export BUILDMAN_ALIAS_ARM="arm:" - - echo -e "\n\n[toolchain-alias]\n${BUILDMAN_ALIAS} i386\n" >> ~/.buildman - - echo -e "${BUILDMAN_ALIAS_ARM} armv5te\n" >> ~/.buildman + - echo -e "[toolchain]\nroot = /usr" > ~/.buildman + - echo -e "\n[toolchain-alias]\nblackfin = bfin\nsh = sh4\nopenrisc = or32" >> ~/.buildman - cat ~/.buildman - virtualenv /tmp/venv - . /tmp/venv/bin/activate - pip install pytest + - grub-mkimage -o ~/grub_x86.efi -O i386-efi normal echo lsefimmap lsefi lsefisystab efinet tftp minicmd + - mkdir ~/grub2-arm + - ( cd ~/grub2-arm; wget -O - http://download.opensuse.org/ports/armv7hl/distribution/leap/42.2/repo/oss/suse/armv7hl/grub2-arm-efi-2.02~beta2-87.1.armv7hl.rpm | rpm2cpio | cpio -di ) env: global: - - PATH=/tmp/dtc:$PATH + - PATH=/tmp/dtc:/tmp/uboot-test-hooks/bin:$PATH + - PYTHONPATH=/tmp/uboot-test-hooks/py/travis-ci - BUILD_DIR=build - HOSTCC="cc" - HOSTCXX="c++" before_script: # install toolchains based on TOOLCHAIN} variable - - if [[ "${TOOLCHAIN}" == *aarch64* ]]; then ./tools/buildman/buildman --fetch-arch aarch64 ; fi - - if [[ "${TOOLCHAIN}" == *arm* ]]; then wget ftp://ftp.denx.de/pub/eldk/5.4/targets/armv5te/eldk-eglibc-i686-arm-toolchain-gmae-5.4.sh ; fi - - if [[ "${TOOLCHAIN}" == *arm* ]]; then sh eldk-eglibc-i686-arm-toolchain-gmae-5.4.sh -y ; fi - if [[ "${TOOLCHAIN}" == *avr32* ]]; then ./tools/buildman/buildman --fetch-arch avr32 ; fi - - if [[ "${TOOLCHAIN}" == *i386* ]]; then ./tools/buildman/buildman sandbox --fetch-arch i386 ; fi + - if [[ "${TOOLCHAIN}" == *bfin* ]]; then ./tools/buildman/buildman --fetch-arch bfin ; fi - if [[ "${TOOLCHAIN}" == *m68k* ]]; then ./tools/buildman/buildman --fetch-arch m68k ; fi + - if [[ "${TOOLCHAIN}" == *microblaze* ]]; then ./tools/buildman/buildman --fetch-arch microblaze ; fi - if [[ "${TOOLCHAIN}" == *mips* ]]; then ./tools/buildman/buildman --fetch-arch mips ; fi - - if [[ "${TOOLCHAIN}" == *ppc* ]]; then wget ftp://ftp.denx.de/pub/eldk/5.4/targets/powerpc/eldk-eglibc-i686-powerpc-toolchain-gmae-5.4.sh ; fi - - if [[ "${TOOLCHAIN}" == *ppc* ]]; then sh eldk-eglibc-i686-powerpc-toolchain-gmae-5.4.sh -y ; 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; + 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: - # the execution sequence for each test - - if [[ "${TEST_CMD}" != "" ]]; then - ${TEST_CMD}; - fi + # Comments must be outside the command strings below, or the Travis parser + # will get confused. + # + # Exit code 129 means warnings only. - if [[ "${BUILDMAN}" != "" ]]; then - tools/buildman/buildman ${BUILDMAN}; + set +e; + 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. + - export UBOOT_TRAVIS_BUILD_DIR=`cd .. && pwd`/.bm-work/${TEST_PY_BD}; + cp ~/grub_x86.efi $UBOOT_TRAVIS_BUILD_DIR/; + cp ~/grub2-arm/usr/lib/grub2/arm-efi/grub.efi $UBOOT_TRAVIS_BUILD_DIR/grub_arm.efi; + 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 "$UBOOT_TRAVIS_BUILD_DIR"; fi matrix: @@ -78,113 +107,183 @@ 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" - TOOLCHAIN="arm" + - BUILDMAN="arm11" - env: - - BUILDMAN="arm1136" - TOOLCHAIN="arm" + - BUILDMAN="arm7" - env: - - BUILDMAN="arm1176" - TOOLCHAIN="arm" + - BUILDMAN="arm920t" - env: - - BUILDMAN="arm720t" - TOOLCHAIN="arm" + - JOB="arm926ejs" + BUILDMAN="arm926ejs -x mx,siemens,atmel" - env: - - BUILDMAN="arm920t" - TOOLCHAIN="arm" + - BUILDMAN="arm946es" - env: - BUILDMAN="atmel -x avr32" - TOOLCHAIN="arm" - env: - BUILDMAN="avr32" TOOLCHAIN="avr32" - - env: - - BUILDMAN="davinci" - TOOLCHAIN="arm" - env: - BUILDMAN="denx" - TOOLCHAIN="arm" - env: - - BUILDMAN="freescale -x powerpc,m68k,aarch64" - TOOLCHAIN="arm" + - 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="i386" + TOOLCHAIN="x86_64" - env: - BUILDMAN="kirkwood" - TOOLCHAIN="arm" + - env: + - BUILDMAN="pxa" - env: - BUILDMAN="m68k" TOOLCHAIN="m68k" + - env: + - BUILDMAN="microblaze" + TOOLCHAIN="microblaze" - env: - BUILDMAN="mips" TOOLCHAIN="mips" - env: - BUILDMAN="mpc512x" - TOOLCHAIN="ppc" - env: - BUILDMAN="mpc5xx" - TOOLCHAIN="ppc" - env: - BUILDMAN="mpc5xxx" - TOOLCHAIN="ppc" - env: - BUILDMAN="mpc8260" - TOOLCHAIN="ppc" - env: - BUILDMAN="mpc83xx" - TOOLCHAIN="ppc" - env: - BUILDMAN="mpc85xx -x freescale" - TOOLCHAIN="ppc" - env: - BUILDMAN="mpc85xx -x t208xrdb -x t4qds -x t102* -x p1_p2_rdb_pc -x p1010rdb -x corenet_ds -x b4860qds -x sbc8548 -x bsc91*" - TOOLCHAIN="ppc" - env: - BUILDMAN="t208xrdb t4qds t102*" - TOOLCHAIN="ppc" - env: - BUILDMAN="p1_p2_rdb_pc p1010rdb" - TOOLCHAIN="ppc" - env: - BUILDMAN="corenet_ds b4860qds sbc8548 bsc91*" - TOOLCHAIN="ppc" - env: - BUILDMAN="mpc86xx" - TOOLCHAIN="ppc" - env: - BUILDMAN="mpc8xx" - TOOLCHAIN="ppc" - env: - BUILDMAN="siemens" - TOOLCHAIN="arm" - env: - - BUILDMAN="ti" - TOOLCHAIN="arm" + - BUILDMAN="tegra" + - env: + - JOB="am33xx" + BUILDMAN="am33xx -x siemens" + - env: + - BUILDMAN="omap3" + - env: + - BUILDMAN="omap4" + - env: + - BUILDMAN="omap5" + - env: + - BUILDMAN="uniphier" - env: - - BUILDMAN="aarch64" + - BUILDMAN="aarch64 -x tegra,freescale,uniphier,sunxi" TOOLCHAIN="aarch64" + - env: + - BUILDMAN="sh4" + TOOLCHAIN="sh4" + - env: + - BUILDMAN="xtensa" + TOOLCHAIN="xtensa" # QA jobs for code analytics # static code analysis with cppcheck (we can add --enable=all later) - env: - - TEST_CMD="cppcheck --force --quiet --inline-suppr ." + - JOB="cppcheck" + script: + - cppcheck --force --quiet --inline-suppr . # search for TODO within source tree - env: - - TEST_CMD="grep -r TODO ." + - JOB="grep TODO" + script: + - grep -r TODO . # search for FIXME within source tree - env: - - TEST_CMD="grep -r FIXME ." + - JOB="grep FIXME HACK" + script: + - grep -r FIXME . # search for HACK within source tree and ignore HACKKIT board - - env: - - TEST_CMD="grep -r HACK . | grep -v HACKKIT" script: - grep -r HACK . | grep -v HACKKIT # some statistics about the code base - env: - - TEST_CMD="sloccount ." + - JOB="sloccount" + script: + - sloccount . + # test/py - env: - - TEST_CMD="./test/py/test.py --bd sandbox --build" + - TEST_PY_BD="sandbox" + BUILDMAN="^sandbox$" + TOOLCHAIN="x86_64" + - env: + - TEST_PY_BD="vexpress_ca15_tc2" + TEST_PY_ID="--id qemu" + BUILDMAN="^vexpress_ca15_tc2$" + - env: + - TEST_PY_BD="vexpress_ca9x4" + TEST_PY_ID="--id qemu" + BUILDMAN="^vexpress_ca9x4$" + - env: + - TEST_PY_BD="integratorcp_cm926ejs" + TEST_PY_TEST_SPEC="not sleep" + 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