summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2017-11-08 06:43:38 -0800
committerGravatar Dirk Hohndel <dirk@hohndel.org>2017-11-09 16:21:46 -0800
commit96a3dd0001747b9acb6c72622b80b84c6f73f50b (patch)
tree535ffbd3733eaceefb8bdb0a1cf9e0c12a737459
parentf16a488b89676817f384ac99d5b2232a511e1b6d (diff)
downloadsubsurface-96a3dd0001747b9acb6c72622b80b84c6f73f50b.tar.gz
Travis: start restructuring the build process
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--.travis.yml46
-rw-r--r--scripts/linux/travisbuild.sh50
2 files changed, 61 insertions, 35 deletions
diff --git a/.travis.yml b/.travis.yml
index 06a80febd..3bd09f5d3 100644
--- a/.travis.yml
+++ b/.travis.yml
@@ -1,14 +1,14 @@
-language: c++
-sudo: true # for FUSE
-dist: trusty
-# cache:
-# directories:
-# - Qt
-
-addons:
- apt:
- packages:
+matrix:
+ include:
+ - env: SUBSURFACE_PLATFORM='linux'
+ os: linux
+ dist: trusty
+ sudo: required
+ language: c++
+ addons:
+ apt:
+ packages:
- git
- g++
- make
@@ -45,31 +45,7 @@ before_install:
- "sh -e /etc/init.d/xvfb start"
script:
- - export QT_ROOT=$PWD/Qt
- - export PATH=$QT_ROOT/5.9.1/bin:$PATH # Make sure correct qmake is found on the $PATH for linuxdeployqt
- - export CMAKE_PREFIX_PATH=$QT_ROOT/5.9.1/lib/cmake ;
- cd .. ;
- bash -e ./subsurface/scripts/build.sh -desktop -create-appdir -build-with-webkit
- - export QT_PLUGIN_PATH=$QT_ROOT/5.9.1/plugins
- - export QT_QPA_PLATFORM_PLUGIN_PATH=$QT_ROOT/5.9.1/plugins
- - export QT_DEBUG_PLUGINS=1
- - find $QT_ROOT/5.9.1/plugins
- - env CTEST_OUTPUT_ON_FAILURE=1 make -C subsurface/build check
- - # env CTEST_OUTPUT_ON_FAILURE=1 make -C subsurface/build-mobile check
- - mkdir -p appdir/usr/plugins/ ; mv appdir/usr/home/travis/build/*/subsurface/Qt/5.9.1/plugins/* appdir/usr/plugins/
- - mv appdir/usr/lib/grantlee/ appdir/usr/plugins/
- - sudo mv appdir/usr/lib/* /usr/local/lib/ # Workaround for https://github.com/probonopd/linuxdeployqt/issues/160
- - rm -rf appdir/usr/home/ appdir/usr/include/ appdir/usr/share/man/ # No need to ship developer and man files as part of the AppImage
- - wget -c "https://github.com/probonopd/linuxdeployqt/releases/download/continuous/linuxdeployqt-continuous-x86_64.AppImage"
- - chmod a+x linuxdeployqt*.AppImage
- - unset QTDIR; unset QT_PLUGIN_PATH ; unset LD_LIBRARY_PATH
- - export LD_LIBRARY_PATH=/usr/local/lib/ # Workaround for https://github.com/probonopd/linuxdeployqt/issues/160
- - ./linuxdeployqt*.AppImage ./appdir/usr/share/applications/*.desktop -bundle-non-qt-libs -qmldir=./subsurface/map-widget/ -verbose=2
- - sed -i -e 's|/usr/lib/x86_64-linux-gnu|/usr/lib/x86_64-linux-xxx|g' ./appdir/usr/lib/libgstreamer-1.0.so.0
- - export VERSION=$(cd subsurface/ ; git rev-parse --short HEAD) # linuxdeployqt uses this for naming the file
- - ./linuxdeployqt*.AppImage ./appdir/usr/share/applications/*.desktop -appimage -qmldir=./subsurface/map-widget/ -verbose=2
- - find ./appdir -executable -type f -exec ldd {} \; | grep " => /usr" | cut -d " " -f 2-3 | sort | uniq
- - curl --upload-file ./Subsurface*.AppImage https://transfer.sh/Subsurface-$VERSION-x86_64.AppImage
+ - source scripts/${SUBSURFACE_PLATFORM}/travisbuild.sh
after_success:
- ls -lh Subsurface*.AppImage
diff --git a/scripts/linux/travisbuild.sh b/scripts/linux/travisbuild.sh
new file mode 100644
index 000000000..7303897ff
--- /dev/null
+++ b/scripts/linux/travisbuild.sh
@@ -0,0 +1,50 @@
+
+#!/bin/bash
+
+# this gets executed by Travis when building an AppImage for Linux
+# it gets started from inside the subsurface directory
+
+export QT_ROOT=$PWD/Qt
+export PATH=$QT_ROOT/5.9.1/bin:$PATH # Make sure correct qmake is found on the $PATH for linuxdeployqt
+export CMAKE_PREFIX_PATH=$QT_ROOT/5.9.1/lib/cmake
+
+# the global build script expects to be called from the directory ABOVE subsurface
+cd ..
+bash -e ./subsurface/scripts/build.sh -desktop -create-appdir -build-with-webkit # we need to build 'both' and need to build without BT and other variations that we want to exercise
+
+export QT_PLUGIN_PATH=$QT_ROOT/5.9.1/plugins
+export QT_QPA_PLATFORM_PLUGIN_PATH=$QT_ROOT/5.9.1/plugins
+export QT_DEBUG_PLUGINS=1
+
+# for debugging: find $QT_ROOT/5.9.1/plugins
+
+env CTEST_OUTPUT_ON_FAILURE=1 make -C subsurface/build check
+
+# set up the appdir
+mkdir -p appdir/usr/plugins/
+mv appdir/usr/home/travis/build/*/subsurface/Qt/5.9.1/plugins/* appdir/usr/plugins/
+mv appdir/usr/lib/grantlee/ appdir/usr/plugins/
+sudo mv appdir/usr/lib/* /usr/local/lib/ # Workaround for https://github.com/probonopd/linuxdeployqt/issues/160
+rm -rf appdir/usr/home/ appdir/usr/include/ appdir/usr/share/man/ # No need to ship developer and man files as part of the AppImage
+
+# get the linuxdeployqt tool and run it to collect the libraries
+wget -c "https://github.com/probonopd/linuxdeployqt/releases/download/continuous/linuxdeployqt-continuous-x86_64.AppImage"
+chmod a+x linuxdeployqt*.AppImage
+unset QTDIR
+unset QT_PLUGIN_PATH
+unset LD_LIBRARY_PATH
+export LD_LIBRARY_PATH=/usr/local/lib/ # Workaround for https://github.com/probonopd/linuxdeployqt/issues/160
+./linuxdeployqt*.AppImage ./appdir/usr/share/applications/*.desktop -bundle-non-qt-libs -qmldir=./subsurface/map-widget/ -verbose=2
+
+# hack around the gstreamer plugins - this should be fixed with better Qt package
+sed -i -e 's|/usr/lib/x86_64-linux-gnu|/usr/lib/x86_64-linux-xxx|g' ./appdir/usr/lib/libgstreamer-1.0.so.0
+
+# create the AppImage
+export VERSION=$(cd subsurface/ ; git rev-parse --short HEAD) # linuxdeployqt uses this for naming the file
+./linuxdeployqt*.AppImage ./appdir/usr/share/applications/*.desktop -appimage -qmldir=./subsurface/map-widget/ -verbose=2
+find ./appdir -executable -type f -exec ldd {} \; | grep " => /usr" | cut -d " " -f 2-3 | sort | uniq
+
+# this shouldn't be in the build, but hey, this ensures that we can always
+# get to the artifact
+curl --upload-file ./Subsurface*.AppImage https://transfer.sh/Subsurface-$VERSION-x86_64.AppImage
+