2014-04-11 17:06:25 +02:00
|
|
|
language: c
|
|
|
|
|
2014-09-20 13:20:30 +02:00
|
|
|
cache: apt
|
|
|
|
|
2014-08-21 19:37:06 +02:00
|
|
|
env:
|
|
|
|
- NPROC_MAX=8
|
|
|
|
|
2014-04-11 17:06:25 +02:00
|
|
|
before_install:
|
|
|
|
- sudo apt-get install emdebian-archive-keyring
|
2014-11-20 13:35:31 +01:00
|
|
|
- echo 'deb http://emdebian.bytesatwork.ch/mirror/toolchains/ wheezy main' | sudo tee /etc/apt/sources.list.d/emdebian.list > /dev/null
|
2014-04-11 17:06:25 +02:00
|
|
|
|
|
|
|
- echo 'deb http://us.archive.ubuntu.com/ubuntu trusty main restricted universe multiverse' | sudo tee /etc/apt/sources.list.d/trusty.list > /dev/null
|
|
|
|
- echo 'deb http://us.archive.ubuntu.com/ubuntu trusty-backports main restricted universe multiverse' | sudo tee -a /etc/apt/sources.list.d/trusty.list > /dev/null
|
|
|
|
- echo 'deb http://us.archive.ubuntu.com/ubuntu trusty-security main restricted universe multiverse' | sudo tee -a /etc/apt/sources.list.d/trusty.list > /dev/null
|
|
|
|
- echo 'deb http://us.archive.ubuntu.com/ubuntu trusty-updates main restricted universe multiverse' | sudo tee -a /etc/apt/sources.list.d/trusty.list > /dev/null
|
|
|
|
- sudo add-apt-repository -y ppa:terry.guo/gcc-arm-embedded
|
|
|
|
- sudo apt-get update
|
|
|
|
|
|
|
|
install:
|
2014-09-22 10:54:26 +02:00
|
|
|
- >
|
|
|
|
sudo apt-get install \
|
|
|
|
build-essential \
|
|
|
|
gcc-multilib \
|
2014-09-30 22:04:25 +02:00
|
|
|
gcc-arm-none-eabi \
|
2014-09-22 10:54:26 +02:00
|
|
|
gcc-msp430 \
|
|
|
|
pcregrep \
|
|
|
|
libpcre3 \
|
|
|
|
qemu-system-x86 \
|
|
|
|
python3 \
|
|
|
|
g++-multilib \
|
|
|
|
gcc-avr \
|
|
|
|
binutils-avr \
|
|
|
|
avr-libc \
|
|
|
|
cppcheck \
|
2014-07-07 23:48:02 +02:00
|
|
|
- git config --global user.email "travis@example.com"
|
|
|
|
- git config --global user.name "Travis CI"
|
2014-04-11 17:06:25 +02:00
|
|
|
|
Travis: auto rebase on master before running
It can happen that two PRs don't interfere with each other in the sense
that they hurt automatic rebasing, but still do not work together. The
prime example is PR1 changes the API of some function that PR2 uses. If
PR1 is merged, and PR2 is not rebased before merging, the error might
get unnoticed before the next build. Travis CI would have have told both
PR1 and PR2 are fine, but will complain (rather unnoticedly) that our
master does not compile.
This PR automatically rebases the PR on top of the current master,
before running the tests. If the automatic rebase fails, then this is
fine, because you will need to manually rebase again before merging,
anyway. The manual rebase, i.e. new push, will trigger Travis CI.
So, the main idea of this PR is that to can hit the "Restart Build"
button in Travis CI before hitting the merge button in Github.
2014-08-01 11:10:51 +02:00
|
|
|
- git remote add riot https://github.com/RIOT-OS/RIOT.git
|
|
|
|
- git fetch riot master
|
|
|
|
- git log -1 --pretty=format:%H riot/master
|
|
|
|
|
2014-04-11 17:06:25 +02:00
|
|
|
script:
|
2014-08-21 19:37:06 +02:00
|
|
|
- make -s -C ./examples/default info-concurrency
|
Travis: auto rebase on master before running
It can happen that two PRs don't interfere with each other in the sense
that they hurt automatic rebasing, but still do not work together. The
prime example is PR1 changes the API of some function that PR2 uses. If
PR1 is merged, and PR2 is not rebased before merging, the error might
get unnoticed before the next build. Travis CI would have have told both
PR1 and PR2 are fine, but will complain (rather unnoticedly) that our
master does not compile.
This PR automatically rebases the PR on top of the current master,
before running the tests. If the automatic rebase fails, then this is
fine, because you will need to manually rebase again before merging,
anyway. The manual rebase, i.e. new push, will trigger Travis CI.
So, the main idea of this PR is that to can hit the "Restart Build"
button in Travis CI before hitting the merge button in Github.
2014-08-01 11:10:51 +02:00
|
|
|
- git rebase riot/master || git rebase --abort
|
|
|
|
|
2014-11-23 10:14:44 +01:00
|
|
|
- ./dist/tools/licenses/check.sh master --diff-filter=MR --error-exitcode=0 || exit
|
2014-11-22 16:35:16 +01:00
|
|
|
- ./dist/tools/licenses/check.sh master --diff-filter=AC || exit
|
2014-11-19 16:17:34 +01:00
|
|
|
|
2014-11-25 03:09:07 +01:00
|
|
|
- ./dist/tools/externc/check.sh master || exit
|
2014-11-18 19:28:44 +01:00
|
|
|
|
|
|
|
# TODO:
|
2014-10-24 11:41:38 +02:00
|
|
|
# Remove all but `master` parameters to cppcheck (and remove second
|
|
|
|
# invocation) once all warnings of cppcheck have been taken care of
|
|
|
|
# in master.
|
2014-11-19 16:17:34 +01:00
|
|
|
- ./dist/tools/cppcheck/check.sh master --diff-filter=MR --error-exitcode=0 || exit
|
|
|
|
- ./dist/tools/cppcheck/check.sh master --diff-filter=AC || exit
|
2014-11-18 19:28:44 +01:00
|
|
|
|
2014-11-19 16:17:34 +01:00
|
|
|
- make -C ./tests/unittests all test BOARD=native || exit
|
|
|
|
- make -C ./tests/unittests all test BOARD=qemu-i386 || exit
|
2014-11-18 19:28:44 +01:00
|
|
|
|
|
|
|
- ./dist/tools/compile_test/compile_test.py
|
2014-11-26 11:12:46 +01:00
|
|
|
- ./dist/tools/pr_check/pr_check.sh riot/master
|
2014-04-11 17:06:25 +02:00
|
|
|
|
|
|
|
notifications:
|
|
|
|
email: false
|