mirror of
https://github.com/OpenVPN/openvpn.git
synced 2026-04-21 06:07:32 -04:00
travis-ci: add arm64, s390x builds.
as described on https://docs.travis-ci.com/user/multi-cpu-architectures travis-ci now supports amd64, ppcle, arm64, s390 architectures. Add arm64 and s390x. travis-ci images were upgraded to bionic. "sudo" is deprecated, let us remove it, also "matrix" is deprecated in favour of "jobs". LD_LIBRARY_PATH was replaced by using "rpath" in LDFLAGS, which is more elegant way of linking. also, dependencies were upgraded to the latest versions. travis_wait was added for long openssl builds. cmocka was added to linux and osx builds. Acked-by: Lev Stipakov <lstipakov@gmail.com> Message-Id: <20200322123521.17710-1-chipitsine@gmail.com> URL: https://www.mail-archive.com/openvpn-devel@lists.sourceforge.net/msg19574.html Signed-off-by: Gert Doering <gert@greenie.muc.de>
This commit is contained in:
parent
50d68142f0
commit
072f7d352d
4 changed files with 65 additions and 58 deletions
93
.travis.yml
93
.travis.yml
|
|
@ -1,5 +1,4 @@
|
|||
sudo: required
|
||||
dist: xenial
|
||||
dist: bionic
|
||||
|
||||
os: linux
|
||||
|
||||
|
|
@ -11,86 +10,111 @@ env:
|
|||
- PREFIX="${HOME}/opt"
|
||||
- TAP_WINDOWS_VERSION=9.23.3
|
||||
- LZO_VERSION=2.10
|
||||
- PKCS11_HELPER_VERSION=1.25.1
|
||||
- MBEDTLS_VERSION=2.16.1
|
||||
- PKCS11_HELPER_VERSION=1.26
|
||||
- MBEDTLS_VERSION=2.16.4
|
||||
- MBEDTLS_CFLAGS="-I${PREFIX}/include"
|
||||
- MBEDTLS_LIBS="-L${PREFIX}/lib -lmbedtls -lmbedx509 -lmbedcrypto"
|
||||
- OPENSSL_VERSION=1.0.2s
|
||||
- OPENSSL_VERSION=1.0.2u
|
||||
- OPENSSL_CFLAGS="-I${PREFIX}/include"
|
||||
- OPENSSL_LIBS="-L${PREFIX}/lib -lssl -lcrypto"
|
||||
# The next declaration is the encrypted COVERITY_SCAN_TOKEN, created
|
||||
# via the "travis encrypt" command using the project repo's public key
|
||||
- secure: "l9mSnEW4LJqjxftH5i1NdDaYfGmQB1mPXnSB3DXnsjzkCWZ+yJLfBemfQ0tx/wS7chBYxqUaUIMT0hw4zJVp/LANFJo2vfh//ymTS6h0uApRY1ofg9Pp1BFcV1laG6/u8pwSZ2EBy/GhCd3DS436oE8sYBRaFM9FU62L/oeQBfJ7r4ID/0eB1b8bqlbD4paty9MHui2P8EZJwR+KAD84prtfpZOcrSMxPh9OUhJxzxUvvVoP4s4+lZ5Kgg1bBQ3yzKGDqe8VOgK2BWCEuezqhMMc8oeKmAe7CUkoz5gsGYH++k3I9XzP9Z4xeJKoQnC/82qi4xkJmlaOxdionej9bHIcjfRt7D8j1J0U+wOj4p8VrDy7yHaxuN2fi0K5MGa/CaXQSrkna8dePniCng+xQ2MY/zxuRX2gA6xPNLUyQLU9LqIug7wj4z84Hk9iWib4L20MoPjeEo+vAUNq8FtjOPxMuHNpv4iGGx6kgJm7RXl5vC5hxfK6MprrnYe2U5Mcd8jpzagKBaKHL3zV2FxX9k0jRO9Mccz7M2WnaV0MQ6zcngzTN4+s0kCjhfGKd2F2ANT2Gkhj3Me36eNHfuE0dBbvYCMh4b3Mgd7b/OuXwQWdJ8PjJ1WHXjSOw5sHw1suaV6cEO2Meyz5j1tOkyOi0M9QF+LFenQ9vLH4sBCww8U="
|
||||
|
||||
matrix:
|
||||
jobs:
|
||||
include:
|
||||
- env:
|
||||
- name: cl
|
||||
env:
|
||||
- SSLLIB="openssl"
|
||||
- OPENSSL_VERSION="1.1.1d"
|
||||
- P7Z="c:\Program Files\7-Zip\7z.exe"
|
||||
- CC="cl"
|
||||
os: windows
|
||||
compiler: cl
|
||||
- env: SSLLIB="openssl" RUN_COVERITY="1"
|
||||
- name: Coverity scan
|
||||
env: SSLLIB="openssl" RUN_COVERITY="1"
|
||||
os: linux
|
||||
compiler: gcc
|
||||
- env: SSLLIB="openssl" OPENSSL_VERSION="1.0.1u"
|
||||
- name: gcc | openssl-1.0.1u
|
||||
env: SSLLIB="openssl" OPENSSL_VERSION="1.0.1u"
|
||||
os: linux
|
||||
compiler: gcc
|
||||
- env: SSLLIB="openssl" OPENSSL_VERSION="1.1.1c"
|
||||
- name: gcc | openssl-1.1.1d
|
||||
env: SSLLIB="openssl" OPENSSL_VERSION="1.1.1d"
|
||||
os: linux
|
||||
arch: amd64
|
||||
compiler: gcc
|
||||
- name: gcc | openssl-1.1.1d
|
||||
env: SSLLIB="openssl" OPENSSL_VERSION="1.1.1d"
|
||||
os: linux
|
||||
arch: ppc64le
|
||||
compiler: gcc
|
||||
- name: gcc | openssl-1.1.1d
|
||||
env: SSLLIB="openssl" OPENSSL_VERSION="1.1.1d"
|
||||
os: linux
|
||||
arch: arm64
|
||||
compiler: gcc
|
||||
- name: gcc | openssl-1.1.1d
|
||||
env: SSLLIB="openssl" OPENSSL_VERSION="1.1.1d"
|
||||
os: linux
|
||||
arch: s390x
|
||||
compiler: gcc
|
||||
- name: gcc | openssl-1.0.2u | iproute2
|
||||
env: SSLLIB="openssl" EXTRA_CONFIG="--enable-iproute2"
|
||||
os: linux
|
||||
compiler: gcc
|
||||
- env: SSLLIB="openssl" OPENSSL_VERSION="1.1.1c" LABEL="linux-ppc64le"
|
||||
os: linux-ppc64le
|
||||
compiler: gcc
|
||||
- env: SSLLIB="openssl" EXTRA_CONFIG="--enable-iproute2"
|
||||
os: linux
|
||||
compiler: gcc
|
||||
- env: SSLLIB="openssl" CFLAGS="-fsanitize=address" CC=clang-9
|
||||
- name: clang+asan | openssl-1.0.2u
|
||||
env: SSLLIB="openssl" CFLAGS="-fsanitize=address" CC=clang-9
|
||||
os: linux
|
||||
compiler: clang
|
||||
- env: SSLLIB="openssl" OPENSSL_VERSION="1.1.1c" CC=clang-9
|
||||
- name: clang | openssl-1.1.1d
|
||||
env: SSLLIB="openssl" OPENSSL_VERSION="1.1.1d" CC=clang-9
|
||||
os: linux
|
||||
compiler: clang
|
||||
- env: SSLLIB="mbedtls"
|
||||
- name: gcc | mbedtls
|
||||
env: SSLLIB="mbedtls"
|
||||
os: linux
|
||||
compiler: gcc
|
||||
- env: SSLLIB="mbedtls" CFLAGS="-fsanitize=address" CC=clang-9
|
||||
- name: clang+asan | mbedtls
|
||||
env: SSLLIB="mbedtls" CFLAGS="-fsanitize=address" CC=clang-9
|
||||
os: linux
|
||||
compiler: clang
|
||||
- env: SSLLIB="openssl"
|
||||
- name: clang | openssl-1.0.2u
|
||||
env: SSLLIB="openssl"
|
||||
os: osx
|
||||
compiler: clang
|
||||
- env: SSLLIB="mbedtls"
|
||||
- name: clang | mbedtls
|
||||
env: SSLLIB="mbedtls"
|
||||
os: osx
|
||||
compiler: clang
|
||||
- env: SSLLIB="openssl" CHOST=x86_64-w64-mingw32 OPENSSL_VERSION="1.0.1u"
|
||||
- name: mingw64 | openssl-1.0.1u
|
||||
env: SSLLIB="openssl" CHOST=x86_64-w64-mingw32 OPENSSL_VERSION="1.0.1u"
|
||||
os: linux
|
||||
compiler: ": Win64 build only"
|
||||
- env: SSLLIB="openssl" CHOST=x86_64-w64-mingw32 OPENSSL_VERSION="1.1.1c"
|
||||
- name: mingw64 | openssl-1.1.1d
|
||||
env: SSLLIB="openssl" CHOST=x86_64-w64-mingw32 OPENSSL_VERSION="1.1.1d"
|
||||
os: linux
|
||||
compiler: ": Win64 build only"
|
||||
- env: SSLLIB="openssl" CHOST=i686-w64-mingw32
|
||||
- name: mingw32 | openssl-1.0.2u
|
||||
env: SSLLIB="openssl" CHOST=i686-w64-mingw32
|
||||
os: linux
|
||||
compiler: ": Win32 build only"
|
||||
- env: SSLLIB="openssl" EXTRA_CONFIG="--disable-lzo" EXTRA_SCRIPT="make distcheck" CC=clang-9
|
||||
- name: clang | openssl-1.0.2u | disable-lzo | distcheck
|
||||
env: SSLLIB="openssl" EXTRA_CONFIG="--disable-lzo" EXTRA_SCRIPT="make distcheck" CC=clang-9
|
||||
os: linux
|
||||
compiler: clang
|
||||
- env: SSLLIB="openssl" EXTRA_CONFIG="--enable-small" CC=clang-9
|
||||
- name: clang | openssl-1.0.2u | enable-small
|
||||
env: SSLLIB="openssl" EXTRA_CONFIG="--enable-small" CC=clang-9
|
||||
os: linux
|
||||
compiler: clang
|
||||
|
||||
addons:
|
||||
apt:
|
||||
sources:
|
||||
- ubuntu-toolchain-r-test
|
||||
- sourceline: 'deb https://apt.llvm.org/xenial/ llvm-toolchain-xenial-9 main'
|
||||
key_url: 'https://apt.llvm.org/llvm-snapshot.gpg.key'
|
||||
update: true
|
||||
packages: [ liblzo2-dev, libpam0g-dev, liblz4-dev, linux-libc-dev, man2html, mingw-w64 ]
|
||||
packages: [ liblzo2-dev, libpam0g-dev, liblz4-dev, linux-libc-dev, man2html, mingw-w64, clang-9, libcmocka-dev ]
|
||||
homebrew:
|
||||
update: true
|
||||
packages: [ lzo ]
|
||||
packages: [ lzo, lz4, cmocka ]
|
||||
|
||||
cache:
|
||||
directories:
|
||||
|
|
@ -99,9 +123,8 @@ cache:
|
|||
- ${HOME}/Library/Caches/Homebrew
|
||||
|
||||
install:
|
||||
- if [ "$TRAVIS_OS_NAME" = "linux" ] && [ "$TRAVIS_CPU_ARCH" != "ppc64le" ]; then sudo apt-get install clang-9; fi
|
||||
- if [ ! -z "${CHOST}" ]; then unset CC; fi
|
||||
- .travis/run-build-deps.sh
|
||||
- travis_wait 30 bash -c '.travis/build-deps.sh > build-deps.log 2>&1' || (cat build-deps.log && exit 1)
|
||||
|
||||
before_script:
|
||||
- .travis/coverity.sh
|
||||
|
|
|
|||
|
|
@ -6,14 +6,6 @@ if [ "${TRAVIS_OS_NAME}" = "windows" ]; then
|
|||
MSBuild.exe openvpn.sln //p:Platform=x64 && exit 0
|
||||
fi
|
||||
|
||||
if [ "${TRAVIS_OS_NAME}" = "linux" ]; then
|
||||
export LD_LIBRARY_PATH="${PREFIX}/lib:${LD_LIBRARY_PATH:-}"
|
||||
fi
|
||||
|
||||
if [ "${TRAVIS_OS_NAME}" = "osx" ]; then
|
||||
export DYLD_LIBRARY_PATH="${PREFIX}/lib:${DYLD_LIBRARY_PATH:-}"
|
||||
fi
|
||||
|
||||
autoreconf -vi
|
||||
|
||||
if [ -z ${CHOST+x} ]; then
|
||||
|
|
@ -21,7 +13,7 @@ if [ -z ${CHOST+x} ]; then
|
|||
export EXTRA_CONFIG="${EXTRA_CONFIG:-} --enable-werror"
|
||||
fi
|
||||
./configure --with-crypto-library="${SSLLIB}" ${EXTRA_CONFIG:-} || (cat config.log && exit 1)
|
||||
make -j$JOBS
|
||||
make LDFLAGS="-Wl,-rpath,${PREFIX}/lib" -j$JOBS
|
||||
src/openvpn/openvpn --version || true
|
||||
if [ "${TRAVIS_OS_NAME}" = "linux" ]; then
|
||||
ldd src/openvpn/openvpn;
|
||||
|
|
|
|||
|
|
@ -44,17 +44,19 @@ build_lzo () {
|
|||
}
|
||||
|
||||
download_pkcs11_helper () {
|
||||
if [ ! -f "pkcs11-helper-${PKCS11_HELPER_VERSION}.tar.bz2" ]; then
|
||||
if [ ! -f "pkcs11-helper-${PKCS11_HELPER_VERSION}.tar.gz" ]; then
|
||||
wget -P download-cache/ \
|
||||
"https://github.com/OpenSC/pkcs11-helper/releases/download/pkcs11-helper-${PKCS11_HELPER_VERSION}/pkcs11-helper-${PKCS11_HELPER_VERSION}.tar.bz2"
|
||||
"https://github.com/OpenSC/pkcs11-helper/archive/pkcs11-helper-${PKCS11_HELPER_VERSION}.tar.gz"
|
||||
fi
|
||||
}
|
||||
|
||||
build_pkcs11_helper () {
|
||||
if [ "$(cat ${PREFIX}/.pkcs11_helper-version)" != "${PKCS11_HELPER_VERSION}" ]; then
|
||||
tar jxf download-cache/pkcs11-helper-${PKCS11_HELPER_VERSION}.tar.bz2
|
||||
tar xf download-cache/pkcs11-helper-${PKCS11_HELPER_VERSION}.tar.gz
|
||||
(
|
||||
cd "pkcs11-helper-${PKCS11_HELPER_VERSION}"
|
||||
cd "pkcs11-helper-pkcs11-helper-${PKCS11_HELPER_VERSION}"
|
||||
|
||||
autoreconf -iv
|
||||
|
||||
./configure --host=${CHOST} --program-prefix='' --libdir=${PREFIX}/lib \
|
||||
--prefix=${PREFIX} --build=x86_64-pc-linux-gnu \
|
||||
|
|
|
|||
|
|
@ -1,10 +0,0 @@
|
|||
#!/bin/sh
|
||||
set -eux
|
||||
|
||||
if [ "${TRAVIS_OS_NAME}" = "windows" ]; then
|
||||
# for windows we need to print output since openssl build
|
||||
# might take more than 10 minutes, which causes build abort
|
||||
.travis/build-deps.sh
|
||||
else
|
||||
.travis/build-deps.sh > build-deps.log 2>&1 || (cat build-deps.log && exit 1)
|
||||
fi
|
||||
Loading…
Reference in a new issue