Ensure that Python3 is available #2428
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# The name of our workflow | |
name: Build | |
on: | |
push: | |
pull_request: | |
jobs: | |
checkuncrustify: | |
name: "Check code style with Uncrustify" | |
# Ubuntu 22.04 has uncrustify 0.72_f | |
runs-on: ubuntu-22.04 | |
steps: | |
- name: Install dependencies | |
run: sudo apt update && sudo apt install -y uncrustify | |
- name: Checkout OpenVPN | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
with: | |
path: openvpn | |
- name: Show uncrustify version | |
run: uncrustify --version | |
- name: Run uncrustify | |
run: ./dev-tools/reformat-all.sh | |
working-directory: openvpn | |
- name: Check for changes | |
run: git diff --output=uncrustify-changes.patch | |
working-directory: openvpn | |
- name: Show changes on standard output | |
run: git diff | |
working-directory: openvpn | |
- uses: actions/upload-artifact@50769540e7f4bd5e21e526ee35c689e35e0d6874 # v4 | |
with: | |
name: uncrustify-changes.patch | |
path: 'openvpn/uncrustify-changes.patch' | |
- name: Set job status | |
run: test ! -s uncrustify-changes.patch | |
working-directory: openvpn | |
mingw: | |
strategy: | |
fail-fast: false | |
matrix: | |
arch: [x86, x64] | |
name: "gcc-mingw - ${{ matrix.arch }} - OSSL" | |
runs-on: ubuntu-22.04 | |
env: | |
VCPKG_ROOT: ${{ github.workspace }}/vcpkg | |
steps: | |
- name: Install dependencies | |
run: sudo apt update && sudo apt install -y mingw-w64 unzip cmake ninja-build build-essential wget python3-docutils man2html-base | |
- name: Checkout OpenVPN | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
- name: Restore from cache and install vcpkg | |
uses: lukka/run-vcpkg@5e0cab206a5ea620130caf672fce3e4a6b5666a1 # v11.5 | |
with: | |
vcpkgGitCommitId: 8d3649ba34aab36914ddd897958599aa0a91b08e | |
vcpkgJsonGlob: '**/mingw/vcpkg.json' | |
- name: Run CMake with vcpkg.json manifest | |
uses: lukka/run-cmake@af1be47fd7c933593f687731bc6fdbee024d3ff4 # v10.8 | |
with: | |
configurePreset: mingw-${{ matrix.arch }} | |
buildPreset: mingw-${{ matrix.arch }} | |
buildPresetAdditionalArgs: "['--config Debug']" | |
- uses: actions/upload-artifact@50769540e7f4bd5e21e526ee35c689e35e0d6874 # v4 | |
with: | |
name: openvpn-mingw-${{ matrix.arch }} | |
path: | | |
${{ github.workspace }}/out/build/mingw/${{ matrix.arch }}/Debug/*.exe | |
${{ github.workspace }}/out/build/mingw/${{ matrix.arch }}/Debug/*.dll | |
!${{ github.workspace }}/out/build/mingw/${{ matrix.arch }}/Debug/test_*.exe | |
- uses: actions/upload-artifact@50769540e7f4bd5e21e526ee35c689e35e0d6874 # v4 | |
with: | |
name: openvpn-mingw-${{ matrix.arch }}-tests | |
path: | | |
${{ github.workspace }}/out/build/mingw/${{ matrix.arch }}/Debug/test_*.exe | |
${{ github.workspace }}/out/build/mingw/${{ matrix.arch }}/Debug/*.dll | |
mingw-unittest: | |
needs: [ mingw ] | |
strategy: | |
fail-fast: false | |
matrix: | |
arch: [x86, x64] | |
test: [argv, auth_token, buffer, cryptoapi, crypto, misc, ncp, packet_id, pkt, provider, ssl, tls_crypt, user_pass] | |
runs-on: windows-latest | |
name: "mingw unittest ${{ matrix.test }} - ${{ matrix.arch }} - OSSL" | |
steps: | |
- name: Checkout OpenVPN | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
- name: Retrieve mingw unittest | |
uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16 # v4 | |
with: | |
name: openvpn-mingw-${{ matrix.arch }}-tests | |
path: unittests | |
- name: Run ${{ matrix.test }} unit test | |
run: ./unittests/test_${{ matrix.test }}.exe | |
env: | |
srcdir: "${{ github.workspace }}/tests/unit_tests/openvpn" | |
ubuntu: | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [ubuntu-20.04, ubuntu-22.04, ubuntu-24.04] | |
sslpkg: [libmbedtls-dev] | |
ssllib: [mbedtls] | |
libname: [mbed TLS] | |
include: | |
- os: ubuntu-20.04 | |
sslpkg: "libssl-dev" | |
libname: OpenSSL 1.1.1 | |
ssllib: openssl | |
- os: ubuntu-22.04 | |
sslpkg: "libssl-dev" | |
libname: OpenSSL 3.0.2 | |
ssllib: openssl | |
pkcs11pkg: "libpkcs11-helper1-dev softhsm2 gnutls-bin" | |
extraconf: --enable-pkcs11 | |
- os: ubuntu-24.04 | |
sslpkg: "libssl-dev" | |
libname: OpenSSL 3.0.13 | |
ssllib: openssl | |
pkcs11pkg: "libpkcs11-helper1-dev softhsm2 gnutls-bin" | |
extraconf: --enable-pkcs11 | |
- os: ubuntu-20.04 | |
sslpkg: "libssl-dev" | |
libname: OpenSSL 1.1.1 | |
ssllib: openssl | |
pkcs11pkg: "libpkcs11-helper1-dev softhsm2 gnutls-bin" | |
extraconf: "--enable-iproute2 --enable-pkcs11" | |
- os: ubuntu-20.04 | |
sslpkg: "libssl-dev" | |
libname: OpenSSL 1.1.1 | |
ssllib: openssl | |
extraconf: "--enable-async-push" | |
- os: ubuntu-20.04 | |
sslpkg: "libssl-dev" | |
libname: OpenSSL 1.1.1 | |
ssllib: openssl | |
extraconf: "--disable-management" | |
- os: ubuntu-20.04 | |
sslpkg: "libssl-dev" | |
libname: OpenSSL 1.1.1 | |
ssllib: openssl | |
extraconf: "--enable-small" | |
- os: ubuntu-20.04 | |
sslpkg: "libssl-dev" | |
libname: OpenSSL 1.1.1 | |
ssllib: openssl | |
extraconf: "--disable-lzo --disable-lz4" | |
name: "gcc - ${{matrix.os}} - ${{matrix.libname}} ${{matrix.extraconf}}" | |
env: | |
SSLPKG: "${{matrix.sslpkg}}" | |
PKCS11PKG: "${{matrix.pkcs11pkg}}" | |
runs-on: ${{matrix.os}} | |
steps: | |
- name: Install dependencies | |
run: sudo apt update && sudo apt install -y liblzo2-dev libpam0g-dev liblz4-dev libcap-ng-dev libnl-genl-3-dev linux-libc-dev man2html libcmocka-dev python3-docutils libtool automake autoconf ${SSLPKG} ${PKCS11PKG} | |
- name: Checkout OpenVPN | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
- name: autoconf | |
run: autoreconf -fvi | |
- name: configure | |
run: ./configure --with-crypto-library=${{matrix.ssllib}} ${{matrix.extraconf}} --enable-werror | |
- name: make all | |
run: make -j3 | |
- name: configure checks | |
if: ${{ matrix.extraconf != '--disable-management' }} | |
run: echo 'RUN_SUDO="sudo -E"' >tests/t_server_null.rc | |
- name: make check | |
run: make -j3 check VERBOSE=1 | |
ubuntu-clang-asan: | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [ubuntu-20.04, ubuntu-22.04, ubuntu-24.04] | |
ssllib: [mbedtls, openssl] | |
name: "clang-asan - ${{matrix.os}} - ${{matrix.ssllib}}" | |
env: | |
UBSAN_OPTIONS: print_stacktrace=1 | |
runs-on: ${{matrix.os}} | |
steps: | |
- name: Install dependencies | |
run: sudo apt update && sudo apt install -y liblzo2-dev libpam0g-dev liblz4-dev libcap-ng-dev libnl-genl-3-dev linux-libc-dev man2html clang libcmocka-dev python3-docutils libtool automake autoconf libmbedtls-dev | |
- name: Checkout OpenVPN | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
- name: autoconf | |
run: autoreconf -fvi | |
- name: configure | |
run: CFLAGS="-fsanitize=address,undefined -fno-sanitize-recover=all -fno-omit-frame-pointer -O2" CC=clang ./configure --with-crypto-library=${{matrix.ssllib}} --enable-werror | |
- name: make all | |
run: make -j3 | |
- name: configure checks | |
run: echo 'RUN_SUDO="sudo -E"' >tests/t_server_null.rc | |
- name: make check | |
run: make -j3 check VERBOSE=1 | |
macos: | |
strategy: | |
fail-fast: false | |
matrix: | |
ssllib: [[email protected], openssl@3, libressl] | |
build: [normal, asan] | |
os: [macos-13, macos-14, macos-15] | |
include: | |
- build: asan | |
cflags: "-fsanitize=address,undefined -fno-sanitize-recover=all -fno-optimize-sibling-calls -fsanitize-address-use-after-scope -fno-omit-frame-pointer -g -O1" | |
ldflags: -fsanitize=address,undefined -fno-sanitize-recover=all | |
# Our build system ignores LDFLAGS for plugins | |
configureflags: --disable-plugin-auth-pam --disable-plugin-down-root | |
- build: normal | |
cflags: "-O2 -g" | |
ldflags: "" | |
configureflags: "" | |
runs-on: ${{matrix.os}} | |
name: "${{matrix.os}} - ${{matrix.ssllib}} - ${{matrix.build}}" | |
env: | |
CFLAGS: ${{ matrix.cflags }} | |
LDFLAGS: ${{ matrix.ldflags }} | |
UBSAN_OPTIONS: print_stacktrace=1 | |
steps: | |
- name: Install dependencies | |
run: brew install ${{matrix.ssllib}} lzo lz4 man2html cmocka libtool automake autoconf | |
- name: Checkout OpenVPN | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
- name: Set environment | |
run: | | |
cat >>$GITHUB_ENV <<EOF; | |
OPENSSL_CFLAGS=-I$(brew --prefix ${{matrix.ssllib}})/include | |
OPENSSL_LIBS=-L$(brew --prefix ${{matrix.ssllib}})/lib -lcrypto -lssl | |
LZO_CFLAGS=-I$(brew --prefix lzo)/include | |
LZO_LIBS=-L$(brew --prefix lzo)/lib -llzo2 | |
EOF | |
- name: autoconf | |
run: autoreconf -fvi | |
- name: configure | |
run: ./configure --enable-werror ${{matrix.configureflags}} | |
- name: make all | |
run: make -j4 | |
- name: configure checks | |
run: echo 'RUN_SUDO="sudo -E"' >tests/t_server_null.rc | |
- name: make check | |
run: make -j4 check VERBOSE=1 | |
msvc: | |
strategy: | |
fail-fast: false | |
matrix: | |
arch: [amd64, x86, arm64, amd64-clang, x86-clang] | |
name: "msbuild - ${{ matrix.arch }} - openssl" | |
env: | |
BUILD_CONFIGURATION: Release | |
runs-on: windows-latest | |
steps: | |
- uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
- uses: lukka/get-cmake@070a0507a7abe157ef918deec391da1be197d2d1 # v3.30.3 | |
- name: Install rst2html | |
run: python -m pip install --upgrade pip docutils | |
- name: Restore artifacts, or setup vcpkg (do not install any package) | |
uses: lukka/run-vcpkg@5e0cab206a5ea620130caf672fce3e4a6b5666a1 # v11.5 | |
with: | |
vcpkgGitCommitId: 8d3649ba34aab36914ddd897958599aa0a91b08e | |
vcpkgJsonGlob: '**/windows/vcpkg.json' | |
- name: Run CMake with vcpkg.json manifest (NO TESTS) | |
uses: lukka/run-cmake@af1be47fd7c933593f687731bc6fdbee024d3ff4 # v10.8 | |
if: ${{ matrix.arch == 'arm64' }} | |
with: | |
configurePreset: win-${{ matrix.arch }}-release | |
buildPreset: win-${{ matrix.arch }}-release | |
- name: Run CMake with vcpkg.json manifest | |
uses: lukka/run-cmake@af1be47fd7c933593f687731bc6fdbee024d3ff4 # v10.8 | |
if: ${{ matrix.arch != 'arm64' }} | |
with: | |
configurePreset: win-${{ matrix.arch }}-release | |
buildPreset: win-${{ matrix.arch }}-release | |
testPreset: win-${{ matrix.arch }}-release | |
testPresetAdditionalArgs: "['--output-on-failure']" | |
- uses: actions/upload-artifact@50769540e7f4bd5e21e526ee35c689e35e0d6874 # v4 | |
with: | |
name: openvpn-msvc-${{ matrix.arch }} | |
path: | | |
${{ github.workspace }}/out/**/*.exe | |
${{ github.workspace }}/out/**/*.dll | |
!${{ github.workspace }}/out/**/test_*.exe | |
!${{ github.workspace }}/out/**/CMakeFiles/** | |
!${{ github.workspace }}/out/**/vcpkg_installed/** | |
libressl: | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [ubuntu-22.04] | |
ssllib: [libressl] | |
build: [ normal, asan ] | |
configureflags: ["--with-openssl-engine=no"] | |
include: | |
- build: asan | |
cflags: "-fsanitize=address -fno-sanitize-recover=all -fno-optimize-sibling-calls -fsanitize-address-use-after-scope -fno-omit-frame-pointer -g -O1" | |
ldflags: -fsanitize=address -fno-sanitize-recover=all | |
cc: clang | |
- build: normal | |
cflags: "-O2 -g" | |
ldflags: "" | |
cc: gcc | |
name: "${{matrix.cc}} ${{matrix.build}} - ${{matrix.os}} - ${{matrix.ssllib}}" | |
runs-on: ${{matrix.os}} | |
env: | |
CFLAGS: ${{ matrix.cflags }} | |
LDFLAGS: ${{ matrix.ldflags }} | |
CC: ${{matrix.cc}} | |
UBSAN_OPTIONS: print_stacktrace=1 | |
steps: | |
- name: Install dependencies | |
run: sudo apt update && sudo apt install -y liblzo2-dev libpam0g-dev liblz4-dev linux-libc-dev man2html clang libcmocka-dev python3-docutils libtool automake autoconf pkg-config libcap-ng-dev libnl-genl-3-dev | |
- name: "libressl: checkout" | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
with: | |
path: libressl | |
# versioning=semver-coerced | |
repository: libressl/portable | |
ref: v3.8.3 | |
- name: "libressl: autogen.sh" | |
run: ./autogen.sh | |
working-directory: libressl | |
- name: "libressl: configure" | |
run: ./configure | |
working-directory: libressl | |
- name: "libressl: make all" | |
run: make -j3 | |
working-directory: libressl | |
- name: "libressl: make install" | |
run: sudo make install | |
working-directory: libressl | |
- name: "ldconfig" | |
run: sudo ldconfig | |
- name: Checkout OpenVPN | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
- name: autoconf | |
run: autoreconf -fvi | |
- name: configure | |
run: ./configure --with-crypto-library=openssl ${{matrix.configureflags}} --enable-werror | |
- name: make all | |
run: make -j3 | |
- name: configure checks | |
run: echo 'RUN_SUDO="sudo -E"' >tests/t_server_null.rc | |
- name: make check | |
run: make -j3 check VERBOSE=1 | |
mbedtls3: | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [ubuntu-22.04] | |
ssllib: [mbedtls3] | |
build: [ normal, asan ] | |
include: | |
- build: asan | |
cflags: "-fsanitize=address -fno-sanitize-recover=all -fno-optimize-sibling-calls -fsanitize-address-use-after-scope -fno-omit-frame-pointer -g -O1" | |
ldflags: -fsanitize=address -fno-sanitize-recover=all | |
cc: clang | |
- build: normal | |
cflags: "-O2 -g" | |
ldflags: "" | |
cc: gcc | |
name: "${{matrix.cc}} ${{matrix.build}} - ${{matrix.os}} - ${{matrix.ssllib}}" | |
runs-on: ${{matrix.os}} | |
env: | |
CFLAGS: ${{ matrix.cflags }} | |
LDFLAGS: ${{ matrix.ldflags }} | |
CC: ${{matrix.cc}} | |
UBSAN_OPTIONS: print_stacktrace=1 | |
steps: | |
- name: Install dependencies | |
run: sudo apt update && sudo apt install -y liblzo2-dev libpam0g-dev liblz4-dev linux-libc-dev man2html clang libcmocka-dev python3-docutils python3-jinja2 python3-jsonschema libtool automake autoconf pkg-config libcap-ng-dev libnl-genl-3-dev | |
- name: "mbedtls: checkout" | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
with: | |
path: mbedtls | |
submodules: true | |
# versioning=semver-coerced | |
repository: Mbed-TLS/mbedtls | |
ref: v3.6.1 | |
- name: "mbedtls: make no_test" | |
run: make -j3 no_test SHARED=1 | |
working-directory: mbedtls | |
- name: "mbedtls: make install" | |
run: sudo make install DESTDIR=/usr | |
working-directory: mbedtls | |
- name: Checkout OpenVPN | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
- name: autoconf | |
run: autoreconf -fvi | |
- name: configure | |
run: ./configure --with-crypto-library=mbedtls | |
- name: make all | |
run: make -j3 | |
- name: configure checks | |
run: echo 'RUN_SUDO="sudo -E"' >tests/t_server_null.rc | |
- name: make check | |
run: make -j3 check VERBOSE=1 |