mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 14:38:30 -04:00
travis: use container infrastructure
In order to use the container infrastructure we can't use sudo to install packages. Now Travis has a way to install packages by specifying them in the .travis.yml. This greatly simplifies how we install the packages and there's no need for a separate script anymore. This also removes several outdated packages that aren't needed anymore.
This commit is contained in:
parent
b7f3782e4e
commit
17d9da4036
49
.travis.yml
49
.travis.yml
@ -1,8 +1,43 @@
|
||||
language: cpp
|
||||
sudo: required
|
||||
sudo: false
|
||||
|
||||
addons:
|
||||
apt:
|
||||
sources:
|
||||
- ubuntu-toolchain-r-test
|
||||
packages:
|
||||
- build-essential
|
||||
- g++-4.8
|
||||
- gcc-4.8
|
||||
- genromfs
|
||||
- libc6-i386
|
||||
- python-argparse
|
||||
- python-empy
|
||||
- python-serial
|
||||
- zlib1g-dev
|
||||
coverity_scan:
|
||||
project:
|
||||
name: "diydrones/ardupilot"
|
||||
description: "Build submitted via Travis CI"
|
||||
notification_email: andrew-scan@tridgell.net
|
||||
build_command_prepend: "make clean"
|
||||
build_command: "make"
|
||||
branch_pattern: coverity_scan
|
||||
|
||||
before_install:
|
||||
- APMDIR=$(pwd) && pushd .. && $APMDIR/Tools/scripts/install-travis-env.sh -y && . ~/.profile && popd
|
||||
- pushd .
|
||||
&& cd ~
|
||||
&& wget http://firmware.diydrones.com/Tools/PX4-tools/gcc-arm-none-eabi-4_9-2015q3-20150921-linux.tar.bz2
|
||||
&& tar -xf gcc-arm-none-eabi-4_9-2015q3-20150921-linux.tar.bz2
|
||||
&& wget http://firmware.diydrones.com/Tools/Travis/NavIO/master.tar.gz
|
||||
&& tar -xf master.tar.gz
|
||||
&& mkdir -p $HOME/bin
|
||||
&& ln -sf /usr/bin/gcc-4.8 $HOME/bin/gcc
|
||||
&& ln -sf /usr/bin/g++-4.8 $HOME/bin/g++
|
||||
&& exportline="export PATH=$HOME/bin:$HOME/gcc-arm-none-eabi-4_9-2015q3/bin:$HOME/tools-master/arm-bcm2708/gcc-linaro-arm-linux-gnueabihf-raspbian-x64/bin:\$PATH"
|
||||
&& if grep -Fxq "$exportline" ~/.profile; then echo nothing to do ; else echo $exportline >> ~/.profile; fi
|
||||
&& . ~/.profile
|
||||
&& popd
|
||||
|
||||
script:
|
||||
- Tools/scripts/build_all_travis.sh
|
||||
@ -23,13 +58,3 @@ env:
|
||||
matrix:
|
||||
- TRAVIS_BUILD_TARGET="px4-v2"
|
||||
- TRAVIS_BUILD_TARGET="sitl linux navio raspilot minlure"
|
||||
|
||||
addons:
|
||||
coverity_scan:
|
||||
project:
|
||||
name: "diydrones/ardupilot"
|
||||
description: "Build submitted via Travis CI"
|
||||
notification_email: andrew-scan@tridgell.net
|
||||
build_command_prepend: "make clean"
|
||||
build_command: "make"
|
||||
branch_pattern: coverity_scan
|
||||
|
@ -3,10 +3,7 @@
|
||||
# This helps when doing large merges
|
||||
# Andrew Tridgell, November 2011
|
||||
|
||||
. config.mk
|
||||
|
||||
set -e
|
||||
set -x
|
||||
set -ex
|
||||
|
||||
. ~/.profile
|
||||
|
||||
|
@ -1,103 +0,0 @@
|
||||
#!/bin/bash
|
||||
# install dependencies for travis build testing
|
||||
|
||||
set -e
|
||||
set -v
|
||||
|
||||
CWD=$(pwd)
|
||||
OPT="$HOME/opt"
|
||||
echo "PATH=$PATH"
|
||||
|
||||
BASE_PKGS="gawk make git arduino-core curl"
|
||||
SITL_PKGS="g++ python-pip python-matplotlib python-serial python-wxgtk2.8 python-scipy python-opencv python-numpy python-pyparsing ccache python-empy"
|
||||
PYTHON_PKGS="pymavlink MAVProxy catkin_pkg"
|
||||
PX4_PKGS="python-serial python-argparse openocd flex bison libncurses5-dev \
|
||||
autoconf texinfo build-essential libftdi-dev libtool zlib1g-dev \
|
||||
zip genromfs"
|
||||
UBUNTU64_PKGS="libc6:i386 libgcc1:i386 gcc-4.6-base:i386 libstdc++5:i386 libstdc++6:i386 gcc-multilib"
|
||||
|
||||
# GNU Tools for ARM Embedded Processors
|
||||
# (see https://launchpad.net/gcc-arm-embedded/)
|
||||
ARM_ROOT="gcc-arm-none-eabi-4_9-2015q3"
|
||||
ARM_TARBALL="$ARM_ROOT-20150921-linux.tar.bz2"
|
||||
ARM_TARBALL_URL="http://firmware.diydrones.com/Tools/PX4-tools/$ARM_TARBALL"
|
||||
|
||||
RPI_ROOT="master"
|
||||
RPI_TARBALL="$RPI_ROOT.tar.gz"
|
||||
RPI_TARBALL_URL="http://firmware.diydrones.com/Tools/Travis/NavIO/$RPI_TARBALL"
|
||||
|
||||
# Ardupilot Tools
|
||||
ARDUPILOT_TOOLS="ardupilot/Tools/autotest"
|
||||
|
||||
APT_GET="sudo apt-get -qq --assume-yes"
|
||||
|
||||
$APT_GET update
|
||||
$APT_GET install $BASE_PKGS $SITL_PKGS $PX4_PKGS $UBUNTU64_PKGS
|
||||
sudo pip install --upgrade pip || {
|
||||
echo "pip upgrade failed"
|
||||
}
|
||||
sudo pip install --upgrade setuptools || {
|
||||
echo "setuptools upgrade failed"
|
||||
}
|
||||
for pkg in $PYTHON_PKGS; do
|
||||
echo "Installing $pkg"
|
||||
sudo pip -q install $pkg || echo "FAILED INSTALL OF $pkg"
|
||||
done
|
||||
|
||||
# install some extra packages (for later AVR compiler)
|
||||
rsync -av firmware.diydrones.com::Tools/Travis/*.deb ExtraPackages
|
||||
sudo dpkg -i ExtraPackages/*.deb || echo "FAILED INSTALL OF EXTRA DEBS"
|
||||
|
||||
# try to upgrade to g++ 4.8. See https://github.com/travis-ci/travis-ci/issues/1379
|
||||
(sudo add-apt-repository -y ppa:ubuntu-toolchain-r/test &&
|
||||
sudo apt-get -qq update &&
|
||||
sudo apt-get -qq install g++-4.8 &&
|
||||
sudo update-alternatives --install /usr/bin/g++ g++ /usr/bin/g++-4.8 90) || {
|
||||
echo "upgrade to gcc 4.8 failed"
|
||||
}
|
||||
|
||||
|
||||
if [ ! -d PX4Firmware ]; then
|
||||
git clone https://github.com/diydrones/PX4Firmware.git
|
||||
fi
|
||||
|
||||
if [ ! -d PX4NuttX ]; then
|
||||
git clone https://github.com/diydrones/PX4NuttX.git
|
||||
fi
|
||||
|
||||
if [ ! -d uavcan ]; then
|
||||
git clone https://github.com/diydrones/uavcan.git
|
||||
fi
|
||||
|
||||
if [ ! -d VRNuttX ]; then
|
||||
git clone https://github.com/virtualrobotix/vrbrain_nuttx.git VRNuttX
|
||||
fi
|
||||
|
||||
mkdir -p $OPT
|
||||
|
||||
cd $OPT
|
||||
wget $ARM_TARBALL_URL
|
||||
tar xjf ${ARM_TARBALL}
|
||||
rm -f ${ARM_TARBALL}
|
||||
|
||||
cd $OPT
|
||||
wget $RPI_TARBALL_URL
|
||||
tar xzf ${RPI_TARBALL}
|
||||
rm -f ${RPI_TARBALL}
|
||||
|
||||
exportline="export PATH=$OPT/$ARM_ROOT/bin:\$PATH";
|
||||
echo $exportline >> ~/.profile
|
||||
|
||||
exportline2="export PATH=$CWD/$ARDUPILOT_TOOLS:\$PATH";
|
||||
echo $exportline2 >> ~/.profile
|
||||
|
||||
exportline3="export PATH=$OPT/tools-master/arm-bcm2708/gcc-linaro-arm-linux-gnueabihf-raspbian-x64/bin:\$PATH";
|
||||
echo $exportline3 >> ~/.profile
|
||||
|
||||
. ~/.profile
|
||||
echo $PATH
|
||||
ls -l $OPT/$ARM_ROOT/bin
|
||||
$OPT/$ARM_ROOT/bin/arm-none-eabi-gcc --version
|
||||
|
||||
echo "Compiler for NavIO"
|
||||
arm-linux-gnueabihf-gcc --version
|
Loading…
Reference in New Issue
Block a user