From 045879953c45ad5cd00836ba05d0646bba9f0ca1 Mon Sep 17 00:00:00 2001 From: Caio Casimiro Date: Tue, 5 Sep 2023 16:08:49 +0100 Subject: [PATCH] chore(ci) bump and sync CC version among Dockerfiles and CI workflows Dockerfiles and CI workflow use the latest version available in the runner OS. Older versions of gcc and clang are tested in CI Large. --- .github/workflows/ci-large.yml | 41 ++++++++++-- .github/workflows/ci.yml | 65 +++++++------------ .github/workflows/job-build-tests.yml | 63 ++++++++++++++++++ .github/workflows/job-unit-tests.yml | 14 ++-- .../Dockerfiles/Dockerfile.ubuntu-22.04 | 13 ++-- util/_lib.sh | 2 +- 6 files changed, 140 insertions(+), 58 deletions(-) create mode 100644 .github/workflows/job-build-tests.yml diff --git a/.github/workflows/ci-large.yml b/.github/workflows/ci-large.yml index 4a35aedbf..d4f491987 100644 --- a/.github/workflows/ci-large.yml +++ b/.github/workflows/ci-large.yml @@ -22,7 +22,7 @@ jobs: label: [""] os: [ubuntu-latest] #os: [ubuntu-latest, macos-latest] - cc: [gcc-9] + cc: [gcc-12] ngx: [1.25.2] runtime: [wasmtime, wasmer, v8] wasmtime: [12.0.1] @@ -35,7 +35,7 @@ jobs: # OpenResty + static ngx_wasm_module - label: dynamic_module os: ubuntu-latest - cc: gcc-9 + cc: gcc-12 openresty: 1.21.4.2 runtime: wasmtime wasmtime: 12.0.1 @@ -65,7 +65,7 @@ jobs: fail-fast: false matrix: os: [ubuntu-22.04] - cc: [gcc-10] + cc: [gcc-12] ngx: [1.25.2] runtime: [wasmer, wasmtime, v8] wasmtime: [12.0.1] @@ -77,7 +77,7 @@ jobs: # OpenResty - label: openresty os: ubuntu-22.04 - cc: gcc-10 + cc: gcc-12 openresty: 1.21.4.2 runtime: wasmer wasmer: 3.1.1 @@ -103,7 +103,7 @@ jobs: fail-fast: false matrix: os: [ubuntu-latest] - cc: [clang-11] + cc: [clang-15] openresty: [1.21.4.2] runtime: [wasmtime, wasmer, v8] wasmtime: [12.0.1] @@ -122,3 +122,34 @@ jobs: v8: ${{ matrix.v8 }} ssl: ${{ matrix.ssl }} debug: ${{ matrix.debug }} + + build-large: + name: 'Build' + #if: ${{ false }} + strategy: + fail-fast: false + matrix: + label: [""] + os: [ubuntu-latest] + cc: [clang-13, clang-14, gcc-10, gcc-11] + ngx: [1.25.2] + runtime: [wasmtime, wasmer, v8] + wasmtime: [12.0.1] + wasmer: [3.1.1] + v8: [11.4.183.23] + include: + - label: old_nginx + os: [ubuntu-latest] + cc: clang-15 + ngx: 1.21.6 + runtime: wasmtime + wasmtime: 12.0.1 + uses: ./.github/workflows/job-build-tests.yml + with: + os: ${{ matrix.os }} + cc: ${{ matrix.cc }} + ngx: ${{ matrix.ngx }} + runtime: ${{ matrix.runtime }} + wasmtime: ${{ matrix.wasmtime }} + wasmer: ${{ matrix.wasmer }} + v8: ${{ matrix.v8 }} diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 23784e803..a526d2e2f 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -28,7 +28,7 @@ jobs: matrix: label: [""] os: [ubuntu-latest] - cc: [gcc-9] + cc: [gcc-12] ngx: [1.25.2] openresty: [""] runtime: [wasmer] @@ -44,7 +44,7 @@ jobs: - runtime: wasmtime wasmtime: 12.0.1 os: ubuntu-latest - cc: gcc-9 + cc: gcc-12 ngx: 1.25.2 ssl: ssl debug: debug @@ -53,7 +53,7 @@ jobs: - runtime: v8 v8: 11.4.183.23 os: ubuntu-latest - cc: gcc-9 + cc: gcc-12 ngx: 1.25.2 ssl: ssl debug: debug @@ -61,7 +61,7 @@ jobs: # Old Nginx - label: old_nginx os: ubuntu-latest - cc: gcc-9 + cc: gcc-12 ngx: 1.21.6 runtime: wasmer wasmer: 3.1.1 @@ -71,7 +71,7 @@ jobs: # Nginx + dynamic ngx_wasm_module + HUP - label: dynamic_nginx os: ubuntu-latest - cc: gcc-9 + cc: gcc-12 ngx: 1.25.2 runtime: wasmtime wasmtime: 12.0.1 @@ -81,7 +81,7 @@ jobs: module_type: dynamic # No SSL - os: ubuntu-latest - cc: gcc-9 + cc: gcc-12 ngx: 1.25.2 runtime: wasmer wasmer: 3.1.1 @@ -91,7 +91,7 @@ jobs: # OpenResty - label: openresty os: ubuntu-latest - cc: gcc-9 + cc: gcc-12 openresty: 1.21.4.2 runtime: wasmtime wasmtime: 12.0.1 @@ -101,7 +101,7 @@ jobs: # OpenResty + dynamic ngx_wasm_module - label: dynamic_openresty os: ubuntu-latest - cc: gcc-9 + cc: gcc-12 openresty: 1.21.4.2 runtime: wasmtime wasmtime: 12.0.1 @@ -147,7 +147,7 @@ jobs: matrix: label: [""] os: [ubuntu-22.04] - cc: [gcc-10] + cc: [gcc-12] ngx: [1.25.2] openresty: [""] runtime: [wasmer] @@ -161,7 +161,7 @@ jobs: - runtime: wasmtime wasmtime: 12.0.1 os: ubuntu-22.04 - cc: gcc-10 + cc: gcc-12 ngx: 1.25.2 hup: no_hup debug: debug @@ -169,14 +169,14 @@ jobs: - runtime: v8 v8: 11.4.183.23 os: ubuntu-22.04 - cc: gcc-10 + cc: gcc-12 ngx: 1.25.2 debug: debug hup: no_hup # OpenResty - label: openresty os: ubuntu-22.04 - cc: gcc-10 + cc: gcc-12 openresty: 1.21.4.2 ngx: runtime: wasmer @@ -240,7 +240,7 @@ jobs: strategy: fail-fast: false matrix: - cc: [clang-11] + cc: [clang-15] openresty: [1.21.4.2] runtime: [wasmtime, wasmer, v8] wasmtime: [12.0.1] @@ -251,7 +251,7 @@ jobs: include: # No SSL - os: ubuntu-latest - cc: clang-11 + cc: clang-15 ngx: 1.25.2 runtime: wasmer wasmer: 3.1.1 @@ -272,39 +272,22 @@ jobs: build: name: 'Build' #if: ${{ false }} - runs-on: ${{ matrix.os }} strategy: fail-fast: false matrix: - label: [""] os: [ubuntu-latest] - cc: [clang-14, gcc-10] + cc: [clang-15, gcc-12] ngx: [1.25.2] runtime: [wasmtime, wasmer, v8] wasmtime: [12.0.1] wasmer: [3.1.1] v8: [11.4.183.23] - include: - - label: old_nginx - os: ubuntu-latest - cc: clang-14 - ngx: 1.21.6 - runtime: wasmtime - wasmtime: 12.0.1 - steps: - - uses: actions/checkout@v3 - - name: 'Setup cache - work/ dir' - uses: actions/cache@v3 - if: ${{ !env.ACT }} - with: - path: | - work/downloads - work/runtimes - work/openssl - key: work-${{ runner.os }}-${{ matrix.cc }}-${{ matrix.ngx }}-${{ matrix.openresty }}-${{ matrix.runtime }}-${{ hashFiles('util/**/*.sh', 'util/**/*.pl', 'util/**/*.awk', '.github/**/*.yml', '.github/**/*.sh', '.github/**/*.js', 'rust-toolchain', 'Makefile') }} - - name: Setup Wasm runtime - run: ./util/runtime.sh -R ${{ matrix.runtime }} -V ${{ matrix[matrix.runtime] }} - - run: make setup - - run: make test-build - env: - NGX_WASM_RUNTIME: ${{ matrix.runtime }} + uses: ./.github/workflows/job-build-tests.yml + with: + os: ${{ matrix.os }} + cc: ${{ matrix.cc }} + ngx: ${{ matrix.ngx }} + runtime: ${{ matrix.runtime }} + wasmtime: ${{ matrix.wasmtime }} + wasmer: ${{ matrix.wasmer }} + v8: ${{ matrix.v8 }} diff --git a/.github/workflows/job-build-tests.yml b/.github/workflows/job-build-tests.yml new file mode 100644 index 000000000..a8d844480 --- /dev/null +++ b/.github/workflows/job-build-tests.yml @@ -0,0 +1,63 @@ +name: Build tests + +on: + workflow_call: + inputs: + os: + required: true + type: string + cc: + required: true + type: string + ngx: + required: true + type: string + runtime: + required: true + type: string + wasmtime: + required: true + type: string + wasmer: + required: true + type: string + v8: + required: true + type: string + +defaults: + run: + shell: bash + +env: + CC: ${{ inputs.cc }} + NGX_WASM_RUNTIME: ${{ inputs.runtime }} + +jobs: + build: + name: 'Build' + #if: ${{ false }} + runs-on: ${{ inputs.os }} + steps: + - name: 'Setup deps - apt-get gcc' + if: ${{ !env.ACT && contains(inputs.cc, 'gcc') }} + run: sudo apt-get update && sudo apt-get install -y ${CC} libstdc++-${CC#*-}-dev lcov + + - name: 'Setup deps - apt-get clang' + if: ${{ !env.ACT && contains(inputs.cc, 'clang') }} + run: sudo apt-get update && sudo apt-get install -y ${CC} lcov + + - uses: actions/checkout@v3 + - name: 'Setup cache - work/ dir' + uses: actions/cache@v3 + if: ${{ !env.ACT }} + with: + path: | + work/downloads + work/runtimes + work/openssl + key: work-${{ runner.os }}-${{ inputs.cc }}-${{ inputs.ngx }}-${{ inputs.runtime }}-${{ hashFiles('util/**/*.sh', 'util/**/*.pl', 'util/**/*.awk', '.github/**/*.yml', '.github/**/*.sh', '.github/**/*.js', 'rust-toolchain', 'Makefile') }} + - name: Setup Wasm runtime + run: ./util/runtime.sh -R ${{ inputs.runtime }} -V ${{ inputs[inputs.runtime] }} + - run: make setup + - run: make test-build diff --git a/.github/workflows/job-unit-tests.yml b/.github/workflows/job-unit-tests.yml index b77f41d6b..a08ed1573 100644 --- a/.github/workflows/job-unit-tests.yml +++ b/.github/workflows/job-unit-tests.yml @@ -70,8 +70,8 @@ jobs: coveralls_name: ${{ steps.lcov.outputs.name }} steps: - name: 'Setup deps - apt-get' - if: ${{ inputs.cc == 'gcc-9' }} - run: sudo apt-get update && sudo apt-get install -y gcc-9 libstdc++-9-dev lcov + if: ${{ !env.ACT }} + run: sudo apt-get update && sudo apt-get install -y ${CC} libstdc++-${CC#*-}-dev lcov - uses: actions/checkout@v3 - name: 'Setup cache - rustup toolchain' if: ${{ !env.ACT }} @@ -116,11 +116,11 @@ jobs: - run: make test - name: Run lcov id: lcov - if: ${{ !env.ACT && inputs.cc == 'gcc-9' && inputs.coverage }} + if: ${{ !env.ACT && inputs.coverage }} run: | - lcov --capture --directory work/buildroot --output-file lcov.info - lcov --remove lcov.info "*/ngx_wasm_module/src/common/debug/*" --output-file lcov.info - lcov --extract lcov.info "*/ngx_wasm_module/src/*" --output-file lcov.info + lcov --gcov-tool gcov-${CC#*-} --capture --directory work/buildroot --output-file lcov.info + lcov --gcov-tool gcov-${CC#*-} --remove lcov.info "*/ngx_wasm_module/src/common/debug/*" --output-file lcov.info + lcov --gcov-tool gcov-${CC#*-} --extract lcov.info "*/ngx_wasm_module/src/*" --output-file lcov.info name="unit" if [ -n "${{ inputs.openresty }}" ]; then @@ -139,7 +139,7 @@ jobs: fi echo "name=$name" >> $GITHUB_OUTPUT - name: Coveralls Upload - if: ${{ !env.ACT && inputs.cc == 'gcc-9' && inputs.coverage }} + if: ${{ !env.ACT && inputs.coverage }} uses: coverallsapp/github-action@v2 with: github-token: ${{ secrets.GITHUB_TOKEN }} diff --git a/assets/release/Dockerfiles/Dockerfile.ubuntu-22.04 b/assets/release/Dockerfiles/Dockerfile.ubuntu-22.04 index 2db2a9dae..8d2f062ca 100644 --- a/assets/release/Dockerfiles/Dockerfile.ubuntu-22.04 +++ b/assets/release/Dockerfiles/Dockerfile.ubuntu-22.04 @@ -1,6 +1,8 @@ FROM ubuntu:22.04 COPY . /ngx_wasm_module +ARG GCC_VERSION=12 +ARG CLANG_VERSION=15 ARG GOLANG_VERSION=1.19.5 ARG TINYGO_VERSION=0.27.0 ARG DEBIAN_FRONTEND=noninteractive @@ -11,12 +13,12 @@ RUN apt-get update && \ ninja-build \ python3 \ cmake \ - gcc-11 \ - libstdc++-11-dev \ + gcc-${GCC_VERSION} \ + libstdc++-${GCC_VERSION}-dev \ git \ pkg-config \ libglib2.0-dev \ - clang \ + clang-${CLANG_VERSION} \ curl \ binfmt-support \ qemu-user-static @@ -26,6 +28,7 @@ ENV PATH $CARGO_HOME/bin:$PATH RUN mkdir -p "$CARGO_HOME" && mkdir -p "$RUSTUP_HOME" && \ curl https://sh.rustup.rs -sSf | sh -s -- -y --default-toolchain stable && \ chmod -R a=rwX $CARGO_HOME $RUSTUP_HOME +RUN rustup target add wasm32-wasi && rustup target add wasm32-unknown-unknown RUN /bin/bash -c 'echo $(uname -m) > /TG_ARCH || : ; \ [[ $(cat /TG_ARCH) == "x86_64" ]] && echo "amd64" > /TG_ARCH || : ; \ @@ -36,15 +39,17 @@ RUN /bin/bash -c 'echo $(uname -m) > /TG_ARCH || : ; \ # # unzip: LuaRocks RUN apt-get install -y \ - clang-tools \ + clang-tools-${CLANG_VERSION} \ libpcre3-dev \ libssl-dev \ zlib1g-dev \ valgrind \ nodejs \ gcovr \ + lcov \ unzip \ sudo && \ + update-alternatives --install /usr/bin/scan-build scan-build /usr/bin/scan-build-${CLANG_VERSION} 100 && \ curl -sLO https://golang.google.cn/dl/go${GOLANG_VERSION}.linux-$(cat /TG_ARCH).tar.gz && \ sudo rm -rf /usr/local/go && tar -C /usr/local -xzf go${GOLANG_VERSION}.linux-$(cat /TG_ARCH).tar.gz && \ curl -sLO https://github.com/tinygo-org/tinygo/releases/download/v$TINYGO_VERSION/tinygo_${TINYGO_VERSION}_$(cat /TG_ARCH).deb && \ diff --git a/util/_lib.sh b/util/_lib.sh index 3cbfd1363..4e55ab438 100644 --- a/util/_lib.sh +++ b/util/_lib.sh @@ -193,7 +193,7 @@ build_nginx() { -analyze-headers \ --force-analyze-debug-code \ --html-title='$NGX - ngx_wasm_module [${build_name[@]}]' \ - --use-cc=clang \ + --use-cc=${CC:-clang} \ --status-bugs" NGX_BUILD_DEBUG=1 fi