3 # Copyright © 2015-2016 Collabora Ltd.
5 # Permission is hereby granted, free of charge, to any person
6 # obtaining a copy of this software and associated documentation files
7 # (the "Software"), to deal in the Software without restriction,
8 # including without limitation the rights to use, copy, modify, merge,
9 # publish, distribute, sublicense, and/or sell copies of the Software,
10 # and to permit persons to whom the Software is furnished to do so,
11 # subject to the following conditions:
13 # The above copyright notice and this permission notice shall be
14 # included in all copies or substantial portions of the Software.
16 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17 # EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18 # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19 # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
20 # BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
21 # ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
22 # CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
31 # OS distribution in which we are testing
32 # Typical values: ubuntu, debian; maybe fedora in future
33 : "${ci_distro:=ubuntu}"
36 # If non-empty, this is the name of a Docker image. ci-install.sh will
37 # fetch it with "docker pull" and use it as a base for a new Docker image
38 # named "ci-image" in which we will do our testing.
42 # Either "native", or an Autoconf --host argument to cross-compile
44 : "${ci_host:=native}"
47 # Used internally by ci-install.sh. If yes, we are inside the Docker image
48 # (ci_docker is empty in this case).
49 : "${ci_in_docker:=no}"
52 # prefer local packages instead of distribution
53 : "${ci_local_packages:=yes}"
56 # OS suite (release, branch) in which we are testing.
57 # Typical values for ci_distro=debian: sid, bullseye
58 # Typical values for ci_distro=fedora might be 25, rawhide
59 : "${ci_suite:=bullseye}"
62 # One of debug, reduced, legacy, production
63 : "${ci_variant:=production}"
65 if [ $(id -u) = 0 ]; then
71 if [ -n "$ci_docker" ]; then
73 -e "s/@ci_distro@/${ci_distro}/" \
74 -e "s/@ci_docker@/${ci_docker}/" \
75 -e "s/@ci_suite@/${ci_suite}/" \
76 < tools/ci-Dockerfile.in > Dockerfile
77 exec docker build -t ci-image .
82 # Don't ask questions, just do it
83 sudo="$sudo env DEBIAN_FRONTEND=noninteractive"
85 # Debian Docker images use httpredir.debian.org but it seems to be
86 # unreliable; use a CDN instead
87 $sudo sed -i -e 's/httpredir\.debian\.org/deb.debian.org/g' \
92 $sudo dpkg --add-architecture i386
95 # assume the host or container is x86_64 already
99 $sudo apt-get -qq -y update
106 binutils-mingw-w64-i686
114 binutils-mingw-w64-x86-64
121 if [ "$ci_host/$ci_variant/$ci_suite" = "native/production/buster" ]; then
148 gnome-desktop-testing
171 $sudo apt-get -qq -y --no-install-recommends install "${packages[@]}"
173 if [ "$ci_in_docker" = yes ]; then
174 # Add the user that we will use to do the build inside the
175 # Docker container, and let them use sudo
176 adduser --disabled-password --gecos "" user
177 echo "user ALL=(ALL) NOPASSWD: ALL" > /etc/sudoers.d/nopasswd
178 chmod 0440 /etc/sudoers.d/nopasswd
181 # Make sure we have a messagebus user, even if the dbus package
183 $sudo adduser --system --quiet --home /nonexistent --no-create-home \
184 --disabled-password --group messagebus
188 echo "Don't know how to set up ${ci_distro}" >&2
193 if [ "$ci_local_packages" = yes ]; then
197 mirror="https://repo.msys2.org/mingw/$cpu"
198 dep_prefix=$(pwd)/${ci_host}-prefix
199 # clean install dir, if present
201 install -d "${dep_prefix}"
202 wget -O files.lst ${mirror}
203 sed 's,^<a href=",,g;s,">.*$,,g' files.lst | grep -v "\.db" | grep -v "\.files" | grep ".*zst$" | sort > filenames.lst
218 for pkg in "${packages[@]}" ; do
219 filename=$(grep -F "mingw-w64-${cpu}-${pkg}-" filenames.lst | tail -1)
220 if [ -z ${filename} ]; then
221 echo "could not find filename for package '${pkg}'"
224 # Remove previously downloaded file, which can happen
226 if [ -f ${filename} ]; then
229 wget ${mirror}/${filename}
230 tar -C ${dep_prefix} --strip-components=1 -xvf ${filename}
233 # limit access rights
234 if [ "$ci_in_docker" = yes ]; then
235 chown -R user "${dep_prefix}"
241 # vim:set sw=4 sts=4 et: