#!/bin/bash # Copyright © 2015-2016 Collabora Ltd. # # Permission is hereby granted, free of charge, to any person # obtaining a copy of this software and associated documentation files # (the "Software"), to deal in the Software without restriction, # including without limitation the rights to use, copy, modify, merge, # publish, distribute, sublicense, and/or sell copies of the Software, # and to permit persons to whom the Software is furnished to do so, # subject to the following conditions: # # The above copyright notice and this permission notice shall be # included in all copies or substantial portions of the Software. # # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, # EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS # BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN # ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN # CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE # SOFTWARE. set -euo pipefail set -x NULL= # ci_distro: # OS distribution in which we are testing # Typical values: ubuntu, debian; maybe fedora in future : "${ci_distro:=ubuntu}" # ci_docker: # If non-empty, this is the name of a Docker image. ci-install.sh will # fetch it with "docker pull" and use it as a base for a new Docker image # named "ci-image" in which we will do our testing. : "${ci_docker:=}" # ci_host: # Either "native", or an Autoconf --host argument to cross-compile # the package : "${ci_host:=native}" # ci_in_docker: # Used internally by ci-install.sh. If yes, we are inside the Docker image # (ci_docker is empty in this case). : "${ci_in_docker:=no}" # ci_suite: # OS suite (release, branch) in which we are testing. # Typical values for ci_distro=debian: sid, jessie # Typical values for ci_distro=fedora might be 25, rawhide : "${ci_suite:=trusty}" if [ $(id -u) = 0 ]; then sudo= else sudo=sudo fi if [ -n "$ci_docker" ]; then sed \ -e "s/@ci_distro@/${ci_distro}/" \ -e "s/@ci_docker@/${ci_docker}/" \ -e "s/@ci_suite@/${ci_suite}/" \ < tools/ci-Dockerfile.in > Dockerfile exec docker build -t ci-image . fi case "$ci_distro" in (debian|ubuntu) # Don't ask questions, just do it sudo="$sudo env DEBIAN_FRONTEND=noninteractive" # Debian Docker images use httpredir.debian.org but it seems to be # unreliable; use a CDN instead $sudo sed -i -e 's/httpredir\.debian\.org/deb.debian.org/g' \ /etc/apt/sources.list # travis-ci has a sources list for Chrome which doesn't support i386 : | $sudo tee /etc/apt/sources.list.d/google-chrome.list if [ "$ci_host" = mingw ]; then $sudo dpkg --add-architecture i386 fi $sudo apt-get -qq -y update if [ "$ci_host" = mingw ]; then $sudo apt-get -qq -y install \ binutils-mingw-w64-i686 \ g++-mingw-w64-i686 \ wine:i386 \ ${NULL} fi $sudo apt-get -qq -y install \ autoconf-archive \ automake \ autotools-dev \ debhelper \ dh-autoreconf \ dh-exec \ doxygen \ dpkg-dev \ gnome-desktop-testing \ libapparmor-dev \ libaudit-dev \ libcap-ng-dev \ libexpat-dev \ libglib2.0-dev \ libselinux1-dev \ libx11-dev \ python \ python-dbus \ python-gi \ valgrind \ wget \ xauth \ xmlto \ xsltproc \ xvfb \ ${NULL} case "$ci_suite" in (trusty) $sudo apt-get -qq -y install libsystemd-daemon-dev ;; (*) $sudo apt-get -qq -y install libsystemd-dev ;; esac if [ "$ci_in_docker" = yes ]; then # Add the user that we will use to do the build inside the # Docker container, and let them use sudo adduser --disabled-password user /etc/sudoers.d/nopasswd chmod 0440 /etc/sudoers.d/nopasswd fi case "$ci_suite" in (trusty|jessie) # Ubuntu 14.04's autoconf-archive is too old wget http://deb.debian.org/debian/pool/main/a/autoconf-archive/autoconf-archive_20160916-1_all.deb $sudo dpkg -i autoconf-archive_*_all.deb rm autoconf-archive_*_all.deb ;; esac ;; (*) echo "Don't know how to set up ${ci_distro}" >&2 exit 1 ;; esac # vim:set sw=4 sts=4 et: