Add tests for DH get params and match OSSL behavior #535
Workflow file for this run
This file contains hidden or 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
| name: OpenVPN Tests | |
| # START OF COMMON SECTION | |
| on: | |
| push: | |
| branches: [ 'master', 'main', 'release/**' ] | |
| pull_request: | |
| branches: [ '*' ] | |
| concurrency: | |
| group: ${{ github.workflow }}-${{ github.ref }} | |
| cancel-in-progress: true | |
| # END OF COMMON SECTION | |
| jobs: | |
| build_wolfprovider: | |
| uses: ./.github/workflows/build-wolfprovider.yml | |
| with: | |
| wolfssl_ref: ${{ matrix.wolfssl_ref }} | |
| openssl_ref: ${{ matrix.openssl_ref }} | |
| strategy: | |
| matrix: | |
| wolfssl_ref: [ 'master', 'v5.8.0-stable' ] | |
| openssl_ref: [ 'openssl-3.5.0' ] | |
| test_openvpn: | |
| runs-on: ubuntu-22.04 | |
| needs: build_wolfprovider | |
| # This should be a safe limit for the tests to run. | |
| timeout-minutes: 20 | |
| strategy: | |
| matrix: | |
| openvpn_ref: [ 'master', 'v2.6.12' ] | |
| wolfssl_ref: [ 'master', 'v5.8.0-stable' ] | |
| openssl_ref: [ 'openssl-3.5.0' ] | |
| force_fail: ['WOLFPROV_FORCE_FAIL=1', ''] | |
| exclude: | |
| - openvpn_ref: 'master' | |
| force_fail: 'WOLFPROV_FORCE_FAIL=1' | |
| steps: | |
| - name: Checkout wolfProvider | |
| uses: actions/checkout@v4 | |
| - name: Retrieving OpenSSL from cache | |
| uses: actions/cache/restore@v4 | |
| id: openssl-cache | |
| with: | |
| path: | | |
| openssl-source | |
| openssl-install | |
| key: ossl-depends-${{ matrix.openssl_ref }}-${{ github.sha }} | |
| fail-on-cache-miss: true | |
| - name: Retrieving wolfSSL/wolfProvider from cache | |
| uses: actions/cache/restore@v4 | |
| id: wolfprov-cache | |
| with: | |
| path: | | |
| wolfssl-source | |
| wolfssl-install | |
| wolfprov-install | |
| provider.conf | |
| key: wolfprov-${{ matrix.wolfssl_ref }}-${{ github.sha }} | |
| fail-on-cache-miss: true | |
| - name: Install test dependencies | |
| run: | | |
| sudo apt-get update | |
| sudo apt-get install liblzo2-dev libpam0g-dev liblz4-dev libcap-ng-dev \ | |
| linux-libc-dev man2html libcmocka-dev python3-docutils \ | |
| libtool automake autoconf libnl-genl-3-dev libnl-genl-3-200 | |
| - name: Build and test OpenVPN | |
| uses: wolfSSL/actions-build-autotools-project@v1 | |
| with: | |
| repository: OpenVPN/openvpn | |
| path: openvpn | |
| ref: ${{ matrix.openvpn_ref }} | |
| configure: | |
| check: false | |
| - name: Test OpenVPN with wolfProvider | |
| working-directory: openvpn | |
| run: | | |
| # Set environment variables | |
| export LD_LIBRARY_PATH=$GITHUB_WORKSPACE/wolfssl-install/lib:$GITHUB_WORKSPACE/openssl-install/lib64 | |
| export OPENSSL_CONF=$GITHUB_WORKSPACE/provider.conf | |
| export OPENSSL_MODULES=$GITHUB_WORKSPACE/wolfprov-install/lib | |
| export ${{ matrix.force_fail }} | |
| # Run tests and save result | |
| make check 2>&1 | tee openvpn-test.log | |
| TEST_RESULT=$? | |
| $GITHUB_WORKSPACE/.github/scripts/check-workflow-result.sh $TEST_RESULT ${{ matrix.force_fail }} openvpn |