From e2f287cea4c13db72f6b168711ad027ef14e6a25 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. Also fix minor issues reported by the newer clang-analyzer. --- .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 ++-- src/wasm/ngx_wasm_ops.c | 2 +- src/wasm/wrt/ngx_wrt_v8.c | 4 ++ src/wasm/wrt/ngx_wrt_wasmer.c | 6 ++ util/_lib.sh | 2 +- 9 files changed, 151 insertions(+), 59 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..64aec1ce3 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-14, clang-15, gcc-11, 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-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/src/wasm/ngx_wasm_ops.c b/src/wasm/ngx_wasm_ops.c index e7d59153f..a11bc5f70 100644 --- a/src/wasm/ngx_wasm_ops.c +++ b/src/wasm/ngx_wasm_ops.c @@ -126,7 +126,7 @@ ngx_wasm_ops_plan_load(ngx_wasm_ops_plan_t *plan, ngx_log_t *log) ngx_uint_t *fid; ngx_array_t *ids; ngx_wasm_op_t *op; - ngx_wasm_ops_pipeline_t *pipeline; + ngx_wasm_ops_pipeline_t *pipeline = NULL; dd("enter"); diff --git a/src/wasm/wrt/ngx_wrt_v8.c b/src/wasm/wrt/ngx_wrt_v8.c index 55e325292..adc1d3677 100644 --- a/src/wasm/wrt/ngx_wrt_v8.c +++ b/src/wasm/wrt/ngx_wrt_v8.c @@ -452,7 +452,9 @@ ngx_v8_init_instance(ngx_wrt_instance_t *instance, ngx_wrt_store_t *store, ngx_wrt_module_t *module, ngx_pool_t *pool, ngx_wrt_err_t *err) { size_t i; +#if (NGX_DEBUG) ngx_uint_t nimports = 0; +#endif ngx_wavm_hfunc_t *import; ngx_v8_hfunc_ctx_t *hctx = NULL; wasm_func_t *func; @@ -485,7 +487,9 @@ ngx_v8_init_instance(ngx_wrt_instance_t *instance, ngx_wrt_store_t *store, hctx, NULL); instance->imports[i] = wasm_func_as_extern(func); +#if (NGX_DEBUG) nimports++; +#endif } ngx_wasm_assert(nimports == module->nimports); diff --git a/src/wasm/wrt/ngx_wrt_wasmer.c b/src/wasm/wrt/ngx_wrt_wasmer.c index 05aed26b3..5bb397555 100644 --- a/src/wasm/wrt/ngx_wrt_wasmer.c +++ b/src/wasm/wrt/ngx_wrt_wasmer.c @@ -515,7 +515,9 @@ ngx_wasmer_init_instance(ngx_wrt_instance_t *instance, ngx_wrt_store_t *store, ngx_wrt_module_t *module, ngx_pool_t *pool, ngx_wrt_err_t *err) { size_t i, j; +#if (NGX_DEBUG) ngx_uint_t nimports = 0; +#endif ngx_wrt_import_t *import; ngx_wasmer_hfunc_ctx_t *hctx, *hctxs = NULL; wasm_func_t *func; @@ -558,7 +560,9 @@ ngx_wasmer_init_instance(ngx_wrt_instance_t *instance, ngx_wrt_store_t *store, instance->env.data[i] = (wasm_extern_t *) wasmer_named_extern_unwrap( instance->wasi_imports.data[j]); +#if (NGX_DEBUG) nimports++; +#endif break; } } @@ -576,7 +580,9 @@ ngx_wasmer_init_instance(ngx_wrt_instance_t *instance, ngx_wrt_store_t *store, hctx, NULL); instance->env.data[i] = wasm_func_as_extern(func); +#if (NGX_DEBUG) nimports++; +#endif break; default: 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