From: William Lallemand Date: Tue, 16 Sep 2025 10:01:23 +0000 (+0200) Subject: CI: github: add an OpenSSL + ECH job X-Git-Tag: v3.3-dev9~81 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=9517116f63913ab51cbb19be2cf59f0e84130c6f;p=thirdparty%2Fhaproxy.git CI: github: add an OpenSSL + ECH job The upcoming ECH feature need a patched OpenSSL with the "feature/ech" branch. This daily job launches an openssl build, as well as haproxy build with reg-tests. --- diff --git a/.github/workflows/openssl-ech.yml b/.github/workflows/openssl-ech.yml new file mode 100644 index 000000000..a8b162603 --- /dev/null +++ b/.github/workflows/openssl-ech.yml @@ -0,0 +1,79 @@ +name: openssl ECH + +on: + schedule: + - cron: "0 3 * * *" + workflow_dispatch: + +permissions: + contents: read + +jobs: + test: + runs-on: ubuntu-latest + if: ${{ github.repository_owner == 'haproxy' || github.event_name == 'workflow_dispatch' }} + steps: + - uses: actions/checkout@v5 + - name: Install VTest + run: | + scripts/build-vtest.sh + - name: Install apt dependencies + run: | + sudo apt-get update -o Acquire::Languages=none -o Acquire::Translation=none + sudo apt-get --no-install-recommends -y install socat gdb + - name: Install OpenSSL+ECH + run: env OPENSSL_VERSION="git-feature/ech" GIT_TYPE="branch" scripts/build-ssl.sh + - name: Compile HAProxy + run: | + make -j$(nproc) ERR=1 CC=gcc TARGET=linux-glibc \ + USE_QUIC=1 USE_OPENSSL=1 \ + SSL_LIB=${HOME}/opt/lib SSL_INC=${HOME}/opt/include \ + DEBUG="-DDEBUG_POOL_INTEGRITY -DDEBUG_UNIT" \ + ADDLIB="-Wl,-rpath,/usr/local/lib/ -Wl,-rpath,$HOME/opt/lib/" \ + ARCH_FLAGS="-ggdb3 -fsanitize=address" + sudo make install + - name: Show HAProxy version + id: show-version + run: | + ldd $(which haproxy) + haproxy -vv + echo "version=$(haproxy -v |awk 'NR==1{print $3}')" >> $GITHUB_OUTPUT + - name: Install problem matcher for VTest + run: echo "::add-matcher::.github/vtest.json" + - name: Run VTest for HAProxy + id: vtest + run: | + # This is required for macOS which does not actually allow to increase + # the '-n' soft limit to the hard limit, thus failing to run. + ulimit -n 65536 + # allow to catch coredumps + ulimit -c unlimited + make reg-tests VTEST_PROGRAM=../vtest/vtest REGTESTS_TYPES=default,bug,devel + - name: Show VTest results + if: ${{ failure() && steps.vtest.outcome == 'failure' }} + run: | + for folder in ${TMPDIR:-/tmp}/haregtests-*/vtc.*; do + printf "::group::" + cat $folder/INFO + cat $folder/LOG + echo "::endgroup::" + done + exit 1 + - name: Run Unit tests + id: unittests + run: | + make unit-tests + - name: Show coredumps + if: ${{ failure() && steps.vtest.outcome == 'failure' }} + run: | + failed=false + shopt -s nullglob + for file in /tmp/core.*; do + failed=true + printf "::group::" + gdb -ex 'thread apply all bt full' ./haproxy $file + echo "::endgroup::" + done + if [ "$failed" = true ]; then + exit 1; + fi