File: haproxy.yml

package info (click to toggle)
wolfssl 5.8.4-1
  • links: PTS
  • area: main
  • in suites: forky, sid
  • size: 117,604 kB
  • sloc: ansic: 1,584,954; asm: 481,206; sh: 11,586; cs: 6,596; xml: 3,878; perl: 3,291; makefile: 2,058; ada: 1,891; javascript: 748; python: 636; cpp: 131; ruby: 118; objc: 80; tcl: 73
file content (98 lines) | stat: -rw-r--r-- 3,170 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
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', 'v3.2.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}}

    - 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 clean && 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"

      # wlallemand/VTest used in v3.1.0 is no longer available
    - name: Patch build-vtest.sh for v3.1.0
      if: matrix.haproxy_ref == 'v3.1.0'
      working-directory: build-dir/haproxy-${{ matrix.haproxy_ref }}/scripts
      run: |
        sed -i 's|https://github.com/wlallemand/VTest/archive/refs/heads/haproxy-sd_notify.tar.gz|https://github.com/vtest/VTest2/archive/main.tar.gz|' build-vtest.sh

    - 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/*