-
Notifications
You must be signed in to change notification settings - Fork 835
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
69e183c
commit 3186451
Showing
1 changed file
with
92 additions
and
0 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,92 @@ | ||
name: haproxy Test | ||
|
||
# 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_wolfssl: | ||
name: Build wolfSSL | ||
if: github.repository_owner == 'wolfssl' | ||
runs-on: ubuntu-22.04 | ||
# This should be a safe limit for the tests to run. | ||
timeout-minutes: 4 | ||
steps: | ||
- name: Build wolfSSL | ||
uses: wolfSSL/actions-build-autotools-project@v1 | ||
with: | ||
path: wolfssl | ||
configure: --enable-haproxy | ||
install: true | ||
|
||
- name: tar build-dir | ||
run: tar -zcf build-dir.tgz build-dir | ||
|
||
- name: Upload built lib | ||
uses: actions/upload-artifact@v4 | ||
with: | ||
name: wolf-install-haproxy | ||
path: build-dir.tgz | ||
retention-days: 5 | ||
|
||
test_haproxy: | ||
name: ${{ matrix.haproxy_ref }} | ||
if: github.repository_owner == 'wolfssl' | ||
runs-on: ubuntu-22.04 | ||
# This should be a safe limit for the tests to run. | ||
timeout-minutes: 15 | ||
needs: build_wolfssl | ||
strategy: | ||
fail-fast: false | ||
matrix: | ||
haproxy_ref: [ 'v3.1.0' ] | ||
steps: | ||
- name: Install test dependencies | ||
run: | | ||
sudo apt-get update | ||
sudo apt-get install libpcre2-dev | ||
- name: Download lib | ||
uses: actions/download-artifact@v4 | ||
with: | ||
name: wolf-install-haproxy | ||
|
||
- name: untar build-dir | ||
run: tar -xf build-dir.tgz | ||
|
||
# check cache for haproxy if not there then download it | ||
- name: Check haproxy cache | ||
uses: actions/cache@v4 | ||
id: cache-haproxy | ||
with: | ||
path: build-dir/haproxy-${{matrix.haproxy-ref}} | ||
key: haproxy-${{matrix.haproxy-ref}} | ||
lookup-only: true | ||
|
||
- name: Download haproxy if needed | ||
if: steps.cache-haproxy.outputs.cache-hit != 'true' | ||
uses: actions/checkout@v3 | ||
with: | ||
repository: haproxy/haproxy | ||
ref: ${{matrix.haproxy-ref}} | ||
path: build-dir/haproxy-${{matrix.haproxy-ref}} | ||
|
||
- name: Build haproxy | ||
working-directory: build-dir/haproxy-${{matrix.haproxy-ref}} | ||
run: make TARGET=linux-glibc USE_OPENSSL_WOLFSSL=1 SSL_LIB=$GITHUB_WORKSPACE/build-dir/lib SSL_INC=$GITHUB_WORKSPACE/build-dir/include ADDLIB=-Wl,-rpath,$GITHUB_WORKSPACE/build-dir/lib CFLAGS="-fsanitize=address" LDFLAGS="-fsanitize=address" | ||
|
||
- name: Build haproxy vtest | ||
working-directory: build-dir/haproxy-${{matrix.haproxy-ref}} | ||
run: ./scripts/build-vtest.sh | ||
|
||
- name: Test haproxy | ||
working-directory: build-dir/haproxy-${{matrix.haproxy-ref}} | ||
run: VTEST_PROGRAM=$GITHUB_WORKSPACE/build-dir/vtest/vtest make reg-tests -- --debug reg-tests/ssl/* |