aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKitsune Ral <Kitsune-Ral@users.sf.net>2020-06-09 15:09:37 +0200
committerKitsune Ral <Kitsune-Ral@users.sf.net>2020-06-10 22:21:08 +0200
commit4237a138f9ad1baa7384f3a539e9343a1471b538 (patch)
tree89c2d27030c200c216e30bb45dd853dc53bda105
parent1293972514b10cd7a5ca6435646c496bb427e305 (diff)
downloadlibquotient-4237a138f9ad1baa7384f3a539e9343a1471b538.tar.gz
libquotient-4237a138f9ad1baa7384f3a539e9343a1471b538.zip
CI: test more configurations
-rw-r--r--.appveyor.yml22
-rw-r--r--.travis.yml43
2 files changed, 46 insertions, 19 deletions
diff --git a/.appveyor.yml b/.appveyor.yml
index 13991ada..764d56d6 100644
--- a/.appveyor.yml
+++ b/.appveyor.yml
@@ -3,12 +3,22 @@ image: Visual Studio 2017
environment:
CMAKE_ARGS: '-G "NMake Makefiles JOM" -DBUILD_SHARED_LIBS=OFF -DCMAKE_BUILD_TYPE=RelWithDebInfo'
matrix:
- - QTDIR: C:\Qt\5.13\msvc2017_64
- VCVARS: "vcvars64.bat"
- PLATFORM:
- - QTDIR: C:\Qt\5.13\msvc2017
+ - QTDIR: C:\Qt\5.13\msvc2017 # Fresh Qt, 32-bit
VCVARS: "vcvars32.bat"
PLATFORM: x86
+ - QTDIR: C:\Qt\5.13\msvc2017_64 # Fresh Qt, 64-bit
+ VCVARS: "vcvars64.bat"
+ PLATFORM:
+ - QTDIR: C:\Qt\5.9\msvc2017_64 # Oldest supported Qt, 64-bit, E2EE
+ VCVARS: "vcvars64.bat"
+ QMAKE_E2EE_ARGS: '"DEFINES += Quotient_E2EE_ENABLED USE_INTREE_LIBQOLM" "INCLUDEPATH += olm/include" "LIBS += -Lbuild/olm"'
+ CMAKE_E2EE_ARGS: '-DQuotient_ENABLE_E2EE=ON -DOlm_DIR=build/olm'
+ PLATFORM:
+ - QTDIR: C:\Qt\5.13\msvc2017_64 # Fresh Qt, 64-bit, E2EE
+ VCVARS: "vcvars64.bat"
+ QMAKE_E2EE_ARGS: '"DEFINES += Quotient_E2EE_ENABLED USE_INTREE_LIBQOLM" "INCLUDEPATH += olm/include" "LIBS += -Lbuild/olm"'
+ CMAKE_E2EE_ARGS: '-DQuotient_ENABLE_E2EE=ON -DOlm_DIR=build/olm'
+ PLATFORM:
init:
- call "%QTDIR%\bin\qtenv2.bat"
@@ -23,10 +33,10 @@ before_build:
- cmake --build build/olm
build_script:
-- cmake %CMAKE_ARGS% -H. -Bbuild "-DOlm_DIR=build/olm"
+- cmake %CMAKE_ARGS% %CMAKE_E2EE_ARGS% -H. -Bbuild
- cmake --build build
# qmake uses olm just built by CMake - it can't build olm on its own.
-- qmake "INCLUDEPATH += olm/include" "LIBS += -Lbuild" "LIBS += -Lbuild/olm" && jom
+- qmake -Wall quotest.pro -- %QMAKE_E2EE_ARGS% && jom
#after_build:
#- cmake --build build --target install
diff --git a/.travis.yml b/.travis.yml
index d1a62c7f..9982be30 100644
--- a/.travis.yml
+++ b/.travis.yml
@@ -19,18 +19,15 @@ env:
- CMAKE_ARGS="-DCMAKE_BUILD_TYPE=RelWithDebInfo -DCMAKE_INSTALL_PREFIX=/usr -DCMAKE_PREFIX_PATH=$DESTDIR/usr"
- VALGRIND="valgrind --tool=memcheck --leak-check=yes --gen-suppressions=all --suppressions=tests/.valgrind.supp $VALGRIND_OPTIONS"
-matrix:
+matrix: # TODO: consider parallel execution, this thing takes an hour to run
include:
- os: linux
compiler: gcc
- os: linux
- compiler: gcc
- env: [ 'E2EE="-DQuotient_ENABLE_E2EE=ON"', 'UPDATE_API=1' ]
- - os: linux
compiler: clang
- os: osx
osx_image: xcode10.1
- env: [ 'PATH=/usr/local/opt/qt/bin:$PATH', 'VALGRIND=' ]
+ env: [ 'E2EE=1', 'VALGRIND=' ]
addons:
homebrew:
update: true
@@ -41,15 +38,32 @@ matrix:
cache:
directories:
- $HOME/Library/Caches/Homebrew
+ # Check a few more advanced configurations
+ - os: linux
+ compiler: gcc
+ env: [ E2EE=1, UPDATE_API=1 ] # Check UPDATE_API with one of fatter options
+ - os: linux
+ compiler: clang
+ env: [ E2EE=1 ]
+ - os: linux
+ compiler: gcc
+ env: [ E2EE=1 ]
before_install:
- if [ -f "$(which ninja)" ]; then export CMAKE_ARGS="$CMAKE_ARGS -GNinja"; fi
+- if [ "$TRAVIS_OS_NAME" = "osx" ]; then export PATH=/usr/local/opt/qt/bin:$PATH; fi
# The recent GTAD uses std::filesystem that's not available in stock bionic
- |
if [ -n "$UPDATE_API" ]; then
export CC=gcc-8 CXX=g++-8
export CMAKE_UPDATE_API_ARGS="-DMATRIX_DOC_PATH=../matrix-doc -DGTAD_PATH=../gtad/gtad"
fi
+- |
+ if [ -n "$E2EE" ]; then
+ export CMAKE_E2EE_ARGS="-DQuotient_ENABLE_E2EE=ON"
+ export QMAKE_E2EE_ARGS='"DEFINES += Quotient_E2EE_ENABLED USE_INTREE_LIBQOLM" "INCLUDEPATH += olm/include" "LIBS += -Lolm/build"'
+ export LIB_PATH_E2EE=olm/build
+ fi
# RPM spec-style: swallow a command with default parameters into an alias
# and add/override parameters further in the code if/as necessary
- shopt -s expand_aliases
@@ -58,11 +72,14 @@ before_install:
install:
- pushd .. # Go out of libQuotient source tree
-- git clone https://gitlab.matrix.org/matrix-org/olm.git
-- pushd olm
-- _cmake_config
-- _cmake_build --target install
-- popd
+- |
+ if [ -n "$E2EE" ]; then
+ git clone https://gitlab.matrix.org/matrix-org/olm.git
+ pushd olm
+ _cmake_config
+ _cmake_build --target install
+ popd
+ fi
- |
if [ -n "$UPDATE_API" ]; then
@@ -76,7 +93,7 @@ install:
- popd # back to libQuotient source tree
before_script:
-- _cmake_config $CMAKE_UPDATE_API_ARGS $E2EE
+- _cmake_config $CMAKE_UPDATE_API_ARGS $CMAKE_E2EE_ARGS
- if [ -n "$UPDATE_API" ]; then _cmake_build --target update-api; fi
script:
@@ -85,10 +102,10 @@ script:
- cmake $CMAKE_ARGS tests -Bbuild-test
- cmake --build build-test --target all
# Build with qmake
-- qmake quotest.pro "CONFIG += debug" "CONFIG -= app_bundle" "QMAKE_CC = $CC" "QMAKE_CXX = $CXX" "INCLUDEPATH += olm/include" "LIBS += -Lbuild/lib" "LIBS += -Lolm/build"
+- qmake -Wall quotest.pro "CONFIG += debug" "CONFIG -= app_bundle" "QMAKE_CC = $CC" "QMAKE_CXX = $CXX" -- $QMAKE_E2EE_ARGS
- make all
# Run the qmake-compiled quotest under valgrind
-- if [ "$TEST_USER" != "" ]; then LD_LIBRARY_PATH="olm/build" $VALGRIND ./quotest "$TEST_USER" "$TEST_PWD" quotest-travis '#quotest:matrix.org' "Travis CI job $TRAVIS_JOB_NUMBER"; fi
+- if [ "$TEST_USER" != "" ]; then LD_LIBRARY_PATH="$LIB_PATH_E2EE" $VALGRIND ./quotest "$TEST_USER" "$TEST_PWD" quotest-travis '#quotest:matrix.org' "Travis CI job $TRAVIS_JOB_NUMBER"; fi
notifications:
webhooks: