From 8711f50d84c2afec1ec9b0fd41d932bd94695027 Mon Sep 17 00:00:00 2001 From: Edoardo Marangoni Date: Thu, 17 Oct 2024 18:15:28 +0200 Subject: [PATCH 01/59] Trigger Build From 2c7c91035230a031584a6d3bb0c20597e792e2c7 Mon Sep 17 00:00:00 2001 From: Edoardo Marangoni Date: Thu, 17 Oct 2024 23:54:32 +0200 Subject: [PATCH 02/59] Trigger Build From d445ea2719e92449d7d68a211629cb539f054a20 Mon Sep 17 00:00:00 2001 From: Edoardo Marangoni Date: Fri, 18 Oct 2024 00:17:51 +0200 Subject: [PATCH 03/59] fix(ci): Use older naming, reinstate windows-gnu --- .github/workflows/test.yaml | 48 +++++++++++++++++++++++-------------- 1 file changed, 30 insertions(+), 18 deletions(-) diff --git a/.github/workflows/test.yaml b/.github/workflows/test.yaml index 1e719a5b531..111e0e29408 100644 --- a/.github/workflows/test.yaml +++ b/.github/workflows/test.yaml @@ -507,7 +507,7 @@ jobs: }, { - build: macos-arm64, + build: macos-arm, os: macos-14, target: aarch64-apple-darwin, exe: '', @@ -522,6 +522,14 @@ jobs: # For now, disable LLVM in `windows-x64.` # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' }, + { + build: windows-gnu, + os: windows-2022, + target: x86_64-pc-windows-gnu, + exe: '.exe', + # For now, disable LLVM in `windows-x64.` + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + }, { build: linux-musl, target: x86_64-unknown-linux-musl, @@ -673,7 +681,7 @@ jobs: CARGO_TARGET: ${{ matrix.metadata.target }} - name: Test C-API shell: bash - if: ${{ matrix.build-what.key == 'capi' && !(matrix.metadata.build == 'linux-musl' || matrix.metadata.build == 'macos-arm' || matrix.metadata.build == 'windows-gnu') }} + if: ${{ matrix.build-what.key == 'capi' && !(matrix.metadata.build == 'linux-musl' || matrix.metadata.build == 'windows-gnu') }} run: make test-capi-ci env: TARGET: ${{ matrix.metadata.target }} @@ -682,7 +690,7 @@ jobs: # C-API tests were disabled for linux-musl and macos-arm (we can't run them) - name: Test C-API integration shell: bash - if: ${{ matrix.build-what.key == 'capi' && !(matrix.metadata.build == 'linux-musl' || matrix.metadata.build == 'macos-arm' || matrix.metadata.build == 'windows-gnu') }} + if: ${{ matrix.build-what.key == 'capi' && !(matrix.metadata.build == 'linux-musl' || matrix.metadata.build == 'windows-gnu') }} run: export WASMER_DIR=`pwd`/package && make test-stage-7-capi-integration-tests env: TARGET: ${{ matrix.metadata.target }} @@ -955,7 +963,7 @@ jobs: path: package/cache/wasmercache2 - uses: actions/download-artifact@v4 with: - name: capi-macos-arm64 + name: capi-macos-arm path: package/cache/wasmercache3 - uses: actions/download-artifact@v4 with: @@ -996,7 +1004,7 @@ jobs: - uses: actions/download-artifact@v4 if: ${{ matrix.build == 'macos-arm64' }} with: - name: capi-macos-arm64 + name: capi-macos-arm path: download_link - uses: actions/download-artifact@v4 if: ${{ matrix.build == 'macos-x64' }} @@ -1020,19 +1028,23 @@ jobs: shell: bash run: | make untar-wasmer - - name: Test integration CLI - if: false # matrix.build != 'macos-arm' - shell: bash - run: | - export WASMER_PATH=`pwd`/target/${{ matrix.target }}/release/wasmer${{ matrix.exe }} - export WASMER_DIR=`pwd`/package && make test-integration-cli-ci - env: - TARGET: ${{ matrix.target }} - TARGET_DIR: target/${{ matrix.target }}/release - CARGO_TARGET: ${{ matrix.target }} - WAPM_DEV_TOKEN: ${{ secrets.WAPM_DEV_TOKEN }} - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - + + # Removed in favour of freestanding integration tests + # + # - name: Test integration CLI + # if: false # matrix.build != 'macos-arm' + # shell: bash + # run: | + # export WASMER_PATH=`pwd`/target/${{ matrix.target }}/release/wasmer${{ matrix.exe }} + # export WASMER_DIR=`pwd`/package && make test-integration-cli-ci + # env: + # TARGET: ${{ matrix.target }} + # TARGET_DIR: target/${{ matrix.target }}/release + # CARGO_TARGET: ${{ matrix.target }} + # WAPM_DEV_TOKEN: ${{ secrets.WAPM_DEV_TOKEN }} + # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + + # ---- # Note (xdoardo on 2024/10/07): # --- From f4a25d15394f7020f632d9d98a9011152ca2bb72 Mon Sep 17 00:00:00 2001 From: Edoardo Marangoni Date: Fri, 18 Oct 2024 00:22:47 +0200 Subject: [PATCH 04/59] Use ubuntu on target windows-gnu --- .github/workflows/test.yaml | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/.github/workflows/test.yaml b/.github/workflows/test.yaml index 111e0e29408..ddffe58f499 100644 --- a/.github/workflows/test.yaml +++ b/.github/workflows/test.yaml @@ -524,11 +524,8 @@ jobs: }, { build: windows-gnu, - os: windows-2022, target: x86_64-pc-windows-gnu, - exe: '.exe', - # For now, disable LLVM in `windows-x64.` - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + os: ubuntu-22.04, }, { build: linux-musl, From e88f5f1ae15c34229fe2d4cc31dccdb845e2c423 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 12:15:07 +0330 Subject: [PATCH 05/59] add build steps for interpreter backends --- .github/workflows/build.yml | 97 +- .github/workflows/test.yaml | 2176 ++++++++--------- .github/workflows/wasmer-config.yaml | 98 +- .../workflows/wasmer-integration-tests.yaml | 98 +- 4 files changed, 1258 insertions(+), 1211 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 08fe9a06f13..8f16f8d6f81 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -12,6 +12,9 @@ on: tags: # this is _not_ a regex, see: https://docs.github.com/en/actions/reference/workflow-syntax-for-github-actions#filter-pattern-cheat-sheet - '[0-9]+.[0-9]+.[0-9]+*' + pull_request: # TODO: MUST BE REMOVED! ONLY FOR TESTING + branches: + - 'main' # Run jobs on PRs targeting the 'main' branch workflow_dispatch: inputs: release: @@ -51,6 +54,30 @@ jobs: use_sccache: false use_llvm: true build_wasm: true + - build: linux-x64-v8 + os: ubuntu-20.04 + artifact_name: 'wasmer-v8-linux-amd64' + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' + cross_compilation_artifact_name: 'cross_compiled_from_linux' + use_sccache: false + use_llvm: true + build_wasm: true + - build: linux-x64-wamr + os: ubuntu-20.04 + artifact_name: 'wasmer-wamr-linux-amd64' + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' + cross_compilation_artifact_name: 'cross_compiled_from_linux' + use_sccache: false + use_llvm: true + build_wasm: true + - build: linux-x64-wasmi + os: ubuntu-20.04 + artifact_name: 'wasmer-wasmi-linux-amd64' + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' + cross_compilation_artifact_name: 'cross_compiled_from_linux' + use_sccache: false + use_llvm: true + build_wasm: true - build: macos-x64 os: macos-12 llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' @@ -93,6 +120,10 @@ jobs: - name: Set up base deps on musl if: matrix.build == 'linux-musl-x64' run: ./scripts/alpine-linux-install-deps.sh + - name: Install mold + if: startsWith(matrix.build, 'linux') + run: | + apt update && apt install mold - name: Install Rust uses: dtolnay/rust-toolchain@stable with: @@ -203,6 +234,22 @@ jobs: make build-wasmer env: ENABLE_LLVM: 1 + - name: Build Wasmer with v8 backend + if: endsWith(matrix.build, 'v8') + run: | + if [ "${{ matrix.build }}" == "linux-x64-v8" ] || [ "${{ matrix.build }}" == "linux-musl-x64-v8" ]; then + RUSTFLAGS="-C linker=clang -C link-arg=-fuse-ld=mold" make build-wasmer-v8 + else + make build-wasmer-v8 + fi + - name: Build Wasmer with wamr backend + if: endsWith(matrix.build, 'wamr') + run: | + make build-wasmer-wamr + - name: Build Wasmer with wasmi backend + if: endsWith(matrix.build, 'wasmi') + run: | + make build-wasmer-wasmi - name: Build Wasmer binary without LLVM if: matrix.use_llvm != true shell: bash @@ -213,31 +260,31 @@ jobs: # shell: bash # run: | # make build-wasmer-wasm - - name: Install Nightly Rust for Headless - if: matrix.build != 'linux-musl-x64' - uses: dtolnay/rust-toolchain@master - with: - toolchain: "nightly-2023-10-05" - target: ${{ matrix.target }} - components: "rust-src" - - name: Build Minimal Wasmer Headless - if: matrix.build != 'linux-musl-x64' - run: | - cargo install xargo - echo "" >> Cargo.toml - echo "[profile.release]" >> Cargo.toml - echo "opt-level = 'z'" >> Cargo.toml - echo "debug = false" >> Cargo.toml - echo "debug-assertions = false" >> Cargo.toml - echo "overflow-checks = false" >> Cargo.toml - echo "lto = true" >> Cargo.toml - echo "panic = 'abort'" >> Cargo.toml - echo "incremental = false" >> Cargo.toml - echo "codegen-units = 1" >> Cargo.toml - echo "rpath = false" >> Cargo.toml - rustup override set nightly-2023-10-05 - make build-wasmer-headless-minimal - rustup override unset + # - name: Install Nightly Rust for Headless + # if: matrix.build != 'linux-musl-x64' + # uses: dtolnay/rust-toolchain@master + # with: + # toolchain: "nightly-2023-10-05" + # target: ${{ matrix.target }} + # components: "rust-src" + # - name: Build Minimal Wasmer Headless + # if: matrix.build != 'linux-musl-x64' + # run: | + # cargo install xargo + # echo "" >> Cargo.toml + # echo "[profile.release]" >> Cargo.toml + # echo "opt-level = 'z'" >> Cargo.toml + # echo "debug = false" >> Cargo.toml + # echo "debug-assertions = false" >> Cargo.toml + # echo "overflow-checks = false" >> Cargo.toml + # echo "lto = true" >> Cargo.toml + # echo "panic = 'abort'" >> Cargo.toml + # echo "incremental = false" >> Cargo.toml + # echo "codegen-units = 1" >> Cargo.toml + # echo "rpath = false" >> Cargo.toml + # rustup override set nightly-2023-10-05 + # make build-wasmer-headless-minimal + # rustup override unset - name: Dist run: | make distribution diff --git a/.github/workflows/test.yaml b/.github/workflows/test.yaml index ddffe58f499..7ea3b591c00 100644 --- a/.github/workflows/test.yaml +++ b/.github/workflows/test.yaml @@ -1,1135 +1,1135 @@ -name: test-sys +# name: test-sys -on: - push: - branches: - - main - - 'with-ci-.*' - - 'v3.0.x' - - 'v3.1.x' - pull_request: - workflow_dispatch: - inputs: - release: - description: 'Make release' +# on: +# push: +# branches: +# - main +# - 'with-ci-.*' +# - 'v3.0.x' +# - 'v3.1.x' +# pull_request: +# workflow_dispatch: +# inputs: +# release: +# description: 'Make release' -# Automatically cancel previous workflow runs when a new commit is pushed. -concurrency: - group: ${{ github.workflow }}-${{ github.ref }} - cancel-in-progress: true +# # Automatically cancel previous workflow runs when a new commit is pushed. +# concurrency: +# group: ${{ github.workflow }}-${{ github.ref }} +# cancel-in-progress: true -env: - RUST_BACKTRACE: 1 - # Sparse will be enabled by dtolnay/rust-toolchain when installing nightly - # Rust, but it's not stable on 1.69 yet. By explicitly setting the protocol we - # can override that behaviour - CARGO_REGISTRIES_CRATES_IO_PROTOCOL: git - MSRV: "1.81" - NEXTEST_PROFILE: "ci" - RUSTUP_WINDOWS_PATH_ADD_BIN: 1 - WASI_SDK_VERSION: "22" +# env: +# RUST_BACKTRACE: 1 +# # Sparse will be enabled by dtolnay/rust-toolchain when installing nightly +# # Rust, but it's not stable on 1.69 yet. By explicitly setting the protocol we +# # can override that behaviour +# CARGO_REGISTRIES_CRATES_IO_PROTOCOL: git +# MSRV: "1.81" +# NEXTEST_PROFILE: "ci" +# RUSTUP_WINDOWS_PATH_ADD_BIN: 1 +# WASI_SDK_VERSION: "22" -jobs: - setup: - name: Set up - runs-on: ubuntu-22.04 - outputs: - VERSION: ${{ steps.setup.outputs.VERSION }} - DOING_RELEASE: ${{ steps.setup.outputs.DOING_RELEASE }} - steps: - - name: Set up env vars - id: setup - shell: bash - run: | - VERSION=${GITHUB_REF/refs\/tags\//} - echo "VERSION=${VERSION}" >> $GITHUB_OUTPUT - DOING_RELEASE=$(echo $VERSION | grep -c '^[0-9]\+\.[0-9]\+\.[0-9]\+\(-\([a-zA-Z]\+\)\?[0-9]*\)\?$' || true) - echo "DOING_RELEASE=${DOING_RELEASE}" >> $GITHUB_OUTPUT - echo $VERSION - echo $DOING_RELEASE +# jobs: +# setup: +# name: Set up +# runs-on: ubuntu-22.04 +# outputs: +# VERSION: ${{ steps.setup.outputs.VERSION }} +# DOING_RELEASE: ${{ steps.setup.outputs.DOING_RELEASE }} +# steps: +# - name: Set up env vars +# id: setup +# shell: bash +# run: | +# VERSION=${GITHUB_REF/refs\/tags\//} +# echo "VERSION=${VERSION}" >> $GITHUB_OUTPUT +# DOING_RELEASE=$(echo $VERSION | grep -c '^[0-9]\+\.[0-9]\+\.[0-9]\+\(-\([a-zA-Z]\+\)\?[0-9]*\)\?$' || true) +# echo "DOING_RELEASE=${DOING_RELEASE}" >> $GITHUB_OUTPUT +# echo $VERSION +# echo $DOING_RELEASE - lint: - name: Code lint - runs-on: ubuntu-22.04 - steps: - - uses: actions/checkout@v3 - - name: Install Rust - uses: dtolnay/rust-toolchain@stable - with: - toolchain: ${{ env.MSRV }} - components: rustfmt, clippy - - name: Install libtinfo - shell: bash - run: | - sudo apt install -y libtinfo5 - - name: Install LLVM (Linux) - run: | - curl --proto '=https' --tlsv1.2 -sSf https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz -L -o /opt/llvm.tar.xz - mkdir -p /opt/llvm-18 - tar xf /opt/llvm.tar.xz --strip-components=1 -C /opt/llvm-18 - echo '/opt/llvm-18/bin' >> $GITHUB_PATH - echo 'LLVM_SYS_180_PREFIX=/opt/llvm-18' >> $GITHUB_ENV - - name: Cache - uses: whywaita/actions-cache-s3@v2 - with: - path: | - ~/.cargo/* - ./target/* - key: r22-${{ github.repository }}-${{ runner.os }}-${{ hashFiles('Cargo.lock') }}-wasmer-make-lint-linux-x64 - aws-s3-bucket: wasmer-rust-artifacts-cache - aws-access-key-id: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_TOKEN }} - aws-secret-access-key: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_KEY }} - aws-region: auto - aws-endpoint: https://1541b1e8a3fc6ad155ce67ef38899700.r2.cloudflarestorage.com - aws-s3-bucket-endpoint: false - aws-s3-force-path-style: true - - run: make lint - env: - ENABLE_CRANELIFT: "1" - ENABLE_LLVM: "1" - ENABLE_SINGLEPASS: "1" - - name: Assert no files have changed - run: | - git status - ! [[ $(git status -s) ]] +# lint: +# name: Code lint +# runs-on: ubuntu-22.04 +# steps: +# - uses: actions/checkout@v3 +# - name: Install Rust +# uses: dtolnay/rust-toolchain@stable +# with: +# toolchain: ${{ env.MSRV }} +# components: rustfmt, clippy +# - name: Install libtinfo +# shell: bash +# run: | +# sudo apt install -y libtinfo5 +# - name: Install LLVM (Linux) +# run: | +# curl --proto '=https' --tlsv1.2 -sSf https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz -L -o /opt/llvm.tar.xz +# mkdir -p /opt/llvm-18 +# tar xf /opt/llvm.tar.xz --strip-components=1 -C /opt/llvm-18 +# echo '/opt/llvm-18/bin' >> $GITHUB_PATH +# echo 'LLVM_SYS_180_PREFIX=/opt/llvm-18' >> $GITHUB_ENV +# - name: Cache +# uses: whywaita/actions-cache-s3@v2 +# with: +# path: | +# ~/.cargo/* +# ./target/* +# key: r22-${{ github.repository }}-${{ runner.os }}-${{ hashFiles('Cargo.lock') }}-wasmer-make-lint-linux-x64 +# aws-s3-bucket: wasmer-rust-artifacts-cache +# aws-access-key-id: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_TOKEN }} +# aws-secret-access-key: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_KEY }} +# aws-region: auto +# aws-endpoint: https://1541b1e8a3fc6ad155ce67ef38899700.r2.cloudflarestorage.com +# aws-s3-bucket-endpoint: false +# aws-s3-force-path-style: true +# - run: make lint +# env: +# ENABLE_CRANELIFT: "1" +# ENABLE_LLVM: "1" +# ENABLE_SINGLEPASS: "1" +# - name: Assert no files have changed +# run: | +# git status +# ! [[ $(git status -s) ]] - cargo_deny: - name: cargo-deny - runs-on: ubuntu-22.04 - steps: - - uses: actions/checkout@v3 - - uses: EmbarkStudios/cargo-deny-action@v1 - with: - log-level: error +# cargo_deny: +# name: cargo-deny +# runs-on: ubuntu-22.04 +# steps: +# - uses: actions/checkout@v3 +# - uses: EmbarkStudios/cargo-deny-action@v1 +# with: +# log-level: error - test_nodejs: - name: Test on NodeJS - runs-on: ubuntu-22.04 - steps: - - uses: actions/checkout@v3 - - name: Install Rust - uses: dtolnay/rust-toolchain@stable - with: - toolchain: ${{ env.MSRV }} - - name: Install NodeJS - uses: actions/setup-node@v2 - with: - node-version: 16 - - name: Install wasm-pack - run: | - curl https://rustwasm.github.io/wasm-pack/installer/init.sh -sSf | sh - - name: make test-js - run: | - make test-js +# test_nodejs: +# name: Test on NodeJS +# runs-on: ubuntu-22.04 +# steps: +# - uses: actions/checkout@v3 +# - name: Install Rust +# uses: dtolnay/rust-toolchain@stable +# with: +# toolchain: ${{ env.MSRV }} +# - name: Install NodeJS +# uses: actions/setup-node@v2 +# with: +# node-version: 16 +# - name: Install wasm-pack +# run: | +# curl https://rustwasm.github.io/wasm-pack/installer/init.sh -sSf | sh +# - name: make test-js +# run: | +# make test-js - test_wasi_fyi: - name: Test wasi-fyi - runs-on: ubuntu-22.04 - steps: - - uses: actions/checkout@v3 - - name: Install Rust - uses: dtolnay/rust-toolchain@stable - with: - toolchain: nightly - targets: "wasm32-wasi" - - name: Install wasm-pack - run: | - curl https://rustwasm.github.io/wasm-pack/installer/init.sh -sSf | sh - - name: Install LLVM 18 - run: | - curl --proto '=https' --tlsv1.2 -sSf https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz -L -o llvm.tar.xz - LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} - mkdir ${LLVM_DIR} - tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} - echo "ENABLE_LLVM=1" >> $GITHUB_ENV - echo "${LLVM_DIR}/bin" >> $GITHUB_PATH - echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH - echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV - env: - LLVM_DIR: .llvm - - name: make test-wasi-fyi - run: | - make test-wasi-fyi +# test_wasi_fyi: +# name: Test wasi-fyi +# runs-on: ubuntu-22.04 +# steps: +# - uses: actions/checkout@v3 +# - name: Install Rust +# uses: dtolnay/rust-toolchain@stable +# with: +# toolchain: nightly +# targets: "wasm32-wasi" +# - name: Install wasm-pack +# run: | +# curl https://rustwasm.github.io/wasm-pack/installer/init.sh -sSf | sh +# - name: Install LLVM 18 +# run: | +# curl --proto '=https' --tlsv1.2 -sSf https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz -L -o llvm.tar.xz +# LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} +# mkdir ${LLVM_DIR} +# tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} +# echo "ENABLE_LLVM=1" >> $GITHUB_ENV +# echo "${LLVM_DIR}/bin" >> $GITHUB_PATH +# echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH +# echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV +# env: +# LLVM_DIR: .llvm +# - name: make test-wasi-fyi +# run: | +# make test-wasi-fyi - # The no_std functionality doesn't work at the moment - no point in testing it. - # - name: make test-js-core - # run: | - # make test-js-core +# # The no_std functionality doesn't work at the moment - no point in testing it. +# # - name: make test-js-core +# # run: | +# # make test-js-core - test_wasix: - name: Test WASIX - runs-on: ubuntu-22.04 - steps: - - uses: actions/checkout@v3 - - name: Install Rust - uses: dtolnay/rust-toolchain@stable - with: - toolchain: ${{ env.MSRV }} - - name: Install Tools - run: | - sudo apt-get update - sudo apt-get install -y git llvm clang make lld curl - - name: Build wasix sysroot - run: | - cd ~ - git clone --recurse-submodules https://github.com/wasix-org/wasix-libc - cd wasix-libc - ./build32.sh - rm -rf /opt/wasix-sysroot - cp -r sysroot32 ~/wasix-sysroot - - name: Install wasi-sdk Tools - run: | - cd ~ - curl -L "https://github.com/WebAssembly/wasi-sdk/releases/download/wasi-sdk-${{ env.WASI_SDK_VERSION }}/wasi-sdk-${{ env.WASI_SDK_VERSION }}.0-linux.tar.gz" -o wasi-sdk.tar.gz - tar -xzf wasi-sdk.tar.gz - cp -r wasi-sdk-${{ env.WASI_SDK_VERSION }}.0 ~/wasi-sdk - - name: Install LLVM 18 - run: | - curl --proto '=https' --tlsv1.2 -sSf https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz -L -o llvm.tar.xz - LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} - mkdir ${LLVM_DIR} - tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} - echo "ENABLE_LLVM=1" >> $GITHUB_ENV - echo "${LLVM_DIR}/bin" >> $GITHUB_PATH - echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH - echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV - env: - LLVM_DIR: .llvm - - name: Install wasm-opt - run: | - sudo apt-get install -y binaryen - - name: make test-wasix - run: | - WASI_SDK=~/wasi-sdk WASIX_SYSROOT=~/wasix-sysroot make test-wasix +# test_wasix: +# name: Test WASIX +# runs-on: ubuntu-22.04 +# steps: +# - uses: actions/checkout@v3 +# - name: Install Rust +# uses: dtolnay/rust-toolchain@stable +# with: +# toolchain: ${{ env.MSRV }} +# - name: Install Tools +# run: | +# sudo apt-get update +# sudo apt-get install -y git llvm clang make lld curl +# - name: Build wasix sysroot +# run: | +# cd ~ +# git clone --recurse-submodules https://github.com/wasix-org/wasix-libc +# cd wasix-libc +# ./build32.sh +# rm -rf /opt/wasix-sysroot +# cp -r sysroot32 ~/wasix-sysroot +# - name: Install wasi-sdk Tools +# run: | +# cd ~ +# curl -L "https://github.com/WebAssembly/wasi-sdk/releases/download/wasi-sdk-${{ env.WASI_SDK_VERSION }}/wasi-sdk-${{ env.WASI_SDK_VERSION }}.0-linux.tar.gz" -o wasi-sdk.tar.gz +# tar -xzf wasi-sdk.tar.gz +# cp -r wasi-sdk-${{ env.WASI_SDK_VERSION }}.0 ~/wasi-sdk +# - name: Install LLVM 18 +# run: | +# curl --proto '=https' --tlsv1.2 -sSf https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz -L -o llvm.tar.xz +# LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} +# mkdir ${LLVM_DIR} +# tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} +# echo "ENABLE_LLVM=1" >> $GITHUB_ENV +# echo "${LLVM_DIR}/bin" >> $GITHUB_PATH +# echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH +# echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV +# env: +# LLVM_DIR: .llvm +# - name: Install wasm-opt +# run: | +# sudo apt-get install -y binaryen +# - name: make test-wasix +# run: | +# WASI_SDK=~/wasi-sdk WASIX_SYSROOT=~/wasix-sysroot make test-wasix - test_wasm_build: - name: Test wasm build - runs-on: ubuntu-22.04 - steps: - - uses: actions/checkout@v3 - - name: rustup target add wasm32-wasi - run: rustup target add wasm32-wasi - - name: make build-wasmer-wasm - run: make build-wasmer-wasm +# test_wasm_build: +# name: Test wasm build +# runs-on: ubuntu-22.04 +# steps: +# - uses: actions/checkout@v3 +# - name: rustup target add wasm32-wasi +# run: rustup target add wasm32-wasi +# - name: make build-wasmer-wasm +# run: make build-wasmer-wasm - test_build_jsc: - name: Test JSC build - runs-on: ubuntu-22.04 - steps: - - uses: actions/checkout@v3 - - uses: dtolnay/rust-toolchain@stable - with: - toolchain: ${{ env.MSRV }} - target: x86_64-unknown-linux-gnu - - name: Install NodeJS - uses: actions/setup-node@v2 - with: - node-version: 16 - - name: Install libjavascriptcoregtk-4.0-dev - run: sudo apt update && sudo apt install -y libjavascriptcoregtk-4.0-dev - - name: make build-wasmer-jsc - run: make build-wasmer-jsc +# test_build_jsc: +# name: Test JSC build +# runs-on: ubuntu-22.04 +# steps: +# - uses: actions/checkout@v3 +# - uses: dtolnay/rust-toolchain@stable +# with: +# toolchain: ${{ env.MSRV }} +# target: x86_64-unknown-linux-gnu +# - name: Install NodeJS +# uses: actions/setup-node@v2 +# with: +# node-version: 16 +# - name: Install libjavascriptcoregtk-4.0-dev +# run: sudo apt update && sudo apt install -y libjavascriptcoregtk-4.0-dev +# - name: make build-wasmer-jsc +# run: make build-wasmer-jsc - test_interpreter_api: - name: ${{ matrix.build-what.name }} on ${{ matrix.metadata.build }} - runs-on: ${{ matrix.metadata.os }} - strategy: - fail-fast: false - matrix: - build-what: [ - { - key: wamr, - build-cmd: 'make test-wamr-api', - name: 'Test API for wamr feature' - }, - { - key: wasmi, - build-cmd: 'make test-wasmi-api', - name: 'Test API for wasmi feature' - }, - { - key: v8, - build-cmd: 'make test-v8-api', - name: 'Test API for v8 feature' - } +# test_interpreter_api: +# name: ${{ matrix.build-what.name }} on ${{ matrix.metadata.build }} +# runs-on: ${{ matrix.metadata.os }} +# strategy: +# fail-fast: false +# matrix: +# build-what: [ +# { +# key: wamr, +# build-cmd: 'make test-wamr-api', +# name: 'Test API for wamr feature' +# }, +# { +# key: wasmi, +# build-cmd: 'make test-wasmi-api', +# name: 'Test API for wasmi feature' +# }, +# { +# key: v8, +# build-cmd: 'make test-v8-api', +# name: 'Test API for v8 feature' +# } - ] - metadata: [ - { - build: linux-x64, - os: ubuntu-22.04, - }, - { - build: macos-arm, - os: macos-14, - }, - { - build: windows-x64, - os: windows-2022, - } - ] - container: ${{ matrix.metadata.container }} - steps: - - uses: actions/checkout@v3 +# ] +# metadata: [ +# { +# build: linux-x64, +# os: ubuntu-22.04, +# }, +# { +# build: macos-arm, +# os: macos-14, +# }, +# { +# build: windows-x64, +# os: windows-2022, +# } +# ] +# container: ${{ matrix.metadata.container }} +# steps: +# - uses: actions/checkout@v3 - - name: Setup MSVC (Windows) - uses: ilammy/msvc-dev-cmd@v1 - if: matrix.metadata.build == 'windows-x64' +# - name: Setup MSVC (Windows) +# uses: ilammy/msvc-dev-cmd@v1 +# if: matrix.metadata.build == 'windows-x64' - - uses: dtolnay/rust-toolchain@stable - with: - toolchain: ${{ env.MSRV }} +# - uses: dtolnay/rust-toolchain@stable +# with: +# toolchain: ${{ env.MSRV }} - - name: Install Nextest - uses: taiki-e/install-action@nextest +# - name: Install Nextest +# uses: taiki-e/install-action@nextest - - name: Install `ninja`, clang` and `mold` on Ubuntu - if: startsWith(matrix.metadata.build, 'linux-') - shell: bash - run: | - sudo apt-get update -y && sudo apt-get install ninja-build clang mold -y +# - name: Install `ninja`, clang` and `mold` on Ubuntu +# if: startsWith(matrix.metadata.build, 'linux-') +# shell: bash +# run: | +# sudo apt-get update -y && sudo apt-get install ninja-build clang mold -y - - name: Install `ninja` on macOS - if: startsWith(matrix.metadata.build, 'macos-') - shell: bash - run: | - brew install ninja +# - name: Install `ninja` on macOS +# if: startsWith(matrix.metadata.build, 'macos-') +# shell: bash +# run: | +# brew install ninja - - name: Install `ninja` on Windows - if: startsWith(matrix.metadata.build, 'windows-') - shell: bash - run: | - choco install ninja +# - name: Install `ninja` on Windows +# if: startsWith(matrix.metadata.build, 'windows-') +# shell: bash +# run: | +# choco install ninja - - name: Delete unwanted link to stop it from interfering (Windows) - shell: bash - run: rm /usr/bin/link.exe - if: startsWith(matrix.metadata.build, 'windows-') +# - name: Delete unwanted link to stop it from interfering (Windows) +# shell: bash +# run: rm /usr/bin/link.exe +# if: startsWith(matrix.metadata.build, 'windows-') - - name: Test WAMR API - if: ${{ matrix.build-what.key == 'wamr' }} - run: ${{ matrix.build-what.build-cmd }} +# - name: Test WAMR API +# if: ${{ matrix.build-what.key == 'wamr' }} +# run: ${{ matrix.build-what.build-cmd }} - - name: Test wasmi API - if: ${{ matrix.build-what.key == 'wasmi' }} - run: ${{ matrix.build-what.build-cmd }} +# - name: Test wasmi API +# if: ${{ matrix.build-what.key == 'wasmi' }} +# run: ${{ matrix.build-what.build-cmd }} - - name: Test v8 API (Linux + mold) - if: ${{ matrix.build-what.key == 'v8' && startsWith(matrix.metadata.build, 'linux-')}} - run: RUSTFLAGS="-C linker=clang -C link-arg=-fuse-ld=mold" CARGO_TERM_VERBOSE=true cargo nextest run --package=wasmer --release --features=v8 --no-default-features +# - name: Test v8 API (Linux + mold) +# if: ${{ matrix.build-what.key == 'v8' && startsWith(matrix.metadata.build, 'linux-')}} +# run: RUSTFLAGS="-C linker=clang -C link-arg=-fuse-ld=mold" CARGO_TERM_VERBOSE=true cargo nextest run --package=wasmer --release --features=v8 --no-default-features - - name: Test v8 API - if: ${{ matrix.build-what.key == 'v8' && !startsWith(matrix.metadata.build, 'linux-')}} - run: ${{ matrix.build-what.build-cmd }} +# - name: Test v8 API +# if: ${{ matrix.build-what.key == 'v8' && !startsWith(matrix.metadata.build, 'linux-')}} +# run: ${{ matrix.build-what.build-cmd }} - test_build_docs_rs: - name: Test build docs rs - runs-on: ubuntu-22.04 - steps: - - uses: actions/checkout@v3 - - uses: dtolnay/rust-toolchain@master - with: - toolchain: "nightly-2024-08-21" - target: x86_64-unknown-linux-gnu - - run: cargo install toml-cli # toml-cli is required to run `make test-build-docs-rs` +# test_build_docs_rs: +# name: Test build docs rs +# runs-on: ubuntu-22.04 +# steps: +# - uses: actions/checkout@v3 +# - uses: dtolnay/rust-toolchain@master +# with: +# toolchain: "nightly-2024-08-21" +# target: x86_64-unknown-linux-gnu +# - run: cargo install toml-cli # toml-cli is required to run `make test-build-docs-rs` - - name: Install `ninja` on Ubuntu - shell: bash - run: | - sudo apt-get install ninja-build -y +# - name: Install `ninja` on Ubuntu +# shell: bash +# run: | +# sudo apt-get install ninja-build -y - - name: Install LLVM 18 - run: | - curl --proto '=https' --tlsv1.2 -sSf https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz -L -o llvm.tar.xz - LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} - mkdir ${LLVM_DIR} - tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} - echo "ENABLE_LLVM=1" >> $GITHUB_ENV - echo "${LLVM_DIR}/bin" >> $GITHUB_PATH - echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH - echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV - env: - LLVM_DIR: .llvm - - name: make test-build-docs-rs-ci - run: make test-build-docs-rs-ci +# - name: Install LLVM 18 +# run: | +# curl --proto '=https' --tlsv1.2 -sSf https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz -L -o llvm.tar.xz +# LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} +# mkdir ${LLVM_DIR} +# tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} +# echo "ENABLE_LLVM=1" >> $GITHUB_ENV +# echo "${LLVM_DIR}/bin" >> $GITHUB_PATH +# echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH +# echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV +# env: +# LLVM_DIR: .llvm +# - name: make test-build-docs-rs-ci +# run: make test-build-docs-rs-ci - build_linux_aarch64: - name: ${{ matrix.build-what.name }} on linux-aarch64 - runs-on: ubuntu-22.04 - strategy: - fail-fast: false - matrix: - build-what: [ - { - key: capi, - build-cmd: 'make build-capi && make package-capi', - name: 'Build C-API' - }, - { - key: wasmer, - build-cmd: 'make build-wasmer && make package-wasmer && make tar-wasmer', - name: 'Build wasmer-cli' - } - ] - steps: - - uses: actions/checkout@v3 - - uses: dtolnay/rust-toolchain@stable - with: - toolchain: ${{ env.MSRV }} - target: aarch64-unknown-linux-gnu - - name: Build cross image - run: | - docker build -t wasmer/aarch64 ${GITHUB_WORKSPACE}/.github/cross-linux-aarch64/ - env: - CROSS_DOCKER_IN_DOCKER: true - - name: Build ${{ matrix.build-what.key }} - run: | - ${{ matrix.build-what.build-cmd }} - env: - CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross - CROSS_DOCKER_IN_DOCKER: true - CARGO_TARGET: aarch64-unknown-linux-gnu - PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig - PKG_CONFIG_ALLOW_CROSS: true - ENABLE_LLVM: 0 - - name: Dist - if: ${{ matrix.build-what.key == 'capi' }} - run: | - make distribution - env: - CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross - CROSS_DOCKER_IN_DOCKER: true - CARGO_TARGET: aarch64-unknown-linux-gnu - PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig - PKG_CONFIG_ALLOW_CROSS: true - TARGET: aarch64-unknown-linux-gnu - TARGET_DIR: target/aarch64-unknown-linux-gnu/release - - name: Upload Artifacts - if: ${{ matrix.build-what.key == 'capi' }} - uses: actions/upload-artifact@v4 - with: - name: capi-linux-aarch64 - path: dist - if-no-files-found: error - retention-days: 2 +# build_linux_aarch64: +# name: ${{ matrix.build-what.name }} on linux-aarch64 +# runs-on: ubuntu-22.04 +# strategy: +# fail-fast: false +# matrix: +# build-what: [ +# { +# key: capi, +# build-cmd: 'make build-capi && make package-capi', +# name: 'Build C-API' +# }, +# { +# key: wasmer, +# build-cmd: 'make build-wasmer && make package-wasmer && make tar-wasmer', +# name: 'Build wasmer-cli' +# } +# ] +# steps: +# - uses: actions/checkout@v3 +# - uses: dtolnay/rust-toolchain@stable +# with: +# toolchain: ${{ env.MSRV }} +# target: aarch64-unknown-linux-gnu +# - name: Build cross image +# run: | +# docker build -t wasmer/aarch64 ${GITHUB_WORKSPACE}/.github/cross-linux-aarch64/ +# env: +# CROSS_DOCKER_IN_DOCKER: true +# - name: Build ${{ matrix.build-what.key }} +# run: | +# ${{ matrix.build-what.build-cmd }} +# env: +# CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross +# CROSS_DOCKER_IN_DOCKER: true +# CARGO_TARGET: aarch64-unknown-linux-gnu +# PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig +# PKG_CONFIG_ALLOW_CROSS: true +# ENABLE_LLVM: 0 +# - name: Dist +# if: ${{ matrix.build-what.key == 'capi' }} +# run: | +# make distribution +# env: +# CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross +# CROSS_DOCKER_IN_DOCKER: true +# CARGO_TARGET: aarch64-unknown-linux-gnu +# PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig +# PKG_CONFIG_ALLOW_CROSS: true +# TARGET: aarch64-unknown-linux-gnu +# TARGET_DIR: target/aarch64-unknown-linux-gnu/release +# - name: Upload Artifacts +# if: ${{ matrix.build-what.key == 'capi' }} +# uses: actions/upload-artifact@v4 +# with: +# name: capi-linux-aarch64 +# path: dist +# if-no-files-found: error +# retention-days: 2 - build_linux_riscv64: - name: ${{ matrix.build-what.name }} on linux-riscv64 - runs-on: ubuntu-22.04 - strategy: - fail-fast: false - matrix: - build-what: [ - { - key: capi, - build-cmd: 'make build-capi && make package-capi', - name: 'Build C-API' - }, - { - key: wasmer, - build-cmd: 'make build-wasmer && make package-wasmer && make tar-wasmer', - name: 'Build wasmer-cli' - } - ] - steps: - - uses: actions/checkout@v3 - #- uses: dtolnay/rust-toolchain@stable - # with: - # toolchain: ${{ env.MSRV }} - # target: riscv64gc-unknown-linux-gnu - - name: Build cross image - run: | - docker build -t wasmer/riscv64 ${GITHUB_WORKSPACE}/.github/cross-linux-riscv64/ - env: - CROSS_DOCKER_IN_DOCKER: true - - name: Build ${{ matrix.build-what.key }} - run: | - ${{ matrix.build-what.build-cmd }} - env: - CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64 cargo - CROSS_DOCKER_IN_DOCKER: true - CARGO_TARGET: riscv64gc-unknown-linux-gnu - ENABLE_LLVM: 0 - - name: Dist - if: ${{ matrix.build-what.key == 'capi' }} - run: | - make distribution - env: - CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64 cargo - CROSS_DOCKER_IN_DOCKER: true - CARGO_TARGET: riscv64gc-unknown-linux-gnu - PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig - PKG_CONFIG_ALLOW_CROSS: true - TARGET: riscv64gc-unknown-linux-gnu - TARGET_DIR: target/riscv64gc-unknown-linux-gnu/release - - name: Upload Artifacts - if: ${{ matrix.build-what.key == 'capi' }} - uses: actions/upload-artifact@v4 - with: - name: capi-linux-riscv64 - path: dist - if-no-files-found: error - retention-days: 2 +# build_linux_riscv64: +# name: ${{ matrix.build-what.name }} on linux-riscv64 +# runs-on: ubuntu-22.04 +# strategy: +# fail-fast: false +# matrix: +# build-what: [ +# { +# key: capi, +# build-cmd: 'make build-capi && make package-capi', +# name: 'Build C-API' +# }, +# { +# key: wasmer, +# build-cmd: 'make build-wasmer && make package-wasmer && make tar-wasmer', +# name: 'Build wasmer-cli' +# } +# ] +# steps: +# - uses: actions/checkout@v3 +# #- uses: dtolnay/rust-toolchain@stable +# # with: +# # toolchain: ${{ env.MSRV }} +# # target: riscv64gc-unknown-linux-gnu +# - name: Build cross image +# run: | +# docker build -t wasmer/riscv64 ${GITHUB_WORKSPACE}/.github/cross-linux-riscv64/ +# env: +# CROSS_DOCKER_IN_DOCKER: true +# - name: Build ${{ matrix.build-what.key }} +# run: | +# ${{ matrix.build-what.build-cmd }} +# env: +# CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64 cargo +# CROSS_DOCKER_IN_DOCKER: true +# CARGO_TARGET: riscv64gc-unknown-linux-gnu +# ENABLE_LLVM: 0 +# - name: Dist +# if: ${{ matrix.build-what.key == 'capi' }} +# run: | +# make distribution +# env: +# CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64 cargo +# CROSS_DOCKER_IN_DOCKER: true +# CARGO_TARGET: riscv64gc-unknown-linux-gnu +# PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig +# PKG_CONFIG_ALLOW_CROSS: true +# TARGET: riscv64gc-unknown-linux-gnu +# TARGET_DIR: target/riscv64gc-unknown-linux-gnu/release +# - name: Upload Artifacts +# if: ${{ matrix.build-what.key == 'capi' }} +# uses: actions/upload-artifact@v4 +# with: +# name: capi-linux-riscv64 +# path: dist +# if-no-files-found: error +# retention-days: 2 - build: - name: ${{ matrix.build-what.name }} on ${{ matrix.metadata.build }} - runs-on: ${{ matrix.metadata.os }} - needs: setup - strategy: - fail-fast: false - matrix: - build-what: [ - { - key: capi, - build-cmd: 'make build-capi && make build-capi-headless && make package-capi && make tar-capi', - name: 'Build and test C-API' - }, - { - key: wasmer, - build-cmd: 'make build-wasmer && make package-wasmer && make tar-wasmer', - name: 'Build wasmer-cli' - } - ] - metadata: [ - { - build: linux-x64, - os: ubuntu-22.04, - target: x86_64-unknown-linux-gnu, - exe: '', - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' - }, - { - build: macos-x64, - os: macos-12, - target: x86_64-apple-darwin, - exe: '', - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' +# build: +# name: ${{ matrix.build-what.name }} on ${{ matrix.metadata.build }} +# runs-on: ${{ matrix.metadata.os }} +# needs: setup +# strategy: +# fail-fast: false +# matrix: +# build-what: [ +# { +# key: capi, +# build-cmd: 'make build-capi && make build-capi-headless && make package-capi && make tar-capi', +# name: 'Build and test C-API' +# }, +# { +# key: wasmer, +# build-cmd: 'make build-wasmer && make package-wasmer && make tar-wasmer', +# name: 'Build wasmer-cli' +# } +# ] +# metadata: [ +# { +# build: linux-x64, +# os: ubuntu-22.04, +# target: x86_64-unknown-linux-gnu, +# exe: '', +# llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' +# }, +# { +# build: macos-x64, +# os: macos-12, +# target: x86_64-apple-darwin, +# exe: '', +# llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' - }, - { - build: macos-arm, - os: macos-14, - target: aarch64-apple-darwin, - exe: '', - # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' - }, - { - build: windows-x64, - os: windows-2022, - target: x86_64-pc-windows-msvc, - exe: '.exe', - # For now, disable LLVM in `windows-x64.` - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' - }, - { - build: windows-gnu, - target: x86_64-pc-windows-gnu, - os: ubuntu-22.04, - }, - { - build: linux-musl, - target: x86_64-unknown-linux-musl, - os: ubuntu-22.04, - exe: '', - container: 'alpine:latest' - } +# }, +# { +# build: macos-arm, +# os: macos-14, +# target: aarch64-apple-darwin, +# exe: '', +# # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. +# # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' +# }, +# { +# build: windows-x64, +# os: windows-2022, +# target: x86_64-pc-windows-msvc, +# exe: '.exe', +# # For now, disable LLVM in `windows-x64.` +# # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' +# }, +# { +# build: windows-gnu, +# target: x86_64-pc-windows-gnu, +# os: ubuntu-22.04, +# }, +# { +# build: linux-musl, +# target: x86_64-unknown-linux-musl, +# os: ubuntu-22.04, +# exe: '', +# container: 'alpine:latest' +# } - ] - container: ${{ matrix.metadata.container }} - env: - SCCACHE_AZURE_BLOB_CONTAINER: wasmerstoragesccacheblob - SCCACHE_AZURE_CONNECTION_STRING: ${{ secrets.SCCACHE_AZURE_CONNECTION_STRING }} - steps: - - uses: actions/checkout@v3 - - name: Set up libstdc++ on Linux - if: matrix.metadata.build == 'linux-x64' - run: | - sudo apt-get update -y - sudo apt-get install -y --allow-downgrades libstdc++6 libtinfo5 - sudo apt-get install --reinstall g++ - - name: Set up base deps on musl - if: matrix.metadata.build == 'linux-musl' - run: ./scripts/alpine-linux-install-deps.sh - - name: Set up dependencies for Mac OS - run: | - brew install automake - # using gnu-tar is a workaround for https://github.com/actions/cache/issues/403 - brew install gnu-tar - echo PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH" >> $GITHUB_ENV - if: matrix.metadata.os == 'macos-12' - - name: Install Rust - uses: dtolnay/rust-toolchain@stable - with: - toolchain: ${{ env.MSRV }} - target: ${{ matrix.metadata.target }} - - name: Install Nextest - uses: taiki-e/install-action@nextest - - name: Install MSVC dev-cmd (Windows) - uses: ilammy/msvc-dev-cmd@v1 - if: ${{ matrix.metadata.build == 'windows-x64' }} - - name: Delete unwanted link to stop it from interfering (Windows) - shell: bash - run: rm /usr/bin/link.exe - if: ${{ matrix.metadata.build == 'windows-x64' }} - - name: Install Windows-GNU linker - if: ${{ matrix.metadata.build == 'windows-gnu' }} - shell: bash - run: | - sudo apt install -y mingw-w64 - - name: Install Windows-GNU target - if: ${{ matrix.metadata.build == 'windows-gnu' }} - shell: bash - run: | - rustup target add x86_64-pc-windows-gnu - - name: Install Windows 10 SDK with xwin - if: ${{ matrix.metadata.build == 'windows-gnu' }} - shell: bash - run: | - mkdir -p /tmp/xwin - mkdir -p /tmp/xwindownload - mkdir -p /tmp/xwincache - git clone https://github.com/wasmerio/xwin --depth=1 /tmp/xwin - cargo build --release --manifest-path=/tmp/xwin/Cargo.toml - /tmp/xwin/target/release/xwin --accept-license --cache-dir /tmp/xwincache splat --output /tmp/xwindownload - mkdir -p /tmp/winsdk - cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/WS2_32.lib /tmp/winsdk/ - cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/KERNEL32.lib /tmp/winsdk/ - cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/BCRYPT.lib /tmp/winsdk/ - cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/ADVAPI32.lib /tmp/winsdk/ - cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/USERENV.lib /tmp/winsdk/ - echo "WinSDK files:" - ls -laH /tmp/winsdk - echo "" - mkdir -p package - mkdir -p package/winsdk - cp -r /tmp/winsdk/* package/winsdk - - name: Install LLVM (macOS Apple Silicon) - if: matrix.metadata.os == 'macos-12' && !matrix.metadata.llvm_url - run: | - brew install llvm - - name: Install LLVM - shell: bash - if: matrix.metadata.llvm_url - run: | - curl --proto '=https' --tlsv1.2 -sSf ${{ matrix.metadata.llvm_url }} -L -o llvm.tar.xz - LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} - mkdir ${LLVM_DIR} - tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} - echo "ENABLE_LLVM=1" >> $GITHUB_ENV - echo "${LLVM_DIR}/bin" >> $GITHUB_PATH - echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH - echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV - env: - LLVM_DIR: .llvm - - name: Add `brew` libs to `RUSTFLAGS` - if: matrix.metadata.os == 'macos-14' - shell: bash - run: | - echo "RUSTFLAGS=-L/opt/homebrew/lib" >> $GITHUB_ENV - - name: Setup Rust target - shell: bash - run: | - mkdir -p .cargo - cat << EOF > .cargo/config.toml - [build] - target = "${{ matrix.metadata.target }}" - EOF - if: matrix.metadata.target - - name: which cargo - if: ${{ matrix.build-what.key == 'capi' && matrix.metadata.build == 'windows-x64' }} - run: which cargo - - name: Set cargo env - run: echo "CARGO_ROOT_DIR=$(dirname $(dirname $( which cargo )))" >> $GITHUB_ENV - - name: List root dir - shell: bash - if: ${{ matrix.build-what.key == 'capi' && matrix.metadata.build == 'windows-x64' }} - run: ls -R $CARGO_ROOT_DIR - - name: Cache - uses: whywaita/actions-cache-s3@v2 - with: - path: | - ~/.cargo/* - ./target/* - $CARGO_ROOT_DIR/* - key: r22-${{ github.repository }}-${{ runner.os }}-${{ hashFiles('Cargo.lock') }}-wasmer-make-build-wasmer-${{ matrix.build-what.key }}-${{ matrix.metadata.build }} - aws-s3-bucket: wasmer-rust-artifacts-cache - aws-access-key-id: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_TOKEN }} - aws-secret-access-key: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_KEY }} - aws-region: auto - aws-endpoint: https://1541b1e8a3fc6ad155ce67ef38899700.r2.cloudflarestorage.com - aws-s3-bucket-endpoint: false - aws-s3-force-path-style: true - - name: Build C-API - shell: bash - run: ${{ matrix.build-what.build-cmd }} - if: ${{ matrix.build-what.key == 'capi' }} - env: - TARGET: ${{ matrix.metadata.target }} - TARGET_DIR: target/${{ matrix.metadata.target }}/release - CARGO_TARGET: ${{ matrix.metadata.target }} - - name: Build Wasmer - shell: bash - if: ${{ matrix.build-what.key == 'wasmer' && matrix.metadata.build != 'windows-gnu' }} - run: ${{ matrix.build-what.build-cmd }} - env: - TARGET: ${{ matrix.metadata.target }} - TARGET_DIR: target/${{ matrix.metadata.target }}/release - CARGO_TARGET: ${{ matrix.metadata.target }} - - name: Test C-API - shell: bash - if: ${{ matrix.build-what.key == 'capi' && !(matrix.metadata.build == 'linux-musl' || matrix.metadata.build == 'windows-gnu') }} - run: make test-capi-ci - env: - TARGET: ${{ matrix.metadata.target }} - TARGET_DIR: target/${{ matrix.metadata.target }}/release - CARGO_TARGET: ${{ matrix.metadata.target }} - # C-API tests were disabled for linux-musl and macos-arm (we can't run them) - - name: Test C-API integration - shell: bash - if: ${{ matrix.build-what.key == 'capi' && !(matrix.metadata.build == 'linux-musl' || matrix.metadata.build == 'windows-gnu') }} - run: export WASMER_DIR=`pwd`/package && make test-stage-7-capi-integration-tests - env: - TARGET: ${{ matrix.metadata.target }} - TARGET_DIR: target/${{ matrix.metadata.target }}/release - CARGO_TARGET: ${{ matrix.metadata.target }} - - name: Archive production artifacts - uses: actions/upload-artifact@v4 - with: - name: wasmer-cli-${{ matrix.metadata.build }} - path: build-wasmer.tar.gz - if-no-files-found: ignore - retention-days: 2 - - name: Archive production artifacts - uses: actions/upload-artifact@v4 - with: - name: capi-${{ matrix.metadata.build }} - path: build-capi.tar.gz - if-no-files-found: ignore - retention-days: 2 +# ] +# container: ${{ matrix.metadata.container }} +# env: +# SCCACHE_AZURE_BLOB_CONTAINER: wasmerstoragesccacheblob +# SCCACHE_AZURE_CONNECTION_STRING: ${{ secrets.SCCACHE_AZURE_CONNECTION_STRING }} +# steps: +# - uses: actions/checkout@v3 +# - name: Set up libstdc++ on Linux +# if: matrix.metadata.build == 'linux-x64' +# run: | +# sudo apt-get update -y +# sudo apt-get install -y --allow-downgrades libstdc++6 libtinfo5 +# sudo apt-get install --reinstall g++ +# - name: Set up base deps on musl +# if: matrix.metadata.build == 'linux-musl' +# run: ./scripts/alpine-linux-install-deps.sh +# - name: Set up dependencies for Mac OS +# run: | +# brew install automake +# # using gnu-tar is a workaround for https://github.com/actions/cache/issues/403 +# brew install gnu-tar +# echo PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH" >> $GITHUB_ENV +# if: matrix.metadata.os == 'macos-12' +# - name: Install Rust +# uses: dtolnay/rust-toolchain@stable +# with: +# toolchain: ${{ env.MSRV }} +# target: ${{ matrix.metadata.target }} +# - name: Install Nextest +# uses: taiki-e/install-action@nextest +# - name: Install MSVC dev-cmd (Windows) +# uses: ilammy/msvc-dev-cmd@v1 +# if: ${{ matrix.metadata.build == 'windows-x64' }} +# - name: Delete unwanted link to stop it from interfering (Windows) +# shell: bash +# run: rm /usr/bin/link.exe +# if: ${{ matrix.metadata.build == 'windows-x64' }} +# - name: Install Windows-GNU linker +# if: ${{ matrix.metadata.build == 'windows-gnu' }} +# shell: bash +# run: | +# sudo apt install -y mingw-w64 +# - name: Install Windows-GNU target +# if: ${{ matrix.metadata.build == 'windows-gnu' }} +# shell: bash +# run: | +# rustup target add x86_64-pc-windows-gnu +# - name: Install Windows 10 SDK with xwin +# if: ${{ matrix.metadata.build == 'windows-gnu' }} +# shell: bash +# run: | +# mkdir -p /tmp/xwin +# mkdir -p /tmp/xwindownload +# mkdir -p /tmp/xwincache +# git clone https://github.com/wasmerio/xwin --depth=1 /tmp/xwin +# cargo build --release --manifest-path=/tmp/xwin/Cargo.toml +# /tmp/xwin/target/release/xwin --accept-license --cache-dir /tmp/xwincache splat --output /tmp/xwindownload +# mkdir -p /tmp/winsdk +# cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/WS2_32.lib /tmp/winsdk/ +# cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/KERNEL32.lib /tmp/winsdk/ +# cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/BCRYPT.lib /tmp/winsdk/ +# cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/ADVAPI32.lib /tmp/winsdk/ +# cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/USERENV.lib /tmp/winsdk/ +# echo "WinSDK files:" +# ls -laH /tmp/winsdk +# echo "" +# mkdir -p package +# mkdir -p package/winsdk +# cp -r /tmp/winsdk/* package/winsdk +# - name: Install LLVM (macOS Apple Silicon) +# if: matrix.metadata.os == 'macos-12' && !matrix.metadata.llvm_url +# run: | +# brew install llvm +# - name: Install LLVM +# shell: bash +# if: matrix.metadata.llvm_url +# run: | +# curl --proto '=https' --tlsv1.2 -sSf ${{ matrix.metadata.llvm_url }} -L -o llvm.tar.xz +# LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} +# mkdir ${LLVM_DIR} +# tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} +# echo "ENABLE_LLVM=1" >> $GITHUB_ENV +# echo "${LLVM_DIR}/bin" >> $GITHUB_PATH +# echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH +# echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV +# env: +# LLVM_DIR: .llvm +# - name: Add `brew` libs to `RUSTFLAGS` +# if: matrix.metadata.os == 'macos-14' +# shell: bash +# run: | +# echo "RUSTFLAGS=-L/opt/homebrew/lib" >> $GITHUB_ENV +# - name: Setup Rust target +# shell: bash +# run: | +# mkdir -p .cargo +# cat << EOF > .cargo/config.toml +# [build] +# target = "${{ matrix.metadata.target }}" +# EOF +# if: matrix.metadata.target +# - name: which cargo +# if: ${{ matrix.build-what.key == 'capi' && matrix.metadata.build == 'windows-x64' }} +# run: which cargo +# - name: Set cargo env +# run: echo "CARGO_ROOT_DIR=$(dirname $(dirname $( which cargo )))" >> $GITHUB_ENV +# - name: List root dir +# shell: bash +# if: ${{ matrix.build-what.key == 'capi' && matrix.metadata.build == 'windows-x64' }} +# run: ls -R $CARGO_ROOT_DIR +# - name: Cache +# uses: whywaita/actions-cache-s3@v2 +# with: +# path: | +# ~/.cargo/* +# ./target/* +# $CARGO_ROOT_DIR/* +# key: r22-${{ github.repository }}-${{ runner.os }}-${{ hashFiles('Cargo.lock') }}-wasmer-make-build-wasmer-${{ matrix.build-what.key }}-${{ matrix.metadata.build }} +# aws-s3-bucket: wasmer-rust-artifacts-cache +# aws-access-key-id: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_TOKEN }} +# aws-secret-access-key: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_KEY }} +# aws-region: auto +# aws-endpoint: https://1541b1e8a3fc6ad155ce67ef38899700.r2.cloudflarestorage.com +# aws-s3-bucket-endpoint: false +# aws-s3-force-path-style: true +# - name: Build C-API +# shell: bash +# run: ${{ matrix.build-what.build-cmd }} +# if: ${{ matrix.build-what.key == 'capi' }} +# env: +# TARGET: ${{ matrix.metadata.target }} +# TARGET_DIR: target/${{ matrix.metadata.target }}/release +# CARGO_TARGET: ${{ matrix.metadata.target }} +# - name: Build Wasmer +# shell: bash +# if: ${{ matrix.build-what.key == 'wasmer' && matrix.metadata.build != 'windows-gnu' }} +# run: ${{ matrix.build-what.build-cmd }} +# env: +# TARGET: ${{ matrix.metadata.target }} +# TARGET_DIR: target/${{ matrix.metadata.target }}/release +# CARGO_TARGET: ${{ matrix.metadata.target }} +# - name: Test C-API +# shell: bash +# if: ${{ matrix.build-what.key == 'capi' && !(matrix.metadata.build == 'linux-musl' || matrix.metadata.build == 'windows-gnu') }} +# run: make test-capi-ci +# env: +# TARGET: ${{ matrix.metadata.target }} +# TARGET_DIR: target/${{ matrix.metadata.target }}/release +# CARGO_TARGET: ${{ matrix.metadata.target }} +# # C-API tests were disabled for linux-musl and macos-arm (we can't run them) +# - name: Test C-API integration +# shell: bash +# if: ${{ matrix.build-what.key == 'capi' && !(matrix.metadata.build == 'linux-musl' || matrix.metadata.build == 'windows-gnu') }} +# run: export WASMER_DIR=`pwd`/package && make test-stage-7-capi-integration-tests +# env: +# TARGET: ${{ matrix.metadata.target }} +# TARGET_DIR: target/${{ matrix.metadata.target }}/release +# CARGO_TARGET: ${{ matrix.metadata.target }} +# - name: Archive production artifacts +# uses: actions/upload-artifact@v4 +# with: +# name: wasmer-cli-${{ matrix.metadata.build }} +# path: build-wasmer.tar.gz +# if-no-files-found: ignore +# retention-days: 2 +# - name: Archive production artifacts +# uses: actions/upload-artifact@v4 +# with: +# name: capi-${{ matrix.metadata.build }} +# path: build-capi.tar.gz +# if-no-files-found: ignore +# retention-days: 2 - test: - name: ${{ matrix.stage.description }} on ${{ matrix.metadata.build }} - runs-on: ${{ matrix.metadata.os }} - needs: setup - strategy: - fail-fast: false - matrix: - stage: [ - { - description: 'Run wast test suite for all compilers', - make: 'test-stage-0-wast', - }, - { - description: 'Unit-test packages on std', - make: 'test-stage-1-test-all', - }, - { - description: 'Unit-test cranelift on no-std', - make: 'test-stage-2-test-compiler-cranelift-nostd', - }, - { - description: 'Unit-test singlepass on no-std', - make: 'test-stage-3-test-compiler-singlepass-nostd', - }, - { - description: 'Unit-test wasmer-cli', - make: 'test-stage-4-wasmer-cli', - }, - { - description: 'Unit-test examples', - make: 'test-stage-5-test-examples', - } - ] - metadata: [ - # We cannot test on macos-arm since we don't have ARM runners - { - build: linux-x64, - os: ubuntu-22.04, - target: x86_64-unknown-linux-gnu, - exe: '', - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' - }, - { - build: macos-x64, - os: macos-12, - target: x86_64-apple-darwin, - exe: '', - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' +# test: +# name: ${{ matrix.stage.description }} on ${{ matrix.metadata.build }} +# runs-on: ${{ matrix.metadata.os }} +# needs: setup +# strategy: +# fail-fast: false +# matrix: +# stage: [ +# { +# description: 'Run wast test suite for all compilers', +# make: 'test-stage-0-wast', +# }, +# { +# description: 'Unit-test packages on std', +# make: 'test-stage-1-test-all', +# }, +# { +# description: 'Unit-test cranelift on no-std', +# make: 'test-stage-2-test-compiler-cranelift-nostd', +# }, +# { +# description: 'Unit-test singlepass on no-std', +# make: 'test-stage-3-test-compiler-singlepass-nostd', +# }, +# { +# description: 'Unit-test wasmer-cli', +# make: 'test-stage-4-wasmer-cli', +# }, +# { +# description: 'Unit-test examples', +# make: 'test-stage-5-test-examples', +# } +# ] +# metadata: [ +# # We cannot test on macos-arm since we don't have ARM runners +# { +# build: linux-x64, +# os: ubuntu-22.04, +# target: x86_64-unknown-linux-gnu, +# exe: '', +# llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' +# }, +# { +# build: macos-x64, +# os: macos-12, +# target: x86_64-apple-darwin, +# exe: '', +# llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' - }, - { - build: macos-arm64, - os: macos-14, - target: aarch64-apple-darwin, - exe: '', - # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' - }, - { - build: windows-x64, - os: windows-2022, - target: x86_64-pc-windows-msvc, - exe: '.exe', - # For now, disable LLVM in `windows-x64.` - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' - }, - { - build: linux-musl, - target: x86_64-unknown-linux-musl, - os: ubuntu-22.04, - exe: '', - container: 'alpine:latest' - } - ] - container: ${{ matrix.metadata.container }} - env: - SCCACHE_AZURE_BLOB_CONTAINER: wasmerstoragesccacheblob - SCCACHE_AZURE_CONNECTION_STRING: ${{ secrets.SCCACHE_AZURE_CONNECTION_STRING }} - steps: - - uses: actions/checkout@v3 - - name: Set up libstdc++ on Linux - if: matrix.metadata.build == 'linux-x64' - run: | - sudo apt-get update -y - sudo apt-get install -y --allow-downgrades libstdc++6 - sudo apt-get install --reinstall g++ - - name: Set up base deps on musl - if: matrix.metadata.build == 'linux-musl' - run: ./scripts/alpine-linux-install-deps.sh - - name: Install MSVC dev-cmd (Windows) - uses: ilammy/msvc-dev-cmd@v1 - if: ${{ matrix.metadata.build == 'windows-x64' }} - - name: Delete unwanted link to stop it from interfering (Windows) - shell: bash - run: rm /usr/bin/link.exe - if: ${{ matrix.metadata.build == 'windows-x64' }} +# }, +# { +# build: macos-arm64, +# os: macos-14, +# target: aarch64-apple-darwin, +# exe: '', +# # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. +# # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' +# }, +# { +# build: windows-x64, +# os: windows-2022, +# target: x86_64-pc-windows-msvc, +# exe: '.exe', +# # For now, disable LLVM in `windows-x64.` +# # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' +# }, +# { +# build: linux-musl, +# target: x86_64-unknown-linux-musl, +# os: ubuntu-22.04, +# exe: '', +# container: 'alpine:latest' +# } +# ] +# container: ${{ matrix.metadata.container }} +# env: +# SCCACHE_AZURE_BLOB_CONTAINER: wasmerstoragesccacheblob +# SCCACHE_AZURE_CONNECTION_STRING: ${{ secrets.SCCACHE_AZURE_CONNECTION_STRING }} +# steps: +# - uses: actions/checkout@v3 +# - name: Set up libstdc++ on Linux +# if: matrix.metadata.build == 'linux-x64' +# run: | +# sudo apt-get update -y +# sudo apt-get install -y --allow-downgrades libstdc++6 +# sudo apt-get install --reinstall g++ +# - name: Set up base deps on musl +# if: matrix.metadata.build == 'linux-musl' +# run: ./scripts/alpine-linux-install-deps.sh +# - name: Install MSVC dev-cmd (Windows) +# uses: ilammy/msvc-dev-cmd@v1 +# if: ${{ matrix.metadata.build == 'windows-x64' }} +# - name: Delete unwanted link to stop it from interfering (Windows) +# shell: bash +# run: rm /usr/bin/link.exe +# if: ${{ matrix.metadata.build == 'windows-x64' }} - - name: Set up dependencies for Mac OS - run: | - brew install automake - # using gnu-tar is a workaround for https://github.com/actions/cache/issues/403 - brew install gnu-tar - echo PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH" >> $GITHUB_ENV - if: matrix.metadata.os == 'macos-12' - - name: Install Rust - uses: dtolnay/rust-toolchain@stable - with: - toolchain: ${{ env.MSRV }} - target: ${{ matrix.metadata.target }} - - name: Install Nextest - uses: taiki-e/install-action@nextest - - name: Install LLVM (macOS Apple Silicon) - if: matrix.metadata.os == 'macos-12' && !matrix.metadata.llvm_url - run: | - brew install llvm - - name: Install LLVM - shell: bash - if: matrix.metadata.llvm_url - run: | - curl --proto '=https' --tlsv1.2 -sSf ${{ matrix.metadata.llvm_url }} -L -o llvm.tar.xz - LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} - mkdir ${LLVM_DIR} - tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} - echo "${LLVM_DIR}/bin" >> $GITHUB_PATH - echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH - echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV - echo "ENABLE_LLVM=1" >> $GITHUB_ENV - env: - LLVM_DIR: .llvm - - name: Add `brew` libs to `RUSTFLAGS` - if: matrix.metadata.os == 'macos-14' - shell: bash - run: | - echo "RUSTFLAGS=-L/opt/homebrew/lib" >> $GITHUB_ENV - - name: Setup Rust target - shell: bash - run: | - mkdir -p .cargo - cat << EOF > .cargo/config.toml - [build] - target = "${{ matrix.metadata.target }}" - EOF - if: matrix.metadata.target - - name: Cache - uses: whywaita/actions-cache-s3@v2 - with: - path: | - ~/.cargo/* - ./target/* - key: r22-${{ github.repository }}-${{ runner.os }}-${{ hashFiles('Cargo.lock') }}-wasmer-make-test-stage-${{ matrix.stage.make }}-${{ matrix.metadata.build }} - aws-s3-bucket: wasmer-rust-artifacts-cache - aws-access-key-id: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_TOKEN }} - aws-secret-access-key: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_KEY }} - aws-region: auto - aws-endpoint: https://1541b1e8a3fc6ad155ce67ef38899700.r2.cloudflarestorage.com - aws-s3-bucket-endpoint: false - aws-s3-force-path-style: true - - name: ${{ matrix.stage.description }} - shell: bash - run: make ${{ matrix.stage.make }} - env: - TARGET: ${{ matrix.metadata.target }} - TARGET_DIR: target/${{ matrix.metadata.target }}/release - CARGO_TARGET: ${{ matrix.metadata.target }} +# - name: Set up dependencies for Mac OS +# run: | +# brew install automake +# # using gnu-tar is a workaround for https://github.com/actions/cache/issues/403 +# brew install gnu-tar +# echo PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH" >> $GITHUB_ENV +# if: matrix.metadata.os == 'macos-12' +# - name: Install Rust +# uses: dtolnay/rust-toolchain@stable +# with: +# toolchain: ${{ env.MSRV }} +# target: ${{ matrix.metadata.target }} +# - name: Install Nextest +# uses: taiki-e/install-action@nextest +# - name: Install LLVM (macOS Apple Silicon) +# if: matrix.metadata.os == 'macos-12' && !matrix.metadata.llvm_url +# run: | +# brew install llvm +# - name: Install LLVM +# shell: bash +# if: matrix.metadata.llvm_url +# run: | +# curl --proto '=https' --tlsv1.2 -sSf ${{ matrix.metadata.llvm_url }} -L -o llvm.tar.xz +# LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} +# mkdir ${LLVM_DIR} +# tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} +# echo "${LLVM_DIR}/bin" >> $GITHUB_PATH +# echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH +# echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV +# echo "ENABLE_LLVM=1" >> $GITHUB_ENV +# env: +# LLVM_DIR: .llvm +# - name: Add `brew` libs to `RUSTFLAGS` +# if: matrix.metadata.os == 'macos-14' +# shell: bash +# run: | +# echo "RUSTFLAGS=-L/opt/homebrew/lib" >> $GITHUB_ENV +# - name: Setup Rust target +# shell: bash +# run: | +# mkdir -p .cargo +# cat << EOF > .cargo/config.toml +# [build] +# target = "${{ matrix.metadata.target }}" +# EOF +# if: matrix.metadata.target +# - name: Cache +# uses: whywaita/actions-cache-s3@v2 +# with: +# path: | +# ~/.cargo/* +# ./target/* +# key: r22-${{ github.repository }}-${{ runner.os }}-${{ hashFiles('Cargo.lock') }}-wasmer-make-test-stage-${{ matrix.stage.make }}-${{ matrix.metadata.build }} +# aws-s3-bucket: wasmer-rust-artifacts-cache +# aws-access-key-id: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_TOKEN }} +# aws-secret-access-key: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_KEY }} +# aws-region: auto +# aws-endpoint: https://1541b1e8a3fc6ad155ce67ef38899700.r2.cloudflarestorage.com +# aws-s3-bucket-endpoint: false +# aws-s3-force-path-style: true +# - name: ${{ matrix.stage.description }} +# shell: bash +# run: make ${{ matrix.stage.make }} +# env: +# TARGET: ${{ matrix.metadata.target }} +# TARGET_DIR: target/${{ matrix.metadata.target }}/release +# CARGO_TARGET: ${{ matrix.metadata.target }} - test_integration_cli: - name: CLI integration tests on ${{ matrix.build }} - runs-on: ${{ matrix.os }} - needs: [build, build_linux_aarch64, build_linux_riscv64] - strategy: - fail-fast: false - matrix: - include: - - build: linux-x64 - os: ubuntu-22.04 - target: x86_64-unknown-linux-gnu - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' - - build: macos-x64 - os: macos-12 - target: x86_64-apple-darwin - # we only build the integration-test CLI, we don't run tests - - build: macos-arm64 - os: macos-12 - target: aarch64-apple-darwin, - - build: linux-musl - target: x86_64-unknown-linux-musl - os: ubuntu-22.04 - container: alpine:latest - - build: windows-x64 - os: windows-2019 - target: x86_64-pc-windows-msvc - # For now, disable LLVM in `windows-x64.` - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' +# test_integration_cli: +# name: CLI integration tests on ${{ matrix.build }} +# runs-on: ${{ matrix.os }} +# needs: [build, build_linux_aarch64, build_linux_riscv64] +# strategy: +# fail-fast: false +# matrix: +# include: +# - build: linux-x64 +# os: ubuntu-22.04 +# target: x86_64-unknown-linux-gnu +# llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' +# - build: macos-x64 +# os: macos-12 +# target: x86_64-apple-darwin +# # we only build the integration-test CLI, we don't run tests +# - build: macos-arm64 +# os: macos-12 +# target: aarch64-apple-darwin, +# - build: linux-musl +# target: x86_64-unknown-linux-musl +# os: ubuntu-22.04 +# container: alpine:latest +# - build: windows-x64 +# os: windows-2019 +# target: x86_64-pc-windows-msvc +# # For now, disable LLVM in `windows-x64.` +# # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' - container: ${{ matrix.container }} - env: - SCCACHE_AZURE_BLOB_CONTAINER: wasmerstoragesccacheblob - SCCACHE_AZURE_CONNECTION_STRING: ${{ secrets.SCCACHE_AZURE_CONNECTION_STRING }} - steps: - - uses: actions/checkout@v3 - - uses: goto-bus-stop/setup-zig@v2 - with: - version: 0.10.0 - - name: Set up base deps on musl - if: matrix.build == 'linux-musl' - run: ./scripts/alpine-linux-install-deps.sh - - uses: actions/download-artifact@v4 - id: download - with: - name: capi-${{ matrix.build }} - - uses: actions/download-artifact@v4 - with: - name: wasmer-cli-${{ matrix.build }} - - name: 'Echo download path' - run: echo ${{steps.download.outputs.download-path}} - - name: Install Rust - uses: dtolnay/rust-toolchain@stable - with: - toolchain: ${{ env.MSRV }} - target: ${{ matrix.metadata.target }} - - name: Install Nextest - uses: taiki-e/install-action@nextest - - name: Cache - uses: whywaita/actions-cache-s3@v2 - with: - path: | - ~/.cargo/* - ./target/* - key: r22-${{ github.repository }}-${{ runner.os }}-${{ hashFiles('Cargo.lock') }}-wasmer-make-test-integration-cli-${{ matrix.build }} - aws-s3-bucket: wasmer-rust-artifacts-cache - aws-access-key-id: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_TOKEN }} - aws-secret-access-key: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_KEY }} - aws-region: auto - aws-endpoint: https://1541b1e8a3fc6ad155ce67ef38899700.r2.cloudflarestorage.com - aws-s3-bucket-endpoint: false - aws-s3-force-path-style: true - - name: Prepare package directory - shell: bash - run: | - mkdir -p package - mkdir -p package/cache - - uses: actions/download-artifact@v4 - with: - name: capi-linux-aarch64 - path: package/cache/wasmercache1 - - uses: actions/download-artifact@v4 - with: - name: capi-windows-x64 - path: package/cache/wasmercache2 - - uses: actions/download-artifact@v4 - with: - name: capi-macos-arm - path: package/cache/wasmercache3 - - uses: actions/download-artifact@v4 - with: - name: capi-macos-x64 - path: package/cache/wasmercache4 - - uses: actions/download-artifact@v4 - with: - name: capi-linux-x64 - path: package/cache/wasmercache5 - - uses: actions/download-artifact@v4 - with: - name: capi-linux-riscv64 - path: package/cache/wasmercache6 - - name: Copy .tar.gz files to proper location - shell: bash - run: | - ls package/cache/wasmercache1 - ls package/cache/wasmercache2 - ls package/cache/wasmercache3 - ls package/cache/wasmercache4 - ls package/cache/wasmercache5 - cp package/cache/wasmercache1/wasmer.tar.gz package/cache/wasmer-linux-aarch64.tar.gz - cp package/cache/wasmercache2/build-capi.tar.gz package/cache/wasmer-windows-gnu64.tar.gz - cp package/cache/wasmercache3/build-capi.tar.gz package/cache/wasmer-darwin-arm64.tar.gz - cp package/cache/wasmercache4/build-capi.tar.gz package/cache/wasmer-darwin-amd64.tar.gz - cp package/cache/wasmercache5/build-capi.tar.gz package/cache/wasmer-linux-amd64.tar.gz - cp package/cache/wasmercache6/wasmer.tar.gz package/cache/wasmer-linux-riscv64.tar.gz - - uses: actions/download-artifact@v4 - if: ${{ matrix.build == 'windows-x64' }} - with: - name: capi-windows-x64 - path: download_link - - uses: actions/download-artifact@v4 - if: ${{ matrix.build == 'linux-musl' }} - with: - name: capi-linux-musl - path: download_link - - uses: actions/download-artifact@v4 - if: ${{ matrix.build == 'macos-arm64' }} - with: - name: capi-macos-arm - path: download_link - - uses: actions/download-artifact@v4 - if: ${{ matrix.build == 'macos-x64' }} - with: - name: capi-macos-x64 - path: download_link - - uses: actions/download-artifact@v4 - if: ${{ matrix.build == 'linux-x64' }} - with: - name: capi-linux-x64 - path: download_link - - name: Copy build-capi.tar.gz to link.tar.gz - shell: bash - run: | - cp download_link/build-capi.tar.gz link.tar.gz - - name: Unzip Artifacts - shell: bash - run: | - make untar-capi - - name: Unzip Artifacts - shell: bash - run: | - make untar-wasmer +# container: ${{ matrix.container }} +# env: +# SCCACHE_AZURE_BLOB_CONTAINER: wasmerstoragesccacheblob +# SCCACHE_AZURE_CONNECTION_STRING: ${{ secrets.SCCACHE_AZURE_CONNECTION_STRING }} +# steps: +# - uses: actions/checkout@v3 +# - uses: goto-bus-stop/setup-zig@v2 +# with: +# version: 0.10.0 +# - name: Set up base deps on musl +# if: matrix.build == 'linux-musl' +# run: ./scripts/alpine-linux-install-deps.sh +# - uses: actions/download-artifact@v4 +# id: download +# with: +# name: capi-${{ matrix.build }} +# - uses: actions/download-artifact@v4 +# with: +# name: wasmer-cli-${{ matrix.build }} +# - name: 'Echo download path' +# run: echo ${{steps.download.outputs.download-path}} +# - name: Install Rust +# uses: dtolnay/rust-toolchain@stable +# with: +# toolchain: ${{ env.MSRV }} +# target: ${{ matrix.metadata.target }} +# - name: Install Nextest +# uses: taiki-e/install-action@nextest +# - name: Cache +# uses: whywaita/actions-cache-s3@v2 +# with: +# path: | +# ~/.cargo/* +# ./target/* +# key: r22-${{ github.repository }}-${{ runner.os }}-${{ hashFiles('Cargo.lock') }}-wasmer-make-test-integration-cli-${{ matrix.build }} +# aws-s3-bucket: wasmer-rust-artifacts-cache +# aws-access-key-id: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_TOKEN }} +# aws-secret-access-key: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_KEY }} +# aws-region: auto +# aws-endpoint: https://1541b1e8a3fc6ad155ce67ef38899700.r2.cloudflarestorage.com +# aws-s3-bucket-endpoint: false +# aws-s3-force-path-style: true +# - name: Prepare package directory +# shell: bash +# run: | +# mkdir -p package +# mkdir -p package/cache +# - uses: actions/download-artifact@v4 +# with: +# name: capi-linux-aarch64 +# path: package/cache/wasmercache1 +# - uses: actions/download-artifact@v4 +# with: +# name: capi-windows-x64 +# path: package/cache/wasmercache2 +# - uses: actions/download-artifact@v4 +# with: +# name: capi-macos-arm +# path: package/cache/wasmercache3 +# - uses: actions/download-artifact@v4 +# with: +# name: capi-macos-x64 +# path: package/cache/wasmercache4 +# - uses: actions/download-artifact@v4 +# with: +# name: capi-linux-x64 +# path: package/cache/wasmercache5 +# - uses: actions/download-artifact@v4 +# with: +# name: capi-linux-riscv64 +# path: package/cache/wasmercache6 +# - name: Copy .tar.gz files to proper location +# shell: bash +# run: | +# ls package/cache/wasmercache1 +# ls package/cache/wasmercache2 +# ls package/cache/wasmercache3 +# ls package/cache/wasmercache4 +# ls package/cache/wasmercache5 +# cp package/cache/wasmercache1/wasmer.tar.gz package/cache/wasmer-linux-aarch64.tar.gz +# cp package/cache/wasmercache2/build-capi.tar.gz package/cache/wasmer-windows-gnu64.tar.gz +# cp package/cache/wasmercache3/build-capi.tar.gz package/cache/wasmer-darwin-arm64.tar.gz +# cp package/cache/wasmercache4/build-capi.tar.gz package/cache/wasmer-darwin-amd64.tar.gz +# cp package/cache/wasmercache5/build-capi.tar.gz package/cache/wasmer-linux-amd64.tar.gz +# cp package/cache/wasmercache6/wasmer.tar.gz package/cache/wasmer-linux-riscv64.tar.gz +# - uses: actions/download-artifact@v4 +# if: ${{ matrix.build == 'windows-x64' }} +# with: +# name: capi-windows-x64 +# path: download_link +# - uses: actions/download-artifact@v4 +# if: ${{ matrix.build == 'linux-musl' }} +# with: +# name: capi-linux-musl +# path: download_link +# - uses: actions/download-artifact@v4 +# if: ${{ matrix.build == 'macos-arm64' }} +# with: +# name: capi-macos-arm +# path: download_link +# - uses: actions/download-artifact@v4 +# if: ${{ matrix.build == 'macos-x64' }} +# with: +# name: capi-macos-x64 +# path: download_link +# - uses: actions/download-artifact@v4 +# if: ${{ matrix.build == 'linux-x64' }} +# with: +# name: capi-linux-x64 +# path: download_link +# - name: Copy build-capi.tar.gz to link.tar.gz +# shell: bash +# run: | +# cp download_link/build-capi.tar.gz link.tar.gz +# - name: Unzip Artifacts +# shell: bash +# run: | +# make untar-capi +# - name: Unzip Artifacts +# shell: bash +# run: | +# make untar-wasmer - # Removed in favour of freestanding integration tests - # - # - name: Test integration CLI - # if: false # matrix.build != 'macos-arm' - # shell: bash - # run: | - # export WASMER_PATH=`pwd`/target/${{ matrix.target }}/release/wasmer${{ matrix.exe }} - # export WASMER_DIR=`pwd`/package && make test-integration-cli-ci - # env: - # TARGET: ${{ matrix.target }} - # TARGET_DIR: target/${{ matrix.target }}/release - # CARGO_TARGET: ${{ matrix.target }} - # WAPM_DEV_TOKEN: ${{ secrets.WAPM_DEV_TOKEN }} - # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} +# # Removed in favour of freestanding integration tests +# # +# # - name: Test integration CLI +# # if: false # matrix.build != 'macos-arm' +# # shell: bash +# # run: | +# # export WASMER_PATH=`pwd`/target/${{ matrix.target }}/release/wasmer${{ matrix.exe }} +# # export WASMER_DIR=`pwd`/package && make test-integration-cli-ci +# # env: +# # TARGET: ${{ matrix.target }} +# # TARGET_DIR: target/${{ matrix.target }}/release +# # CARGO_TARGET: ${{ matrix.target }} +# # WAPM_DEV_TOKEN: ${{ secrets.WAPM_DEV_TOKEN }} +# # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - # ---- - # Note (xdoardo on 2024/10/07): - # --- - # As of now the WAMR, WASMI (and V8) backends are not that mature enough. We will re-enable these tests - # when they've been used and matured. - # ---- - # - # - name: Test CLI integration (WAMR) - # shell: bash - # run: | - # export WASMER_PATH=`pwd`/target/${{ matrix.target }}/release/wasmer${{ matrix.exe }} - # export WASMER_DIR=`pwd`/package && make test-integration-cli-wamr-ci - # env: - # TARGET: ${{ matrix.target }} - # TARGET_DIR: target/${{ matrix.target }}/release - # CARGO_TARGET: ${{ matrix.target }} - # WAPM_DEV_TOKEN: ${{ secrets.WAPM_DEV_TOKEN }} - # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} +# # ---- +# # Note (xdoardo on 2024/10/07): +# # --- +# # As of now the WAMR, WASMI (and V8) backends are not that mature enough. We will re-enable these tests +# # when they've been used and matured. +# # ---- +# # +# # - name: Test CLI integration (WAMR) +# # shell: bash +# # run: | +# # export WASMER_PATH=`pwd`/target/${{ matrix.target }}/release/wasmer${{ matrix.exe }} +# # export WASMER_DIR=`pwd`/package && make test-integration-cli-wamr-ci +# # env: +# # TARGET: ${{ matrix.target }} +# # TARGET_DIR: target/${{ matrix.target }}/release +# # CARGO_TARGET: ${{ matrix.target }} +# # WAPM_DEV_TOKEN: ${{ secrets.WAPM_DEV_TOKEN }} +# # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - # - name: Test CLI integration (WASMI) - # shell: bash - # run: | - # export WASMER_PATH=`pwd`/target/${{ matrix.target }}/release/wasmer${{ matrix.exe }} - # export WASMER_DIR=`pwd`/package && make test-integration-cli-wasmi-ci - # env: - # TARGET: ${{ matrix.target }} - # TARGET_DIR: target/${{ matrix.target }}/release - # CARGO_TARGET: ${{ matrix.target }} - # WAPM_DEV_TOKEN: ${{ secrets.WAPM_DEV_TOKEN }} - # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} +# # - name: Test CLI integration (WASMI) +# # shell: bash +# # run: | +# # export WASMER_PATH=`pwd`/target/${{ matrix.target }}/release/wasmer${{ matrix.exe }} +# # export WASMER_DIR=`pwd`/package && make test-integration-cli-wasmi-ci +# # env: +# # TARGET: ${{ matrix.target }} +# # TARGET_DIR: target/${{ matrix.target }}/release +# # CARGO_TARGET: ${{ matrix.target }} +# # WAPM_DEV_TOKEN: ${{ secrets.WAPM_DEV_TOKEN }} +# # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - # there is another set of integration tests in 'wasmer-integration-tests' repo. Run those - test-wasmer-integration-tests: - needs: [build] - runs-on: ubuntu-22.04 - steps: - - name: Checkout wasmer-integration-tests repository - uses: actions/checkout@v3 - with: - repository: wasmerio/wasmer-integration-tests - submodules: true - token: ${{ secrets.CLONE_WASMER_INTEGRATION_TESTS }} - - uses: actions/download-artifact@v4 - with: - name: wasmer-cli-linux-x64 - - name: Cargo Registry Cache - uses: actions/cache@v3 - with: - path: | - ~/.cargo/advisory-db - ~/.cargo/git - ~/.cargo/registry - key: cargo-registry-${{ hashFiles('**/Cargo.lock') }} - - name: Cargo target cache - uses: actions/cache@v3 - with: - path: | - target/ - key: cargo-release-${{ hashFiles('**/Cargo.lock') }} - - run: | - # install rust toolchain - curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y - . "$HOME/.cargo/env" +# # there is another set of integration tests in 'wasmer-integration-tests' repo. Run those +# test-wasmer-integration-tests: +# needs: [build] +# runs-on: ubuntu-22.04 +# steps: +# - name: Checkout wasmer-integration-tests repository +# uses: actions/checkout@v3 +# with: +# repository: wasmerio/wasmer-integration-tests +# submodules: true +# token: ${{ secrets.CLONE_WASMER_INTEGRATION_TESTS }} +# - uses: actions/download-artifact@v4 +# with: +# name: wasmer-cli-linux-x64 +# - name: Cargo Registry Cache +# uses: actions/cache@v3 +# with: +# path: | +# ~/.cargo/advisory-db +# ~/.cargo/git +# ~/.cargo/registry +# key: cargo-registry-${{ hashFiles('**/Cargo.lock') }} +# - name: Cargo target cache +# uses: actions/cache@v3 +# with: +# path: | +# target/ +# key: cargo-release-${{ hashFiles('**/Cargo.lock') }} +# - run: | +# # install rust toolchain +# curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y +# . "$HOME/.cargo/env" - # add wasmer cli to PATH - tar -xzf build-wasmer.tar.gz +# # add wasmer cli to PATH +# tar -xzf build-wasmer.tar.gz - docker build -t tmp . - docker run -v $PWD:/app -w /app tmp bash -c " \ - cp ./bin/wasmer /root/.wasmer/bin/wasmer &&\ - export MYSQL_HOST='${{ vars.INTEGRATION_TEST_MYSQL_HOST }}' &&\ - export MYSQL_DBNAME='${{ vars.INTEGRATION_TEST_MYSQL_DBNAME }}' &&\ - export MYSQL_USERNAME='${{ secrets.INTEGRATION_TEST_MYSQL_USERNAME }}' &&\ - export MYSQL_PASSWORD='${{ secrets.INTEGRATION_TEST_MYSQL_PASSWORD }}' &&\ - export MYSQL_PORT='${{ vars.INTEGRATION_TEST_MYSQL_PORT }}' &&\ - export MYSQL_CERT='${{ secrets.INTEGRATION_TEST_MYSQL_CERT }}' &&\ - export PG_HOST='${{ vars.INTEGRATION_TEST_PG_HOST }}' &&\ - export PG_DBNAME='${{ vars.INTEGRATION_TEST_PG_DBNAME }}' &&\ - export PG_USERNAME='${{ secrets.INTEGRATION_TEST_PG_USERNAME }}' &&\ - export PG_PASSWORD='${{ secrets.INTEGRATION_TEST_PG_PASSWORD }}' &&\ - export PG_PORT='${{ vars.INTEGRATION_TEST_PG_PORT }}' &&\ - wasmer config set registry.url https://registry.wasmer.io/graphql &&\ - wasmer login '${{ secrets.WAPM_PROD_TOKEN }}' &&\ - wasmer config set registry.url https://registry.wasmer.wtf/graphql &&\ - wasmer login '${{ secrets.WAPM_DEV_TOKEN }}' &&\ - cargo test --no-fail-fast" - - name: notify failure in slack - if: failure() - run: | - curl -X POST -H 'Content-type: application/json' --data '{"text":"Integration tests failed ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}"}' ${{ secrets.INTEGRATION_TEST_SLACK_WEBHOOK }} +# docker build -t tmp . +# docker run -v $PWD:/app -w /app tmp bash -c " \ +# cp ./bin/wasmer /root/.wasmer/bin/wasmer &&\ +# export MYSQL_HOST='${{ vars.INTEGRATION_TEST_MYSQL_HOST }}' &&\ +# export MYSQL_DBNAME='${{ vars.INTEGRATION_TEST_MYSQL_DBNAME }}' &&\ +# export MYSQL_USERNAME='${{ secrets.INTEGRATION_TEST_MYSQL_USERNAME }}' &&\ +# export MYSQL_PASSWORD='${{ secrets.INTEGRATION_TEST_MYSQL_PASSWORD }}' &&\ +# export MYSQL_PORT='${{ vars.INTEGRATION_TEST_MYSQL_PORT }}' &&\ +# export MYSQL_CERT='${{ secrets.INTEGRATION_TEST_MYSQL_CERT }}' &&\ +# export PG_HOST='${{ vars.INTEGRATION_TEST_PG_HOST }}' &&\ +# export PG_DBNAME='${{ vars.INTEGRATION_TEST_PG_DBNAME }}' &&\ +# export PG_USERNAME='${{ secrets.INTEGRATION_TEST_PG_USERNAME }}' &&\ +# export PG_PASSWORD='${{ secrets.INTEGRATION_TEST_PG_PASSWORD }}' &&\ +# export PG_PORT='${{ vars.INTEGRATION_TEST_PG_PORT }}' &&\ +# wasmer config set registry.url https://registry.wasmer.io/graphql &&\ +# wasmer login '${{ secrets.WAPM_PROD_TOKEN }}' &&\ +# wasmer config set registry.url https://registry.wasmer.wtf/graphql &&\ +# wasmer login '${{ secrets.WAPM_DEV_TOKEN }}' &&\ +# cargo test --no-fail-fast" +# - name: notify failure in slack +# if: failure() +# run: | +# curl -X POST -H 'Content-type: application/json' --data '{"text":"Integration tests failed ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}"}' ${{ secrets.INTEGRATION_TEST_SLACK_WEBHOOK }} diff --git a/.github/workflows/wasmer-config.yaml b/.github/workflows/wasmer-config.yaml index 9091574b1e3..90a36b31efd 100644 --- a/.github/workflows/wasmer-config.yaml +++ b/.github/workflows/wasmer-config.yaml @@ -1,54 +1,54 @@ -# Dedicated workflow just for the wasmer-config crate -name: wasmer-config +# # Dedicated workflow just for the wasmer-config crate +# name: wasmer-config -on: - push: - branches: - - main - pull_request: +# on: +# push: +# branches: +# - main +# pull_request: -# Automatically cancel previous workflow runs when a new commit is pushed. -concurrency: - group: ${{ github.workflow }}-${{ github.ref }} - cancel-in-progress: true +# # Automatically cancel previous workflow runs when a new commit is pushed. +# concurrency: +# group: ${{ github.workflow }}-${{ github.ref }} +# cancel-in-progress: true -env: - DEFAULT_CRATE_NAME: wasmer_toml +# env: +# DEFAULT_CRATE_NAME: wasmer_toml -jobs: - check: - name: Compile and Test - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - name: Rust Cache - uses: Swatinem/rust-cache@v2 - - name: Setup Rust - uses: dsherret/rust-toolchain-file@v1 - - name: Install Nextest - uses: taiki-e/install-action@nextest - - name: Type Checking - run: | - cd lib/config && cargo check --verbose --locked - - name: Build - run: | - cd lib/config && cargo build --verbose --locked - - name: Test - run: | - cd lib/config && cargo nextest run --verbose --locked +# jobs: +# check: +# name: Compile and Test +# runs-on: ubuntu-latest +# steps: +# - uses: actions/checkout@v2 +# - name: Rust Cache +# uses: Swatinem/rust-cache@v2 +# - name: Setup Rust +# uses: dsherret/rust-toolchain-file@v1 +# - name: Install Nextest +# uses: taiki-e/install-action@nextest +# - name: Type Checking +# run: | +# cd lib/config && cargo check --verbose --locked +# - name: Build +# run: | +# cd lib/config && cargo build --verbose --locked +# - name: Test +# run: | +# cd lib/config && cargo nextest run --verbose --locked - lints: - name: Linting and Formatting - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - name: Rust Cache - uses: Swatinem/rust-cache@v2 - - name: Setup Rust - uses: dsherret/rust-toolchain-file@v1 - - name: Check Formatting - run: | - cd lib/config && cargo fmt --verbose --check - - name: Clippy - run: | - cd lib/config && cargo clippy --verbose +# lints: +# name: Linting and Formatting +# runs-on: ubuntu-latest +# steps: +# - uses: actions/checkout@v2 +# - name: Rust Cache +# uses: Swatinem/rust-cache@v2 +# - name: Setup Rust +# uses: dsherret/rust-toolchain-file@v1 +# - name: Check Formatting +# run: | +# cd lib/config && cargo fmt --verbose --check +# - name: Clippy +# run: | +# cd lib/config && cargo clippy --verbose diff --git a/.github/workflows/wasmer-integration-tests.yaml b/.github/workflows/wasmer-integration-tests.yaml index 8a079aed71d..f06a96fd5c8 100644 --- a/.github/workflows/wasmer-integration-tests.yaml +++ b/.github/workflows/wasmer-integration-tests.yaml @@ -1,51 +1,51 @@ -name: test-sys +# name: test-sys -on: - push: - branches: - - sre-383-re-enable-ignored-integration-test-test_php_extensions +# on: +# push: +# branches: +# - sre-383-re-enable-ignored-integration-test-test_php_extensions -jobs: - # there is another set of integration tests in 'wasmer-integration-tests' repo. Run those - test-wasmer-integration-tests: - runs-on: ubuntu-22.04 - steps: - - name: Checkout wasmer-integration-tests repository - uses: actions/checkout@v3 - with: - repository: wasmerio/wasmer-integration-tests - submodules: true - token: ${{ secrets.CLONE_WASMER_INTEGRATION_TESTS }} - - name: Cargo Registry Cache - uses: actions/cache@v3 - with: - path: | - ~/.cargo/advisory-db - ~/.cargo/git - ~/.cargo/registry - key: cargo-registry-${{ hashFiles('**/Cargo.lock') }} - - name: Cargo target cache - uses: actions/cache@v3 - with: - path: | - target/ - key: cargo-release-${{ hashFiles('**/Cargo.lock') }} - - run: | - docker build -t tmp . - docker run -v $PWD:/app -w /app tmp bash -c " \ - export MYSQL_HOST='${{ vars.INTEGRATION_TEST_MYSQL_HOST }}' &&\ - export MYSQL_DBNAME='${{ vars.INTEGRATION_TEST_MYSQL_DBNAME }}' &&\ - export MYSQL_USERNAME='${{ secrets.INTEGRATION_TEST_MYSQL_USERNAME }}' &&\ - export MYSQL_PASSWORD='${{ secrets.INTEGRATION_TEST_MYSQL_PASSWORD }}' &&\ - export MYSQL_PORT='${{ vars.INTEGRATION_TEST_MYSQL_PORT }}' &&\ - export MYSQL_CERT='${{ secrets.INTEGRATION_TEST_MYSQL_CERT }}' &&\ - export PG_HOST='${{ vars.INTEGRATION_TEST_PG_HOST }}' &&\ - export PG_DBNAME='${{ vars.INTEGRATION_TEST_PG_DBNAME }}' &&\ - export PG_USERNAME='${{ secrets.INTEGRATION_TEST_PG_USERNAME }}' &&\ - export PG_PASSWORD='${{ secrets.INTEGRATION_TEST_PG_PASSWORD }}' &&\ - export PG_PORT='${{ vars.INTEGRATION_TEST_PG_PORT }}' &&\ - wasmer config set registry.url https://registry.wasmer.io/graphql &&\ - wasmer login ${{ secrets.WAPM_PROD_TOKEN }} &&\ - wasmer config set registry.url https://registry.wasmer.wtf/graphql &&\ - wasmer login ${{ secrets.WAPM_DEV_TOKEN }} &&\ - cargo test --no-fail-fast" \ No newline at end of file +# jobs: +# # there is another set of integration tests in 'wasmer-integration-tests' repo. Run those +# test-wasmer-integration-tests: +# runs-on: ubuntu-22.04 +# steps: +# - name: Checkout wasmer-integration-tests repository +# uses: actions/checkout@v3 +# with: +# repository: wasmerio/wasmer-integration-tests +# submodules: true +# token: ${{ secrets.CLONE_WASMER_INTEGRATION_TESTS }} +# - name: Cargo Registry Cache +# uses: actions/cache@v3 +# with: +# path: | +# ~/.cargo/advisory-db +# ~/.cargo/git +# ~/.cargo/registry +# key: cargo-registry-${{ hashFiles('**/Cargo.lock') }} +# - name: Cargo target cache +# uses: actions/cache@v3 +# with: +# path: | +# target/ +# key: cargo-release-${{ hashFiles('**/Cargo.lock') }} +# - run: | +# docker build -t tmp . +# docker run -v $PWD:/app -w /app tmp bash -c " \ +# export MYSQL_HOST='${{ vars.INTEGRATION_TEST_MYSQL_HOST }}' &&\ +# export MYSQL_DBNAME='${{ vars.INTEGRATION_TEST_MYSQL_DBNAME }}' &&\ +# export MYSQL_USERNAME='${{ secrets.INTEGRATION_TEST_MYSQL_USERNAME }}' &&\ +# export MYSQL_PASSWORD='${{ secrets.INTEGRATION_TEST_MYSQL_PASSWORD }}' &&\ +# export MYSQL_PORT='${{ vars.INTEGRATION_TEST_MYSQL_PORT }}' &&\ +# export MYSQL_CERT='${{ secrets.INTEGRATION_TEST_MYSQL_CERT }}' &&\ +# export PG_HOST='${{ vars.INTEGRATION_TEST_PG_HOST }}' &&\ +# export PG_DBNAME='${{ vars.INTEGRATION_TEST_PG_DBNAME }}' &&\ +# export PG_USERNAME='${{ secrets.INTEGRATION_TEST_PG_USERNAME }}' &&\ +# export PG_PASSWORD='${{ secrets.INTEGRATION_TEST_PG_PASSWORD }}' &&\ +# export PG_PORT='${{ vars.INTEGRATION_TEST_PG_PORT }}' &&\ +# wasmer config set registry.url https://registry.wasmer.io/graphql &&\ +# wasmer login ${{ secrets.WAPM_PROD_TOKEN }} &&\ +# wasmer config set registry.url https://registry.wasmer.wtf/graphql &&\ +# wasmer login ${{ secrets.WAPM_DEV_TOKEN }} &&\ +# cargo test --no-fail-fast" \ No newline at end of file From 2f4f892922db31402808e4d07d281289ee441bf8 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 12:18:02 +0330 Subject: [PATCH 06/59] disable more steps for now --- .github/workflows/build.yml | 40 ++++++++++++++++++------------------- 1 file changed, 20 insertions(+), 20 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 8f16f8d6f81..9ea64170d14 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -219,21 +219,21 @@ jobs: '${{ runner.tool_cache }}/cargo-sccache/bin/sccache' -s echo 'RUSTC_WRAPPER=${{ runner.tool_cache }}/cargo-sccache/bin/sccache' >> $GITHUB_ENV shell: bash - - name: Build C API headless - shell: bash - run: | - make package-capi-headless - - name: Build C API - shell: bash - run: | - make build-capi - - name: Build Wasmer binary with LLVM - if: matrix.use_llvm - shell: bash - run: | - make build-wasmer - env: - ENABLE_LLVM: 1 + # - name: Build C API headless + # shell: bash + # run: | + # make package-capi-headless + # - name: Build C API + # shell: bash + # run: | + # make build-capi + # - name: Build Wasmer binary with LLVM + # if: matrix.use_llvm + # shell: bash + # run: | + # make build-wasmer + # env: + # ENABLE_LLVM: 1 - name: Build Wasmer with v8 backend if: endsWith(matrix.build, 'v8') run: | @@ -250,11 +250,11 @@ jobs: if: endsWith(matrix.build, 'wasmi') run: | make build-wasmer-wasmi - - name: Build Wasmer binary without LLVM - if: matrix.use_llvm != true - shell: bash - run: | - make build-wasmer + # - name: Build Wasmer binary without LLVM + # if: matrix.use_llvm != true + # shell: bash + # run: | + # make build-wasmer #- name: Build Wasmer binary on Wasm32-WASI without LLVM # if: matrix.build_wasm # shell: bash From dcb1cb282f64cca144c6e384fd407b3302d48823 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 12:19:46 +0330 Subject: [PATCH 07/59] use sudo for package installation --- .github/workflows/build.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 9ea64170d14..f5692d8c418 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -123,7 +123,7 @@ jobs: - name: Install mold if: startsWith(matrix.build, 'linux') run: | - apt update && apt install mold + sudo apt update && sudo apt install mold - name: Install Rust uses: dtolnay/rust-toolchain@stable with: From 9733ce83efc710ae392c41525bef6704aa8b42fc Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 12:23:59 +0330 Subject: [PATCH 08/59] use newer version of ubuntu --- .github/workflows/build.yml | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index f5692d8c418..89cb006c6f9 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -47,7 +47,7 @@ jobs: matrix: include: - build: linux-x64 - os: ubuntu-20.04 + os: ubuntu-22.04 artifact_name: 'wasmer-linux-amd64' llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' cross_compilation_artifact_name: 'cross_compiled_from_linux' @@ -55,7 +55,7 @@ jobs: use_llvm: true build_wasm: true - build: linux-x64-v8 - os: ubuntu-20.04 + os: ubuntu-22.04 artifact_name: 'wasmer-v8-linux-amd64' llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' cross_compilation_artifact_name: 'cross_compiled_from_linux' @@ -63,7 +63,7 @@ jobs: use_llvm: true build_wasm: true - build: linux-x64-wamr - os: ubuntu-20.04 + os: ubuntu-22.04 artifact_name: 'wasmer-wamr-linux-amd64' llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' cross_compilation_artifact_name: 'cross_compiled_from_linux' @@ -71,7 +71,7 @@ jobs: use_llvm: true build_wasm: true - build: linux-x64-wasmi - os: ubuntu-20.04 + os: ubuntu-22.04 artifact_name: 'wasmer-wasmi-linux-amd64' llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' cross_compilation_artifact_name: 'cross_compiled_from_linux' From 8613741824399096001840db88ed0b1841bffd82 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 12:46:56 +0330 Subject: [PATCH 09/59] fix linux issues and enable macos --- .github/workflows/build.yml | 60 ++++++++++++++++++++++++++++++------- 1 file changed, 49 insertions(+), 11 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 89cb006c6f9..a4a96dd48d5 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -86,6 +86,30 @@ jobs: use_sccache: false use_llvm: true build_wasm: false + - build: macos-x64-v8 + os: macos-12 + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + artifact_name: 'wasmer-v8-darwin-amd64' + cross_compilation_artifact_name: 'cross_compiled_from_mac' + use_sccache: false + use_llvm: true + build_wasm: false + - build: macos-x64-wamr + os: macos-12 + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + artifact_name: 'wasmer-wamr-darwin-amd64' + cross_compilation_artifact_name: 'cross_compiled_from_mac' + use_sccache: false + use_llvm: true + build_wasm: false + - build: macos-x64-wasmi + os: macos-12 + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + artifact_name: 'wasmer-wasmi-darwin-amd64' + cross_compilation_artifact_name: 'cross_compiled_from_mac' + use_sccache: false + use_llvm: true + build_wasm: false - build: macos-arm64 os: macos-14 target: aarch64-apple-darwin @@ -120,10 +144,24 @@ jobs: - name: Set up base deps on musl if: matrix.build == 'linux-musl-x64' run: ./scripts/alpine-linux-install-deps.sh - - name: Install mold - if: startsWith(matrix.build, 'linux') + - name: Install Linux tools + if: startsWith(matrix.build, 'linux-x64') run: | - sudo apt update && sudo apt install mold + sudo apt install mold ninja-build + - name: Install Linux musl tools + if: startsWith(matrix.build, 'linux-musl') + run: | + apk add mold ninja + - name: Install `ninja` on macOS + if: startsWith(matrix.build, 'macos-') + shell: bash + run: | + brew install ninja + - name: Install `ninja` on Windows + if: startsWith(matrix.build, 'windows-') + shell: bash + run: | + choco install ninja - name: Install Rust uses: dtolnay/rust-toolchain@stable with: @@ -219,14 +257,14 @@ jobs: '${{ runner.tool_cache }}/cargo-sccache/bin/sccache' -s echo 'RUSTC_WRAPPER=${{ runner.tool_cache }}/cargo-sccache/bin/sccache' >> $GITHUB_ENV shell: bash - # - name: Build C API headless - # shell: bash - # run: | - # make package-capi-headless - # - name: Build C API - # shell: bash - # run: | - # make build-capi + - name: Build C API headless + shell: bash + run: | + make package-capi-headless + - name: Build C API + shell: bash + run: | + make build-capi # - name: Build Wasmer binary with LLVM # if: matrix.use_llvm # shell: bash From f69f60d7ab07ca53dece951a6d1184ecc2320c13 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 13:23:16 +0330 Subject: [PATCH 10/59] only enable macos, bump to macos 13, and install missing header files --- .github/workflows/build.yml | 121 +++++++++++++++++++----------------- 1 file changed, 63 insertions(+), 58 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index a4a96dd48d5..05c013b393a 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -46,40 +46,40 @@ jobs: fail-fast: false matrix: include: - - build: linux-x64 - os: ubuntu-22.04 - artifact_name: 'wasmer-linux-amd64' - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' - cross_compilation_artifact_name: 'cross_compiled_from_linux' - use_sccache: false - use_llvm: true - build_wasm: true - - build: linux-x64-v8 - os: ubuntu-22.04 - artifact_name: 'wasmer-v8-linux-amd64' - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' - cross_compilation_artifact_name: 'cross_compiled_from_linux' - use_sccache: false - use_llvm: true - build_wasm: true - - build: linux-x64-wamr - os: ubuntu-22.04 - artifact_name: 'wasmer-wamr-linux-amd64' - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' - cross_compilation_artifact_name: 'cross_compiled_from_linux' - use_sccache: false - use_llvm: true - build_wasm: true - - build: linux-x64-wasmi - os: ubuntu-22.04 - artifact_name: 'wasmer-wasmi-linux-amd64' - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' - cross_compilation_artifact_name: 'cross_compiled_from_linux' - use_sccache: false - use_llvm: true - build_wasm: true + # - build: linux-x64 + # os: ubuntu-22.04 + # artifact_name: 'wasmer-linux-amd64' + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' + # cross_compilation_artifact_name: 'cross_compiled_from_linux' + # use_sccache: false + # use_llvm: true + # build_wasm: true + # - build: linux-x64-v8 + # os: ubuntu-22.04 + # artifact_name: 'wasmer-v8-linux-amd64' + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' + # cross_compilation_artifact_name: 'cross_compiled_from_linux' + # use_sccache: false + # use_llvm: true + # build_wasm: true + # - build: linux-x64-wamr + # os: ubuntu-22.04 + # artifact_name: 'wasmer-wamr-linux-amd64' + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' + # cross_compilation_artifact_name: 'cross_compiled_from_linux' + # use_sccache: false + # use_llvm: true + # build_wasm: true + # - build: linux-x64-wasmi + # os: ubuntu-22.04 + # artifact_name: 'wasmer-wasmi-linux-amd64' + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' + # cross_compilation_artifact_name: 'cross_compiled_from_linux' + # use_sccache: false + # use_llvm: true + # build_wasm: true - build: macos-x64 - os: macos-12 + os: macos-13 llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' artifact_name: 'wasmer-darwin-amd64' cross_compilation_artifact_name: 'cross_compiled_from_mac' @@ -87,7 +87,7 @@ jobs: use_llvm: true build_wasm: false - build: macos-x64-v8 - os: macos-12 + os: macos-13 llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' artifact_name: 'wasmer-v8-darwin-amd64' cross_compilation_artifact_name: 'cross_compiled_from_mac' @@ -95,7 +95,7 @@ jobs: use_llvm: true build_wasm: false - build: macos-x64-wamr - os: macos-12 + os: macos-13 llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' artifact_name: 'wasmer-wamr-darwin-amd64' cross_compilation_artifact_name: 'cross_compiled_from_mac' @@ -103,37 +103,37 @@ jobs: use_llvm: true build_wasm: false - build: macos-x64-wasmi - os: macos-12 + os: macos-13 llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' artifact_name: 'wasmer-wasmi-darwin-amd64' cross_compilation_artifact_name: 'cross_compiled_from_mac' use_sccache: false use_llvm: true build_wasm: false - - build: macos-arm64 - os: macos-14 - target: aarch64-apple-darwin - artifact_name: 'wasmer-darwin-arm64' - use_sccache: false - use_llvm: false - build_wasm: false + # - build: macos-arm64 + # os: macos-14 + # target: aarch64-apple-darwin + # artifact_name: 'wasmer-darwin-arm64' + # use_sccache: false + # use_llvm: false + # build_wasm: false # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' - - build: windows-x64 - os: windows-2019 - artifact_name: 'wasmer-windows-amd64' - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' - cross_compilation_artifact_name: 'cross_compiled_from_win' - use_sccache: false - use_llvm: true - build_wasm: false - - build: linux-musl-x64 - os: ubuntu-latest - artifact_name: 'wasmer-linux-musl-amd64' - container: alpine:latest - use_sccache: false - use_llvm: false - build_wasm: true + # - build: windows-x64 + # os: windows-2019 + # artifact_name: 'wasmer-windows-amd64' + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + # cross_compilation_artifact_name: 'cross_compiled_from_win' + # use_sccache: false + # use_llvm: true + # build_wasm: false + # - build: linux-musl-x64 + # os: ubuntu-latest + # artifact_name: 'wasmer-linux-musl-amd64' + # container: alpine:latest + # use_sccache: false + # use_llvm: false + # build_wasm: true container: ${{ matrix.container }} env: SCCACHE_AZURE_BLOB_CONTAINER: wasmerstoragesccacheblob @@ -162,6 +162,11 @@ jobs: shell: bash run: | choco install ninja + - name: Install standard header files on macOS + if: startsWith(matrix.build, 'macos-') + shell: bash + run: | + xcode-select -s /Library/Developer/CommandLineTools - name: Install Rust uses: dtolnay/rust-toolchain@stable with: From ae9b94bf7cf215b4a30586bd1a86c76b62352e74 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 13:24:34 +0330 Subject: [PATCH 11/59] use sudo --- .github/workflows/build.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 05c013b393a..a554236238b 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -166,7 +166,7 @@ jobs: if: startsWith(matrix.build, 'macos-') shell: bash run: | - xcode-select -s /Library/Developer/CommandLineTools + sudo xcode-select -s /Library/Developer/CommandLineTools - name: Install Rust uses: dtolnay/rust-toolchain@stable with: From 92ec5b172c94c493dfd34152008cb6bd9bc05b99 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 13:45:14 +0330 Subject: [PATCH 12/59] just enable v8 on macos --- .github/workflows/build.yml | 49 +++++++++++++++++++------------------ 1 file changed, 25 insertions(+), 24 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index a554236238b..dfa68fad895 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -78,14 +78,14 @@ jobs: # use_sccache: false # use_llvm: true # build_wasm: true - - build: macos-x64 - os: macos-13 - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' - artifact_name: 'wasmer-darwin-amd64' - cross_compilation_artifact_name: 'cross_compiled_from_mac' - use_sccache: false - use_llvm: true - build_wasm: false + # - build: macos-x64 + # os: macos-13 + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + # artifact_name: 'wasmer-darwin-amd64' + # cross_compilation_artifact_name: 'cross_compiled_from_mac' + # use_sccache: false + # use_llvm: true + # build_wasm: false - build: macos-x64-v8 os: macos-13 llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' @@ -94,22 +94,22 @@ jobs: use_sccache: false use_llvm: true build_wasm: false - - build: macos-x64-wamr - os: macos-13 - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' - artifact_name: 'wasmer-wamr-darwin-amd64' - cross_compilation_artifact_name: 'cross_compiled_from_mac' - use_sccache: false - use_llvm: true - build_wasm: false - - build: macos-x64-wasmi - os: macos-13 - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' - artifact_name: 'wasmer-wasmi-darwin-amd64' - cross_compilation_artifact_name: 'cross_compiled_from_mac' - use_sccache: false - use_llvm: true - build_wasm: false + # - build: macos-x64-wamr + # os: macos-13 + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + # artifact_name: 'wasmer-wamr-darwin-amd64' + # cross_compilation_artifact_name: 'cross_compiled_from_mac' + # use_sccache: false + # use_llvm: true + # build_wasm: false + # - build: macos-x64-wasmi + # os: macos-13 + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + # artifact_name: 'wasmer-wasmi-darwin-amd64' + # cross_compilation_artifact_name: 'cross_compiled_from_mac' + # use_sccache: false + # use_llvm: true + # build_wasm: false # - build: macos-arm64 # os: macos-14 # target: aarch64-apple-darwin @@ -166,6 +166,7 @@ jobs: if: startsWith(matrix.build, 'macos-') shell: bash run: | + sudo xcode-select --install sudo xcode-select -s /Library/Developer/CommandLineTools - name: Install Rust uses: dtolnay/rust-toolchain@stable From e8631a05894cef41437982d15ece56b231701663 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 13:46:44 +0330 Subject: [PATCH 13/59] disable more jobs --- .github/workflows/build.yml | 508 ++++++++++++++++++------------------ 1 file changed, 254 insertions(+), 254 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index dfa68fad895..696b3432f7c 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -340,264 +340,264 @@ jobs: if-no-files-found: error retention-days: 2 - windows_gnu: - name: Windows GNU - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v3 - - name: Install Windows-GNU linker - shell: bash - run: | - sudo apt install -y mingw-w64 - - uses: dtolnay/rust-toolchain@stable - with: - target: x86_64-pc-windows-gnu - - name: Install Windows-GNU target - shell: bash - run: | - rustup target add x86_64-pc-windows-gnu - - name: Install Windows 10 SDK with xwin - shell: bash - run: | - mkdir -p /tmp/xwin - mkdir -p /tmp/xwindownload - mkdir -p /tmp/xwincache - git clone https://github.com/wasmerio/xwin --depth=1 /tmp/xwin - cargo build --release --manifest-path=/tmp/xwin/Cargo.toml - /tmp/xwin/target/release/xwin --accept-license --cache-dir /tmp/xwincache splat --output /tmp/xwindownload - mkdir -p /tmp/winsdk - cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/WS2_32.lib /tmp/winsdk/ - cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/KERNEL32.lib /tmp/winsdk/ - cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/BCRYPT.lib /tmp/winsdk/ - cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/ADVAPI32.lib /tmp/winsdk/ - cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/USERENV.lib /tmp/winsdk/ - echo "WinSDK files:" - ls -laH /tmp/winsdk - echo "" - mkdir -p package - mkdir -p package/winsdk - cp -r /tmp/winsdk/* package/winsdk - - name: Build Wasmer C-API without LLVM - shell: bash - run: | - make build-capi - env: - RUSTFLAGS: -Cpanic=abort - CARGO_TARGET: x86_64-pc-windows-gnu - ENABLE_LLVM: 0 - - name: Build Wasmer C-API headless without LLVM - shell: bash - run: | - make build-capi-headless - env: - RUSTFLAGS: -Cpanic=abort - CARGO_TARGET: x86_64-pc-windows-gnu - ENABLE_LLVM: 0 - - name: Dist - run: | - make distribution-gnu - env: - CARGO_TARGET: x86_64-pc-windows-gnu - TARGET_DIR: target/x86_64-pc-windows-gnu/release - - name: Upload Artifacts - uses: actions/upload-artifact@v4 - with: - name: 'wasmer-windows-gnu64' - path: dist - if-no-files-found: error - retention-days: 2 + # windows_gnu: + # name: Windows GNU + # runs-on: ubuntu-latest + # steps: + # - uses: actions/checkout@v3 + # - name: Install Windows-GNU linker + # shell: bash + # run: | + # sudo apt install -y mingw-w64 + # - uses: dtolnay/rust-toolchain@stable + # with: + # target: x86_64-pc-windows-gnu + # - name: Install Windows-GNU target + # shell: bash + # run: | + # rustup target add x86_64-pc-windows-gnu + # - name: Install Windows 10 SDK with xwin + # shell: bash + # run: | + # mkdir -p /tmp/xwin + # mkdir -p /tmp/xwindownload + # mkdir -p /tmp/xwincache + # git clone https://github.com/wasmerio/xwin --depth=1 /tmp/xwin + # cargo build --release --manifest-path=/tmp/xwin/Cargo.toml + # /tmp/xwin/target/release/xwin --accept-license --cache-dir /tmp/xwincache splat --output /tmp/xwindownload + # mkdir -p /tmp/winsdk + # cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/WS2_32.lib /tmp/winsdk/ + # cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/KERNEL32.lib /tmp/winsdk/ + # cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/BCRYPT.lib /tmp/winsdk/ + # cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/ADVAPI32.lib /tmp/winsdk/ + # cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/USERENV.lib /tmp/winsdk/ + # echo "WinSDK files:" + # ls -laH /tmp/winsdk + # echo "" + # mkdir -p package + # mkdir -p package/winsdk + # cp -r /tmp/winsdk/* package/winsdk + # - name: Build Wasmer C-API without LLVM + # shell: bash + # run: | + # make build-capi + # env: + # RUSTFLAGS: -Cpanic=abort + # CARGO_TARGET: x86_64-pc-windows-gnu + # ENABLE_LLVM: 0 + # - name: Build Wasmer C-API headless without LLVM + # shell: bash + # run: | + # make build-capi-headless + # env: + # RUSTFLAGS: -Cpanic=abort + # CARGO_TARGET: x86_64-pc-windows-gnu + # ENABLE_LLVM: 0 + # - name: Dist + # run: | + # make distribution-gnu + # env: + # CARGO_TARGET: x86_64-pc-windows-gnu + # TARGET_DIR: target/x86_64-pc-windows-gnu/release + # - name: Upload Artifacts + # uses: actions/upload-artifact@v4 + # with: + # name: 'wasmer-windows-gnu64' + # path: dist + # if-no-files-found: error + # retention-days: 2 - darwin_aarch64_jsc: - name: macOS aarch64 (JSC) - runs-on: macos-12 - steps: - - uses: actions/checkout@v3 - - uses: dtolnay/rust-toolchain@stable - with: - target: aarch64-apple-darwin - - name: Install Darwin-aarch64 target - shell: bash - run: | - rustup target add aarch64-apple-darwin - - name: Build Wasmer C-API (JSC) - shell: bash - run: | - make build-capi-jsc - env: - RUSTFLAGS: -Cpanic=abort - CARGO_TARGET: aarch64-apple-darwin - - name: Dist - run: | - make distribution - env: - CARGO_TARGET: aarch64-apple-darwin - TARGET_DIR: target/aarch64-apple-darwin/release - - name: Upload Artifacts - uses: actions/upload-artifact@v4 - with: - name: 'aarch64-apple-darwin-jsc' - path: dist - if-no-files-found: error - retention-days: 2 + # darwin_aarch64_jsc: + # name: macOS aarch64 (JSC) + # runs-on: macos-12 + # steps: + # - uses: actions/checkout@v3 + # - uses: dtolnay/rust-toolchain@stable + # with: + # target: aarch64-apple-darwin + # - name: Install Darwin-aarch64 target + # shell: bash + # run: | + # rustup target add aarch64-apple-darwin + # - name: Build Wasmer C-API (JSC) + # shell: bash + # run: | + # make build-capi-jsc + # env: + # RUSTFLAGS: -Cpanic=abort + # CARGO_TARGET: aarch64-apple-darwin + # - name: Dist + # run: | + # make distribution + # env: + # CARGO_TARGET: aarch64-apple-darwin + # TARGET_DIR: target/aarch64-apple-darwin/release + # - name: Upload Artifacts + # uses: actions/upload-artifact@v4 + # with: + # name: 'aarch64-apple-darwin-jsc' + # path: dist + # if-no-files-found: error + # retention-days: 2 - darwin_x86_64_jsc: - name: macOS x86_64 (JSC) - runs-on: macos-12 - steps: - - uses: actions/checkout@v3 - - uses: dtolnay/rust-toolchain@stable - with: - target: x86_64-apple-darwin - - name: Build Wasmer C-API (JSC) - shell: bash - run: | - make build-capi-jsc - env: - RUSTFLAGS: -Cpanic=abort - CARGO_TARGET: x86_64-apple-darwin - - name: Dist - run: | - make distribution - env: - CARGO_TARGET: x86_64-apple-darwin - TARGET_DIR: target/x86_64-apple-darwin/release - - name: Upload Artifacts - uses: actions/upload-artifact@v4 - with: - name: 'x86_64-apple-darwin-jsc' - path: dist - if-no-files-found: error - retention-days: 2 + # darwin_x86_64_jsc: + # name: macOS x86_64 (JSC) + # runs-on: macos-12 + # steps: + # - uses: actions/checkout@v3 + # - uses: dtolnay/rust-toolchain@stable + # with: + # target: x86_64-apple-darwin + # - name: Build Wasmer C-API (JSC) + # shell: bash + # run: | + # make build-capi-jsc + # env: + # RUSTFLAGS: -Cpanic=abort + # CARGO_TARGET: x86_64-apple-darwin + # - name: Dist + # run: | + # make distribution + # env: + # CARGO_TARGET: x86_64-apple-darwin + # TARGET_DIR: target/x86_64-apple-darwin/release + # - name: Upload Artifacts + # uses: actions/upload-artifact@v4 + # with: + # name: 'x86_64-apple-darwin-jsc' + # path: dist + # if-no-files-found: error + # retention-days: 2 - linux_aarch64: - name: Linux aarch64 - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v3 - - uses: dtolnay/rust-toolchain@stable - with: - target: aarch64-unknown-linux-gnu - - name: Build cross image - run: | - docker build -t wasmer/aarch64 ${GITHUB_WORKSPACE}/.github/cross-linux-aarch64/ - env: - CROSS_DOCKER_IN_DOCKER: true - - name: Build Wasmer binary - run: | - make build-wasmer - env: - CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross - CROSS_DOCKER_IN_DOCKER: true - CARGO_TARGET: aarch64-unknown-linux-gnu - PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig - PKG_CONFIG_ALLOW_CROSS: true - ENABLE_LLVM: 0 - - name: Build C API headless - shell: bash - run: | - make package-capi-headless - env: - CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross - CROSS_DOCKER_IN_DOCKER: true - CARGO_TARGET: aarch64-unknown-linux-gnu - PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig - PKG_CONFIG_ALLOW_CROSS: true - ENABLE_LLVM: 0 - TARGET: aarch64-unknown-linux-gnu - TARGET_DIR: target/aarch64-unknown-linux-gnu/release - - name: Build C API - run: | - make build-capi - env: - CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross - CROSS_DOCKER_IN_DOCKER: true - CARGO_TARGET: aarch64-unknown-linux-gnu - PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig - PKG_CONFIG_ALLOW_CROSS: true - ENABLE_LLVM: 0 - - name: Dist - run: | - make distribution - env: - CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross - CROSS_DOCKER_IN_DOCKER: true - CARGO_TARGET: aarch64-unknown-linux-gnu - PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig - PKG_CONFIG_ALLOW_CROSS: true - TARGET: aarch64-unknown-linux-gnu - TARGET_DIR: target/aarch64-unknown-linux-gnu/release - - name: Upload Artifacts - uses: actions/upload-artifact@v4 - with: - name: wasmer-linux-aarch64 - path: dist - if-no-files-found: error - retention-days: 2 + # linux_aarch64: + # name: Linux aarch64 + # runs-on: ubuntu-latest + # steps: + # - uses: actions/checkout@v3 + # - uses: dtolnay/rust-toolchain@stable + # with: + # target: aarch64-unknown-linux-gnu + # - name: Build cross image + # run: | + # docker build -t wasmer/aarch64 ${GITHUB_WORKSPACE}/.github/cross-linux-aarch64/ + # env: + # CROSS_DOCKER_IN_DOCKER: true + # - name: Build Wasmer binary + # run: | + # make build-wasmer + # env: + # CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross + # CROSS_DOCKER_IN_DOCKER: true + # CARGO_TARGET: aarch64-unknown-linux-gnu + # PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig + # PKG_CONFIG_ALLOW_CROSS: true + # ENABLE_LLVM: 0 + # - name: Build C API headless + # shell: bash + # run: | + # make package-capi-headless + # env: + # CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross + # CROSS_DOCKER_IN_DOCKER: true + # CARGO_TARGET: aarch64-unknown-linux-gnu + # PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig + # PKG_CONFIG_ALLOW_CROSS: true + # ENABLE_LLVM: 0 + # TARGET: aarch64-unknown-linux-gnu + # TARGET_DIR: target/aarch64-unknown-linux-gnu/release + # - name: Build C API + # run: | + # make build-capi + # env: + # CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross + # CROSS_DOCKER_IN_DOCKER: true + # CARGO_TARGET: aarch64-unknown-linux-gnu + # PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig + # PKG_CONFIG_ALLOW_CROSS: true + # ENABLE_LLVM: 0 + # - name: Dist + # run: | + # make distribution + # env: + # CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross + # CROSS_DOCKER_IN_DOCKER: true + # CARGO_TARGET: aarch64-unknown-linux-gnu + # PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig + # PKG_CONFIG_ALLOW_CROSS: true + # TARGET: aarch64-unknown-linux-gnu + # TARGET_DIR: target/aarch64-unknown-linux-gnu/release + # - name: Upload Artifacts + # uses: actions/upload-artifact@v4 + # with: + # name: wasmer-linux-aarch64 + # path: dist + # if-no-files-found: error + # retention-days: 2 - linux_riscv64: - name: Linux riscv64 - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v3 - - uses: dtolnay/rust-toolchain@stable - with: - target: riscv64gc-unknown-linux-gnu - - name: Build cross image - run: | - docker build -t wasmer/riscv64 ${GITHUB_WORKSPACE}/.github/cross-linux-riscv64/ - env: - CROSS_DOCKER_IN_DOCKER: true - - name: Build Wasmer binary - run: | - make build-wasmer - env: - CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64:latest cargo - CROSS_DOCKER_IN_DOCKER: true - CARGO_TARGET: riscv64gc-unknown-linux-gnu - PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig - PKG_CONFIG_ALLOW_CROSS: true - ENABLE_LLVM: 0 - - name: Build C API headless - shell: bash - run: | - make package-capi-headless - env: - CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64:latest cargo - CROSS_DOCKER_IN_DOCKER: true - CARGO_TARGET: riscv64gc-unknown-linux-gnu - PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig - PKG_CONFIG_ALLOW_CROSS: true - ENABLE_LLVM: 0 - TARGET: riscv64gc-unknown-linux-gnu - TARGET_DIR: target/riscv64gc-unknown-linux-gnu/release - - name: Build C API - run: | - make build-capi - env: - CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64:latest cargo - CROSS_DOCKER_IN_DOCKER: true - CARGO_TARGET: riscv64gc-unknown-linux-gnu - PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig - PKG_CONFIG_ALLOW_CROSS: true - ENABLE_LLVM: 0 - - name: Dist - run: | - make distribution - env: - CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64:latest cargo - CROSS_DOCKER_IN_DOCKER: true - CARGO_TARGET: riscv64gc-unknown-linux-gnu - PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig - PKG_CONFIG_ALLOW_CROSS: true - TARGET: riscv64gc-unknown-linux-gnu - TARGET_DIR: target/riscv64gc-unknown-linux-gnu/release - - name: Upload Artifacts - uses: actions/upload-artifact@v4 - with: - name: wasmer-linux-riscv64 - path: dist - if-no-files-found: error - retention-days: 2 + # linux_riscv64: + # name: Linux riscv64 + # runs-on: ubuntu-latest + # steps: + # - uses: actions/checkout@v3 + # - uses: dtolnay/rust-toolchain@stable + # with: + # target: riscv64gc-unknown-linux-gnu + # - name: Build cross image + # run: | + # docker build -t wasmer/riscv64 ${GITHUB_WORKSPACE}/.github/cross-linux-riscv64/ + # env: + # CROSS_DOCKER_IN_DOCKER: true + # - name: Build Wasmer binary + # run: | + # make build-wasmer + # env: + # CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64:latest cargo + # CROSS_DOCKER_IN_DOCKER: true + # CARGO_TARGET: riscv64gc-unknown-linux-gnu + # PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig + # PKG_CONFIG_ALLOW_CROSS: true + # ENABLE_LLVM: 0 + # - name: Build C API headless + # shell: bash + # run: | + # make package-capi-headless + # env: + # CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64:latest cargo + # CROSS_DOCKER_IN_DOCKER: true + # CARGO_TARGET: riscv64gc-unknown-linux-gnu + # PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig + # PKG_CONFIG_ALLOW_CROSS: true + # ENABLE_LLVM: 0 + # TARGET: riscv64gc-unknown-linux-gnu + # TARGET_DIR: target/riscv64gc-unknown-linux-gnu/release + # - name: Build C API + # run: | + # make build-capi + # env: + # CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64:latest cargo + # CROSS_DOCKER_IN_DOCKER: true + # CARGO_TARGET: riscv64gc-unknown-linux-gnu + # PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig + # PKG_CONFIG_ALLOW_CROSS: true + # ENABLE_LLVM: 0 + # - name: Dist + # run: | + # make distribution + # env: + # CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64:latest cargo + # CROSS_DOCKER_IN_DOCKER: true + # CARGO_TARGET: riscv64gc-unknown-linux-gnu + # PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig + # PKG_CONFIG_ALLOW_CROSS: true + # TARGET: riscv64gc-unknown-linux-gnu + # TARGET_DIR: target/riscv64gc-unknown-linux-gnu/release + # - name: Upload Artifacts + # uses: actions/upload-artifact@v4 + # with: + # name: wasmer-linux-riscv64 + # path: dist + # if-no-files-found: error + # retention-days: 2 release: needs: [setup, build, linux_aarch64, windows_gnu, linux_riscv64] From a433615a3dd9cfc047528e98ede3e91ed0ed0700 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 13:49:43 +0330 Subject: [PATCH 14/59] also install gcc --- .github/workflows/build.yml | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 696b3432f7c..e3f85dc61ba 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -156,7 +156,7 @@ jobs: if: startsWith(matrix.build, 'macos-') shell: bash run: | - brew install ninja + brew install ninja gcc - name: Install `ninja` on Windows if: startsWith(matrix.build, 'windows-') shell: bash @@ -166,7 +166,6 @@ jobs: if: startsWith(matrix.build, 'macos-') shell: bash run: | - sudo xcode-select --install sudo xcode-select -s /Library/Developer/CommandLineTools - name: Install Rust uses: dtolnay/rust-toolchain@stable From 4505e997cc8ee00f40731fa7fc688bc0f397346b Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 13:51:28 +0330 Subject: [PATCH 15/59] try to fix macos --- .github/workflows/build.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index e3f85dc61ba..ba608bf97a6 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -167,6 +167,7 @@ jobs: shell: bash run: | sudo xcode-select -s /Library/Developer/CommandLineTools + export CPATH=/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include - name: Install Rust uses: dtolnay/rust-toolchain@stable with: @@ -280,6 +281,7 @@ jobs: - name: Build Wasmer with v8 backend if: endsWith(matrix.build, 'v8') run: | + echo $CPATH if [ "${{ matrix.build }}" == "linux-x64-v8" ] || [ "${{ matrix.build }}" == "linux-musl-x64-v8" ]; then RUSTFLAGS="-C linker=clang -C link-arg=-fuse-ld=mold" make build-wasmer-v8 else From 53bb16c9d061555bd2eef2a3abe3096ecbca1755 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 13:52:57 +0330 Subject: [PATCH 16/59] trigger --- .github/workflows/build.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index ba608bf97a6..096fd13abd6 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -601,7 +601,8 @@ jobs: # retention-days: 2 release: - needs: [setup, build, linux_aarch64, windows_gnu, linux_riscv64] + # needs: [setup, build, linux_aarch64, windows_gnu, linux_riscv64] + needs: [setup, build] runs-on: ubuntu-latest if: needs.setup.outputs.DOING_RELEASE == '1' || github.event.inputs.release != '' steps: From 43ecbc1cb8d0e5a217de3d0c3eba6c0d78acee87 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 14:13:10 +0330 Subject: [PATCH 17/59] enable v8 on windows --- .github/workflows/build.yml | 50 +++++++++++++++++++++++++++++-------- 1 file changed, 39 insertions(+), 11 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 096fd13abd6..9ff8c9a314d 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -86,14 +86,14 @@ jobs: # use_sccache: false # use_llvm: true # build_wasm: false - - build: macos-x64-v8 - os: macos-13 - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' - artifact_name: 'wasmer-v8-darwin-amd64' - cross_compilation_artifact_name: 'cross_compiled_from_mac' - use_sccache: false - use_llvm: true - build_wasm: false + # - build: macos-x64-v8 + # os: macos-13 + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + # artifact_name: 'wasmer-v8-darwin-amd64' + # cross_compilation_artifact_name: 'cross_compiled_from_mac' + # use_sccache: false + # use_llvm: true + # build_wasm: false # - build: macos-x64-wamr # os: macos-13 # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' @@ -127,6 +127,30 @@ jobs: # use_sccache: false # use_llvm: true # build_wasm: false + - build: windows-x64-v8 + os: windows-2019 + artifact_name: 'wasmer-v8-windows-amd64' + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + cross_compilation_artifact_name: 'cross_compiled_from_win' + use_sccache: false + use_llvm: true + build_wasm: false + - build: windows-x64-wamr + os: windows-2019 + artifact_name: 'wasmer-wamr-windows-amd64' + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + cross_compilation_artifact_name: 'cross_compiled_from_win' + use_sccache: false + use_llvm: true + build_wasm: false + - build: windows-x64-wasmi + os: windows-2019 + artifact_name: 'wasmer-wasmi-windows-amd64' + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + cross_compilation_artifact_name: 'cross_compiled_from_win' + use_sccache: false + use_llvm: true + build_wasm: false # - build: linux-musl-x64 # os: ubuntu-latest # artifact_name: 'wasmer-linux-musl-amd64' @@ -162,12 +186,19 @@ jobs: shell: bash run: | choco install ninja + - name: Delete unwanted link to stop it from interfering (Windows) + if: startsWith(matrix.build, 'windows-') + shell: bash + run: rm /usr/bin/link.exe - name: Install standard header files on macOS if: startsWith(matrix.build, 'macos-') shell: bash run: | sudo xcode-select -s /Library/Developer/CommandLineTools export CPATH=/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include + - name: Install MSVC dev-cmd (Windows) + uses: ilammy/msvc-dev-cmd@v1 + if: ${{ matrix.build == 'windows-x64' }} - name: Install Rust uses: dtolnay/rust-toolchain@stable with: @@ -189,9 +220,6 @@ jobs: echo "${LLVM_DIR}/bin" >> $GITHUB_PATH env: LLVM_DIR: .llvm - - name: Install MSVC dev-cmd (Windows) - uses: ilammy/msvc-dev-cmd@v1 - if: ${{ matrix.metadata.build == 'windows-x64' }} - name: Configure LLVM (Windows) # The Custom Windows build does not contains llvm-config.exe, so need to setup manualy here if: matrix.build == 'windows-x64' && matrix.llvm_url From 948891fbb7009b04a995d190c3abed2e7819aee2 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 14:17:01 +0330 Subject: [PATCH 18/59] fix windows step --- .github/workflows/build.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 9ff8c9a314d..dfd9174e9a8 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -198,7 +198,7 @@ jobs: export CPATH=/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include - name: Install MSVC dev-cmd (Windows) uses: ilammy/msvc-dev-cmd@v1 - if: ${{ matrix.build == 'windows-x64' }} + if: startsWith(matrix.build, 'windows-') - name: Install Rust uses: dtolnay/rust-toolchain@stable with: From a4d5a72497e3cf2f097d1d4cbda1c2dfd2c8c8f0 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 14:53:08 +0330 Subject: [PATCH 19/59] fix v8 on windows --- .github/workflows/build.yml | 33 +++++++++++++++++---------------- 1 file changed, 17 insertions(+), 16 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index dfd9174e9a8..b01e941419e 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -291,14 +291,14 @@ jobs: '${{ runner.tool_cache }}/cargo-sccache/bin/sccache' -s echo 'RUSTC_WRAPPER=${{ runner.tool_cache }}/cargo-sccache/bin/sccache' >> $GITHUB_ENV shell: bash - - name: Build C API headless - shell: bash - run: | - make package-capi-headless - - name: Build C API - shell: bash - run: | - make build-capi + # - name: Build C API headless + # shell: bash + # run: | + # make package-capi-headless + # - name: Build C API + # shell: bash + # run: | + # make build-capi # - name: Build Wasmer binary with LLVM # if: matrix.use_llvm # shell: bash @@ -308,6 +308,7 @@ jobs: # ENABLE_LLVM: 1 - name: Build Wasmer with v8 backend if: endsWith(matrix.build, 'v8') + shell: bash run: | echo $CPATH if [ "${{ matrix.build }}" == "linux-x64-v8" ] || [ "${{ matrix.build }}" == "linux-musl-x64-v8" ]; then @@ -315,14 +316,14 @@ jobs: else make build-wasmer-v8 fi - - name: Build Wasmer with wamr backend - if: endsWith(matrix.build, 'wamr') - run: | - make build-wasmer-wamr - - name: Build Wasmer with wasmi backend - if: endsWith(matrix.build, 'wasmi') - run: | - make build-wasmer-wasmi + # - name: Build Wasmer with wamr backend + # if: endsWith(matrix.build, 'wamr') + # run: | + # make build-wasmer-wamr + # - name: Build Wasmer with wasmi backend + # if: endsWith(matrix.build, 'wasmi') + # run: | + # make build-wasmer-wasmi # - name: Build Wasmer binary without LLVM # if: matrix.use_llvm != true # shell: bash From 149f6b46cd1e690e6deab36fd88dfa504d65e80f Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 15:11:16 +0330 Subject: [PATCH 20/59] fix v8 on windows --- .github/workflows/build.yml | 46 ++++++++++++++++++------------------- 1 file changed, 22 insertions(+), 24 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index b01e941419e..9f8f06b2697 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -135,22 +135,22 @@ jobs: use_sccache: false use_llvm: true build_wasm: false - - build: windows-x64-wamr - os: windows-2019 - artifact_name: 'wasmer-wamr-windows-amd64' - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' - cross_compilation_artifact_name: 'cross_compiled_from_win' - use_sccache: false - use_llvm: true - build_wasm: false - - build: windows-x64-wasmi - os: windows-2019 - artifact_name: 'wasmer-wasmi-windows-amd64' - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' - cross_compilation_artifact_name: 'cross_compiled_from_win' - use_sccache: false - use_llvm: true - build_wasm: false + # - build: windows-x64-wamr + # os: windows-2019 + # artifact_name: 'wasmer-wamr-windows-amd64' + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + # cross_compilation_artifact_name: 'cross_compiled_from_win' + # use_sccache: false + # use_llvm: true + # build_wasm: false + # - build: windows-x64-wasmi + # os: windows-2019 + # artifact_name: 'wasmer-wasmi-windows-amd64' + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + # cross_compilation_artifact_name: 'cross_compiled_from_win' + # use_sccache: false + # use_llvm: true + # build_wasm: false # - build: linux-musl-x64 # os: ubuntu-latest # artifact_name: 'wasmer-linux-musl-amd64' @@ -306,16 +306,14 @@ jobs: # make build-wasmer # env: # ENABLE_LLVM: 1 - - name: Build Wasmer with v8 backend - if: endsWith(matrix.build, 'v8') - shell: bash - run: | - echo $CPATH - if [ "${{ matrix.build }}" == "linux-x64-v8" ] || [ "${{ matrix.build }}" == "linux-musl-x64-v8" ]; then + - name: Build Wasmer with v8 backend with mold + if: ${{ endsWith(matrix.build, 'v8') && startsWith(matrix.build, 'linux') }} + run: | RUSTFLAGS="-C linker=clang -C link-arg=-fuse-ld=mold" make build-wasmer-v8 - else + - name: Build Wasmer with v8 backend + if: ${{ endsWith(matrix.build, 'v8') && !startsWith(matrix.build, 'linux') }} + run: | make build-wasmer-v8 - fi # - name: Build Wasmer with wamr backend # if: endsWith(matrix.build, 'wamr') # run: | From 04c8bd1ed11aad824b4c9440bd15ca68a7fdd559 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 15:29:10 +0330 Subject: [PATCH 21/59] use windows 2022 --- .github/workflows/build.yml | 34 +++++++++++++++++----------------- 1 file changed, 17 insertions(+), 17 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 9f8f06b2697..dbb757c64eb 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -128,29 +128,29 @@ jobs: # use_llvm: true # build_wasm: false - build: windows-x64-v8 - os: windows-2019 + os: windows-2022 artifact_name: 'wasmer-v8-windows-amd64' llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' cross_compilation_artifact_name: 'cross_compiled_from_win' use_sccache: false use_llvm: true build_wasm: false - # - build: windows-x64-wamr - # os: windows-2019 - # artifact_name: 'wasmer-wamr-windows-amd64' - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' - # cross_compilation_artifact_name: 'cross_compiled_from_win' - # use_sccache: false - # use_llvm: true - # build_wasm: false - # - build: windows-x64-wasmi - # os: windows-2019 - # artifact_name: 'wasmer-wasmi-windows-amd64' - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' - # cross_compilation_artifact_name: 'cross_compiled_from_win' - # use_sccache: false - # use_llvm: true - # build_wasm: false + - build: windows-x64-wamr + os: windows-2022 + artifact_name: 'wasmer-wamr-windows-amd64' + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + cross_compilation_artifact_name: 'cross_compiled_from_win' + use_sccache: false + use_llvm: true + build_wasm: false + - build: windows-x64-wasmi + os: windows-2022 + artifact_name: 'wasmer-wasmi-windows-amd64' + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + cross_compilation_artifact_name: 'cross_compiled_from_win' + use_sccache: false + use_llvm: true + build_wasm: false # - build: linux-musl-x64 # os: ubuntu-latest # artifact_name: 'wasmer-linux-musl-amd64' From c32c00551fca4aa6c3641a14626b1c3ce1e6d736 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 15:35:41 +0330 Subject: [PATCH 22/59] re-enable wamr and wasmi for windows --- .github/workflows/build.yml | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index dbb757c64eb..66ec0b8cad3 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -314,14 +314,14 @@ jobs: if: ${{ endsWith(matrix.build, 'v8') && !startsWith(matrix.build, 'linux') }} run: | make build-wasmer-v8 - # - name: Build Wasmer with wamr backend - # if: endsWith(matrix.build, 'wamr') - # run: | - # make build-wasmer-wamr - # - name: Build Wasmer with wasmi backend - # if: endsWith(matrix.build, 'wasmi') - # run: | - # make build-wasmer-wasmi + - name: Build Wasmer with wamr backend + if: endsWith(matrix.build, 'wamr') + run: | + make build-wasmer-wamr + - name: Build Wasmer with wasmi backend + if: endsWith(matrix.build, 'wasmi') + run: | + make build-wasmer-wasmi # - name: Build Wasmer binary without LLVM # if: matrix.use_llvm != true # shell: bash From 4936e713613fd557477260ea7ea3bb9fae579756 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 15:54:02 +0330 Subject: [PATCH 23/59] enable backends on macos x64 --- .github/workflows/build.yml | 100 ++++++++++++++++++------------------ 1 file changed, 50 insertions(+), 50 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 66ec0b8cad3..e8e20b44126 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -86,30 +86,30 @@ jobs: # use_sccache: false # use_llvm: true # build_wasm: false - # - build: macos-x64-v8 - # os: macos-13 - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' - # artifact_name: 'wasmer-v8-darwin-amd64' - # cross_compilation_artifact_name: 'cross_compiled_from_mac' - # use_sccache: false - # use_llvm: true - # build_wasm: false - # - build: macos-x64-wamr - # os: macos-13 - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' - # artifact_name: 'wasmer-wamr-darwin-amd64' - # cross_compilation_artifact_name: 'cross_compiled_from_mac' - # use_sccache: false - # use_llvm: true - # build_wasm: false - # - build: macos-x64-wasmi - # os: macos-13 - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' - # artifact_name: 'wasmer-wasmi-darwin-amd64' - # cross_compilation_artifact_name: 'cross_compiled_from_mac' - # use_sccache: false - # use_llvm: true - # build_wasm: false + - build: macos-x64-v8 + os: macos-13 + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + artifact_name: 'wasmer-v8-darwin-amd64' + cross_compilation_artifact_name: 'cross_compiled_from_mac' + use_sccache: false + use_llvm: true + build_wasm: false + - build: macos-x64-wamr + os: macos-13 + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + artifact_name: 'wasmer-wamr-darwin-amd64' + cross_compilation_artifact_name: 'cross_compiled_from_mac' + use_sccache: false + use_llvm: true + build_wasm: false + - build: macos-x64-wasmi + os: macos-13 + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + artifact_name: 'wasmer-wasmi-darwin-amd64' + cross_compilation_artifact_name: 'cross_compiled_from_mac' + use_sccache: false + use_llvm: true + build_wasm: false # - build: macos-arm64 # os: macos-14 # target: aarch64-apple-darwin @@ -127,30 +127,30 @@ jobs: # use_sccache: false # use_llvm: true # build_wasm: false - - build: windows-x64-v8 - os: windows-2022 - artifact_name: 'wasmer-v8-windows-amd64' - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' - cross_compilation_artifact_name: 'cross_compiled_from_win' - use_sccache: false - use_llvm: true - build_wasm: false - - build: windows-x64-wamr - os: windows-2022 - artifact_name: 'wasmer-wamr-windows-amd64' - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' - cross_compilation_artifact_name: 'cross_compiled_from_win' - use_sccache: false - use_llvm: true - build_wasm: false - - build: windows-x64-wasmi - os: windows-2022 - artifact_name: 'wasmer-wasmi-windows-amd64' - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' - cross_compilation_artifact_name: 'cross_compiled_from_win' - use_sccache: false - use_llvm: true - build_wasm: false + # - build: windows-x64-v8 + # os: windows-2022 + # artifact_name: 'wasmer-v8-windows-amd64' + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + # cross_compilation_artifact_name: 'cross_compiled_from_win' + # use_sccache: false + # use_llvm: true + # build_wasm: false + # - build: windows-x64-wamr + # os: windows-2022 + # artifact_name: 'wasmer-wamr-windows-amd64' + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + # cross_compilation_artifact_name: 'cross_compiled_from_win' + # use_sccache: false + # use_llvm: true + # build_wasm: false + # - build: windows-x64-wasmi + # os: windows-2022 + # artifact_name: 'wasmer-wasmi-windows-amd64' + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + # cross_compilation_artifact_name: 'cross_compiled_from_win' + # use_sccache: false + # use_llvm: true + # build_wasm: false # - build: linux-musl-x64 # os: ubuntu-latest # artifact_name: 'wasmer-linux-musl-amd64' @@ -195,7 +195,7 @@ jobs: shell: bash run: | sudo xcode-select -s /Library/Developer/CommandLineTools - export CPATH=/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include + echo "CPATH=/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include" >> $GITHUB_ENV - name: Install MSVC dev-cmd (Windows) uses: ilammy/msvc-dev-cmd@v1 if: startsWith(matrix.build, 'windows-') @@ -236,7 +236,7 @@ jobs: # using gnu-tar is a workaround for https://github.com/actions/cache/issues/403 brew install gnu-tar echo PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH" >> $GITHUB_ENV - if: matrix.os == 'macos-12' + if: matrix.os == 'macos-13' - uses: actions/cache@v2 with: path: | From d2ded18f44c7b759d3abffd46217aada076eaa30 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 16:12:54 +0330 Subject: [PATCH 24/59] enable backends for macos-arm --- .github/workflows/build.yml | 77 +++++++++++++++++++++++++------------ 1 file changed, 52 insertions(+), 25 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index e8e20b44126..4831f4fca88 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -86,30 +86,30 @@ jobs: # use_sccache: false # use_llvm: true # build_wasm: false - - build: macos-x64-v8 - os: macos-13 - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' - artifact_name: 'wasmer-v8-darwin-amd64' - cross_compilation_artifact_name: 'cross_compiled_from_mac' - use_sccache: false - use_llvm: true - build_wasm: false - - build: macos-x64-wamr - os: macos-13 - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' - artifact_name: 'wasmer-wamr-darwin-amd64' - cross_compilation_artifact_name: 'cross_compiled_from_mac' - use_sccache: false - use_llvm: true - build_wasm: false - - build: macos-x64-wasmi - os: macos-13 - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' - artifact_name: 'wasmer-wasmi-darwin-amd64' - cross_compilation_artifact_name: 'cross_compiled_from_mac' - use_sccache: false - use_llvm: true - build_wasm: false + # - build: macos-x64-v8 + # os: macos-13 + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + # artifact_name: 'wasmer-v8-darwin-amd64' + # cross_compilation_artifact_name: 'cross_compiled_from_mac' + # use_sccache: false + # use_llvm: true + # build_wasm: false + # - build: macos-x64-wamr + # os: macos-13 + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + # artifact_name: 'wasmer-wamr-darwin-amd64' + # cross_compilation_artifact_name: 'cross_compiled_from_mac' + # use_sccache: false + # use_llvm: true + # build_wasm: false + # - build: macos-x64-wasmi + # os: macos-13 + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + # artifact_name: 'wasmer-wasmi-darwin-amd64' + # cross_compilation_artifact_name: 'cross_compiled_from_mac' + # use_sccache: false + # use_llvm: true + # build_wasm: false # - build: macos-arm64 # os: macos-14 # target: aarch64-apple-darwin @@ -117,8 +117,35 @@ jobs: # use_sccache: false # use_llvm: false # build_wasm: false + # # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' + - build: macos-arm64-v8 + os: macos-14 + target: aarch64-apple-darwin + artifact_name: 'wasmer-v8-darwin-arm64' + use_sccache: false + use_llvm: false + build_wasm: false + # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' + - build: macos-arm64-wamr + os: macos-14 + target: aarch64-apple-darwin + artifact_name: 'wasmer-wamr-darwin-arm64' + use_sccache: false + use_llvm: false + build_wasm: false + # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' + - build: macos-arm64-wasmi + os: macos-14 + target: aarch64-apple-darwin + artifact_name: 'wasmer-wasmi-darwin-arm64' + use_sccache: false + use_llvm: false + build_wasm: false # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' # - build: windows-x64 # os: windows-2019 # artifact_name: 'wasmer-windows-amd64' From 92fd41ed9c13893b8f92507221a4224f2efe0162 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 16:14:18 +0330 Subject: [PATCH 25/59] install things on arm as well --- .github/workflows/build.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 4831f4fca88..abf444a7862 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -263,7 +263,7 @@ jobs: # using gnu-tar is a workaround for https://github.com/actions/cache/issues/403 brew install gnu-tar echo PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH" >> $GITHUB_ENV - if: matrix.os == 'macos-13' + if: startsWith(matrix.os == 'macos') - uses: actions/cache@v2 with: path: | From 66415a7554051b9a4c5508b1b95479a57aee7e8d Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 16:16:47 +0330 Subject: [PATCH 26/59] cancel in progress ci --- .github/workflows/build.yml | 3 +++ 1 file changed, 3 insertions(+) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index abf444a7862..05969caeaa0 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -42,6 +42,9 @@ jobs: name: Build on ${{ matrix.build }} runs-on: ${{ matrix.os }} needs: setup + concurrency: + group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }} + cancel-in-progress: true strategy: fail-fast: false matrix: From 18e90ab8a663151877d6883ef49ca4bdb17158e5 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 16:17:33 +0330 Subject: [PATCH 27/59] fix syntax --- .github/workflows/build.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 05969caeaa0..1dca916e721 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -266,7 +266,7 @@ jobs: # using gnu-tar is a workaround for https://github.com/actions/cache/issues/403 brew install gnu-tar echo PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH" >> $GITHUB_ENV - if: startsWith(matrix.os == 'macos') + if: startsWith(matrix.os, 'macos') - uses: actions/cache@v2 with: path: | From 4cd71a9765067ab55b5096db72513c1492f28878 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 16:18:32 +0330 Subject: [PATCH 28/59] revert concurrency --- .github/workflows/build.yml | 3 --- 1 file changed, 3 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 1dca916e721..2f3bd63e3d1 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -42,9 +42,6 @@ jobs: name: Build on ${{ matrix.build }} runs-on: ${{ matrix.os }} needs: setup - concurrency: - group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }} - cancel-in-progress: true strategy: fail-fast: false matrix: From 0f7bc63d092d668dc8d108def75e134e2e46170d Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 16:26:13 +0330 Subject: [PATCH 29/59] enable linux-musl --- .github/workflows/build.yml | 75 ++++++++++++++++++++++++------------- 1 file changed, 48 insertions(+), 27 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 2f3bd63e3d1..47612ee60ed 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -119,33 +119,33 @@ jobs: # build_wasm: false # # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' - - build: macos-arm64-v8 - os: macos-14 - target: aarch64-apple-darwin - artifact_name: 'wasmer-v8-darwin-arm64' - use_sccache: false - use_llvm: false - build_wasm: false - # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' - - build: macos-arm64-wamr - os: macos-14 - target: aarch64-apple-darwin - artifact_name: 'wasmer-wamr-darwin-arm64' - use_sccache: false - use_llvm: false - build_wasm: false - # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' - - build: macos-arm64-wasmi - os: macos-14 - target: aarch64-apple-darwin - artifact_name: 'wasmer-wasmi-darwin-arm64' - use_sccache: false - use_llvm: false - build_wasm: false - # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. - llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' + # - build: macos-arm64-v8 + # os: macos-14 + # target: aarch64-apple-darwin + # artifact_name: 'wasmer-v8-darwin-arm64' + # use_sccache: false + # use_llvm: false + # build_wasm: false + # # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' + # - build: macos-arm64-wamr + # os: macos-14 + # target: aarch64-apple-darwin + # artifact_name: 'wasmer-wamr-darwin-arm64' + # use_sccache: false + # use_llvm: false + # build_wasm: false + # # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' + # - build: macos-arm64-wasmi + # os: macos-14 + # target: aarch64-apple-darwin + # artifact_name: 'wasmer-wasmi-darwin-arm64' + # use_sccache: false + # use_llvm: false + # build_wasm: false + # # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' # - build: windows-x64 # os: windows-2019 # artifact_name: 'wasmer-windows-amd64' @@ -185,6 +185,27 @@ jobs: # use_sccache: false # use_llvm: false # build_wasm: true + - build: linux-musl-x64-v8 + os: ubuntu-latest + artifact_name: 'wasmer-v8-linux-musl-amd64' + container: alpine:latest + use_sccache: false + use_llvm: false + build_wasm: true + - build: linux-musl-x64-wamr + os: ubuntu-latest + artifact_name: 'wasmer-wamr-linux-musl-amd64' + container: alpine:latest + use_sccache: false + use_llvm: false + build_wasm: true + - build: linux-musl-x64-wasmi + os: ubuntu-latest + artifact_name: 'wasmer-wasmi-linux-musl-amd64' + container: alpine:latest + use_sccache: false + use_llvm: false + build_wasm: true container: ${{ matrix.container }} env: SCCACHE_AZURE_BLOB_CONTAINER: wasmerstoragesccacheblob From 2c8dc8caa4acd413d284cf2bbab27c500029a714 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 16:28:41 +0330 Subject: [PATCH 30/59] install bash on alpine --- .github/workflows/build.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 47612ee60ed..596c0ff5361 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -223,7 +223,7 @@ jobs: - name: Install Linux musl tools if: startsWith(matrix.build, 'linux-musl') run: | - apk add mold ninja + apk add mold ninja bash - name: Install `ninja` on macOS if: startsWith(matrix.build, 'macos-') shell: bash From 2d0eb88918bbdb4f8c7f1e437fd43f464b244df4 Mon Sep 17 00:00:00 2001 From: Edoardo Marangoni Date: Fri, 18 Oct 2024 14:59:07 +0200 Subject: [PATCH 31/59] fix(c-api): Change signature for `wasm_val_delete`, implement `Drop` for `wasm_val_t` --- Cargo.lock | 10 +++++----- lib/c-api/Cargo.toml | 2 +- lib/c-api/src/wasm_c_api/value.rs | 21 ++++++++++++++++----- 3 files changed, 22 insertions(+), 11 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 721eaf6a9f3..2e716e90a9a 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -597,20 +597,20 @@ checksum = "37b2a672a2cb129a2e41c10b1224bb368f9f37a2b16b612598138befd7b37eb5" [[package]] name = "cbindgen" -version = "0.24.5" +version = "0.27.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4b922faaf31122819ec80c4047cc684c6979a087366c069611e33649bf98e18d" +checksum = "3fce8dd7fcfcbf3a0a87d8f515194b49d6135acab73e18bd380d1d93bb1a15eb" dependencies = [ "heck 0.4.1", - "indexmap 1.9.3", + "indexmap 2.6.0", "log 0.4.22", "proc-macro2", "quote", "serde", "serde_json", - "syn 1.0.109", + "syn 2.0.79", "tempfile", - "toml 0.5.11", + "toml 0.8.19", ] [[package]] diff --git a/lib/c-api/Cargo.toml b/lib/c-api/Cargo.toml index dad2b23e7b0..ade9ac88870 100644 --- a/lib/c-api/Cargo.toml +++ b/lib/c-api/Cargo.toml @@ -111,4 +111,4 @@ jit = ["compiler"] #emscripten = ["wasmer-emscripten"] [build-dependencies] -cbindgen = { version = "0.24", default-features = false } +cbindgen = { version = "0.27", default-features = false } diff --git a/lib/c-api/src/wasm_c_api/value.rs b/lib/c-api/src/wasm_c_api/value.rs index 3be2f2a340b..8c2e51d6515 100644 --- a/lib/c-api/src/wasm_c_api/value.rs +++ b/lib/c-api/src/wasm_c_api/value.rs @@ -156,14 +156,25 @@ pub unsafe extern "C" fn wasm_val_copy( }); otherwise ()); } -#[no_mangle] -pub unsafe extern "C" fn wasm_val_delete(val: Option>) { - if let Some(val) = val { - // TODO: figure out where wasm_val is allocated first... - let _ = val; +impl Drop for wasm_val_t { + fn drop(&mut self) { + let kind: Result = self.kind.try_into(); + match kind { + Ok(wasm_valkind_enum::WASM_EXTERNREF) | Ok(wasm_valkind_enum::WASM_FUNCREF) => unsafe { + if !self.of.wref.is_null() { + drop(Box::from_raw(self.of.wref)); + } + }, + _ => {} + } } } +#[no_mangle] +pub unsafe extern "C" fn wasm_val_delete(val: *mut wasm_val_t) { + std::ptr::drop_in_place(val); +} + impl TryFrom for wasm_valkind_enum { type Error = &'static str; From 895f5f4f7aad3ebf982298a719143710d676546b Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 16:30:56 +0330 Subject: [PATCH 32/59] install curl on alpine --- .github/workflows/build.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 596c0ff5361..3cbc45cd9c6 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -223,7 +223,7 @@ jobs: - name: Install Linux musl tools if: startsWith(matrix.build, 'linux-musl') run: | - apk add mold ninja bash + apk add mold ninja bash curl - name: Install `ninja` on macOS if: startsWith(matrix.build, 'macos-') shell: bash From 79d5cded4c39193fceb49b6a73a512ad48df0490 Mon Sep 17 00:00:00 2001 From: Edoardo Marangoni Date: Fri, 18 Oct 2024 15:04:24 +0200 Subject: [PATCH 33/59] chore: Add `wamr` folder to .gitignore --- lib/api/third_party/.gitignore | 1 + 1 file changed, 1 insertion(+) create mode 100644 lib/api/third_party/.gitignore diff --git a/lib/api/third_party/.gitignore b/lib/api/third_party/.gitignore new file mode 100644 index 00000000000..b2e7e790c55 --- /dev/null +++ b/lib/api/third_party/.gitignore @@ -0,0 +1 @@ +wamr From bf6a8599f7f06a61515d65e60791518b64915275 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 16:36:56 +0330 Subject: [PATCH 34/59] install more packages --- .github/workflows/build.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 3cbc45cd9c6..d6ed44dbcad 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -223,7 +223,7 @@ jobs: - name: Install Linux musl tools if: startsWith(matrix.build, 'linux-musl') run: | - apk add mold ninja bash curl + apk add mold cmake ninja bash curl make - name: Install `ninja` on macOS if: startsWith(matrix.build, 'macos-') shell: bash From a924c380f43bde7b1777eeb705cdba7f11f07229 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 16:41:31 +0330 Subject: [PATCH 35/59] install llvm18 on alpine --- .github/workflows/build.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index d6ed44dbcad..91c967e3137 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -223,7 +223,7 @@ jobs: - name: Install Linux musl tools if: startsWith(matrix.build, 'linux-musl') run: | - apk add mold cmake ninja bash curl make + apk add mold cmake ninja bash curl make llvm18 - name: Install `ninja` on macOS if: startsWith(matrix.build, 'macos-') shell: bash From 67d2e4bb5fbd27d4079a9bd64ce61c7c7223a0ec Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 16:48:02 +0330 Subject: [PATCH 36/59] install clang --- .github/workflows/build.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 91c967e3137..c63e308208c 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -223,7 +223,7 @@ jobs: - name: Install Linux musl tools if: startsWith(matrix.build, 'linux-musl') run: | - apk add mold cmake ninja bash curl make llvm18 + apk add mold cmake ninja bash curl make llvm18 clang18 - name: Install `ninja` on macOS if: startsWith(matrix.build, 'macos-') shell: bash @@ -384,7 +384,7 @@ jobs: # if: matrix.build != 'linux-musl-x64' # uses: dtolnay/rust-toolchain@master # with: - # toolchain: "nightly-2023-10-05" + # toolchain: "nightly-2024-07-05" # target: ${{ matrix.target }} # components: "rust-src" # - name: Build Minimal Wasmer Headless @@ -402,7 +402,7 @@ jobs: # echo "incremental = false" >> Cargo.toml # echo "codegen-units = 1" >> Cargo.toml # echo "rpath = false" >> Cargo.toml - # rustup override set nightly-2023-10-05 + # rustup override set nightly-2024-07-05 # make build-wasmer-headless-minimal # rustup override unset - name: Dist From c9785748952a9336a95df3900237ff5adef5b6e7 Mon Sep 17 00:00:00 2001 From: Edoardo Marangoni Date: Fri, 18 Oct 2024 15:20:03 +0200 Subject: [PATCH 37/59] fix(c-api): Add null check --- lib/c-api/src/wasm_c_api/value.rs | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/lib/c-api/src/wasm_c_api/value.rs b/lib/c-api/src/wasm_c_api/value.rs index 8c2e51d6515..5a5a6e67561 100644 --- a/lib/c-api/src/wasm_c_api/value.rs +++ b/lib/c-api/src/wasm_c_api/value.rs @@ -172,7 +172,9 @@ impl Drop for wasm_val_t { #[no_mangle] pub unsafe extern "C" fn wasm_val_delete(val: *mut wasm_val_t) { - std::ptr::drop_in_place(val); + if !val.is_null() { + std::ptr::drop_in_place(val); + } } impl TryFrom for wasm_valkind_enum { From 624fdc27144c53a0dc206c63fe8355c5df0a4020 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 16:55:02 +0330 Subject: [PATCH 38/59] install lld --- .github/workflows/build.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index c63e308208c..3a327d7e690 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -223,7 +223,7 @@ jobs: - name: Install Linux musl tools if: startsWith(matrix.build, 'linux-musl') run: | - apk add mold cmake ninja bash curl make llvm18 clang18 + apk add mold cmake ninja bash curl make llvm18 clang18 lld - name: Install `ninja` on macOS if: startsWith(matrix.build, 'macos-') shell: bash From c23d6593a5e177f21cd6d797643ec3663c991ccc Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 17:00:03 +0330 Subject: [PATCH 39/59] do not use mold when building with musl --- .github/workflows/build.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 3a327d7e690..16153bbc81d 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -355,11 +355,11 @@ jobs: # env: # ENABLE_LLVM: 1 - name: Build Wasmer with v8 backend with mold - if: ${{ endsWith(matrix.build, 'v8') && startsWith(matrix.build, 'linux') }} + if: ${{ endsWith(matrix.build, 'v8') && startsWith(matrix.build, 'linux-x64') }} run: | RUSTFLAGS="-C linker=clang -C link-arg=-fuse-ld=mold" make build-wasmer-v8 - name: Build Wasmer with v8 backend - if: ${{ endsWith(matrix.build, 'v8') && !startsWith(matrix.build, 'linux') }} + if: ${{ endsWith(matrix.build, 'v8') && !startsWith(matrix.build, 'linux-x64') }} run: | make build-wasmer-v8 - name: Build Wasmer with wamr backend From f96bb21dc2ac64ef0da55929094fd76ff0d0bc44 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 17:14:14 +0330 Subject: [PATCH 40/59] fix clang and add release steps for backends --- .github/workflows/build.yml | 140 +++++++++++++++++++++++++++++++++++- 1 file changed, 139 insertions(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 16153bbc81d..3284a901562 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -223,7 +223,7 @@ jobs: - name: Install Linux musl tools if: startsWith(matrix.build, 'linux-musl') run: | - apk add mold cmake ninja bash curl make llvm18 clang18 lld + apk add mold cmake ninja bash curl make llvm18 clang18 lld clang18-libclang - name: Install `ninja` on macOS if: startsWith(matrix.build, 'macos-') shell: bash @@ -713,6 +713,33 @@ jobs: asset_path: artifacts/wasmer-windows-amd64/wasmer.tar.gz asset_name: wasmer-windows-amd64.tar.gz asset_content_type: application/gzip + - name: Upload Release Asset Windows v8 + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: artifacts/wasmer-v8-windows-amd64/wasmer.tar.gz + asset_name: wasmer-v8-windows-amd64.tar.gz + asset_content_type: application/gzip + - name: Upload Release Asset Windows wamr + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: artifacts/wasmer-wamr-windows-amd64/wasmer.tar.gz + asset_name: wasmer-wamr-windows-amd64.tar.gz + asset_content_type: application/gzip + - name: Upload Release Asset Windows wasmi + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: artifacts/wasmer-wasmi-windows-amd64/wasmer.tar.gz + asset_name: wasmer-wasmi-windows-amd64.tar.gz + asset_content_type: application/gzip - name: Upload Release Asset Linux amd64 uses: actions/upload-release-asset@v1 env: @@ -722,6 +749,33 @@ jobs: asset_path: artifacts/wasmer-linux-amd64/wasmer.tar.gz asset_name: wasmer-linux-amd64.tar.gz asset_content_type: application/gzip + - name: Upload Release Asset v8 Linux amd64 + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: artifacts/wasmer-v8-linux-amd64/wasmer.tar.gz + asset_name: wasmer-v8-linux-amd64.tar.gz + asset_content_type: application/gzip + - name: Upload Release Asset wamr Linux amd64 + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: artifacts/wasmer-wamr-linux-amd64/wasmer.tar.gz + asset_name: wasmer-wamr-linux-amd64.tar.gz + asset_content_type: application/gzip + - name: Upload Release Asset wasmi Linux amd64 + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: artifacts/wasmer-wasmi-linux-amd64/wasmer.tar.gz + asset_name: wasmer-wasmi-linux-amd64.tar.gz + asset_content_type: application/gzip - name: Upload Release Asset Linux aarch64 uses: actions/upload-release-asset@v1 env: @@ -759,6 +813,36 @@ jobs: asset_path: artifacts/wasmer-linux-musl-amd64/wasmer.tar.gz asset_name: wasmer-linux-musl-amd64.tar.gz asset_content_type: application/gzip + - name: Upload Release Asset Linux amd64 (musl) v8 + id: upload-release-asset-linux-musl-amd64-v8 + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: artifacts/wasmer-v8-linux-musl-amd64/wasmer.tar.gz + asset_name: wasmer-v8-linux-musl-amd64.tar.gz + asset_content_type: application/gzip + - name: Upload Release Asset Linux amd64 (musl) wamr + id: upload-release-asset-linux-musl-amd64-wamr + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: artifacts/wasmer-wamr-linux-musl-amd64/wasmer.tar.gz + asset_name: wasmer-wamr-linux-musl-amd64.tar.gz + asset_content_type: application/gzip + - name: Upload Release Asset Linux amd64 (musl) wasmi + id: upload-release-asset-linux-musl-amd64-wasmi + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: artifacts/wasmer-wasmi-linux-musl-amd64/wasmer.tar.gz + asset_name: wasmer-wasmi-linux-musl-amd64.tar.gz + asset_content_type: application/gzip - name: Upload Release Asset Mac amd64 uses: actions/upload-release-asset@v1 env: @@ -768,6 +852,33 @@ jobs: asset_path: artifacts/wasmer-darwin-amd64/wasmer.tar.gz asset_name: wasmer-darwin-amd64.tar.gz asset_content_type: application/gzip + - name: Upload Release Asset Mac amd64 v8 + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: artifacts/wasmer-v8-darwin-amd64/wasmer.tar.gz + asset_name: wasmer-v8-darwin-amd64.tar.gz + asset_content_type: application/gzip + - name: Upload Release Asset Mac amd64 wamr + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: artifacts/wasmer-wamr-darwin-amd64/wasmer.tar.gz + asset_name: wasmer-wamr-darwin-amd64.tar.gz + asset_content_type: application/gzip + - name: Upload Release Asset Mac amd64 wasmi + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: artifacts/wasmer-wasmi-darwin-amd64/wasmer.tar.gz + asset_name: wasmer-wasmi-darwin-amd64.tar.gz + asset_content_type: application/gzip - name: Upload Release Asset Mac arm64 uses: actions/upload-release-asset@v1 env: @@ -777,3 +888,30 @@ jobs: asset_path: artifacts/wasmer-darwin-arm64/wasmer.tar.gz asset_name: wasmer-darwin-arm64.tar.gz asset_content_type: application/gzip + - name: Upload Release Asset Mac arm64 v8 + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: artifacts/wasmer-v8-darwin-arm64/wasmer.tar.gz + asset_name: wasmer-v8-darwin-arm64.tar.gz + asset_content_type: application/gzip + - name: Upload Release Asset Mac arm64 wamr + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: artifacts/wasmer-wamr-darwin-arm64/wasmer.tar.gz + asset_name: wasmer-wamr-darwin-arm64.tar.gz + asset_content_type: application/gzip + - name: Upload Release Asset Mac arm64 wasmi + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: artifacts/wasmer-wasmi-darwin-arm64/wasmer.tar.gz + asset_name: wasmer-wasmi-darwin-arm64.tar.gz + asset_content_type: application/gzip From 883fa9dd9ad1c99285b5c0b76bd5ce45710dbdcd Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 17:29:46 +0330 Subject: [PATCH 41/59] install clang static --- .github/workflows/build.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 3284a901562..d34c71e44bc 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -223,7 +223,7 @@ jobs: - name: Install Linux musl tools if: startsWith(matrix.build, 'linux-musl') run: | - apk add mold cmake ninja bash curl make llvm18 clang18 lld clang18-libclang + apk add mold cmake ninja bash curl make llvm18 clang18 lld clang18-static - name: Install `ninja` on macOS if: startsWith(matrix.build, 'macos-') shell: bash From 1089cf5228c8a4a23b22bcbeec1fd5a3c187b822 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 17:40:23 +0330 Subject: [PATCH 42/59] also install shared libs I guess --- .github/workflows/build.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index d34c71e44bc..1ed35d446ef 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -223,7 +223,7 @@ jobs: - name: Install Linux musl tools if: startsWith(matrix.build, 'linux-musl') run: | - apk add mold cmake ninja bash curl make llvm18 clang18 lld clang18-static + apk add mold cmake ninja bash curl make llvm18 clang18 lld clang18-static clang18-libclang - name: Install `ninja` on macOS if: startsWith(matrix.build, 'macos-') shell: bash From 7c9be634a85084dbcee9aa8406b035912fb513a2 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 17:51:22 +0330 Subject: [PATCH 43/59] add path for static clang --- .github/workflows/build.yml | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 1ed35d446ef..452ef76a97d 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -224,6 +224,7 @@ jobs: if: startsWith(matrix.build, 'linux-musl') run: | apk add mold cmake ninja bash curl make llvm18 clang18 lld clang18-static clang18-libclang + echo "LIBCLANG_STATIC_PATH=/usr/lib/llvm18/lib" >> $GITHUB_ENV - name: Install `ninja` on macOS if: startsWith(matrix.build, 'macos-') shell: bash @@ -357,11 +358,12 @@ jobs: - name: Build Wasmer with v8 backend with mold if: ${{ endsWith(matrix.build, 'v8') && startsWith(matrix.build, 'linux-x64') }} run: | - RUSTFLAGS="-C linker=clang -C link-arg=-fuse-ld=mold" make build-wasmer-v8 + RUSTFLAGS="-C linker=clang -C link-arg=-fuse-ld=mold" make build-wasmer-v8 - name: Build Wasmer with v8 backend if: ${{ endsWith(matrix.build, 'v8') && !startsWith(matrix.build, 'linux-x64') }} run: | - make build-wasmer-v8 + echo $LIBCLANG_STATIC_PATH + make build-wasmer-v8 - name: Build Wasmer with wamr backend if: endsWith(matrix.build, 'wamr') run: | From bb2d2ff010fa22af9a86fa92244e3a0e3d7ea06b Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 17:52:30 +0330 Subject: [PATCH 44/59] also install llvm-dev --- .github/workflows/build.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 452ef76a97d..1dbd3a33ec9 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -223,7 +223,7 @@ jobs: - name: Install Linux musl tools if: startsWith(matrix.build, 'linux-musl') run: | - apk add mold cmake ninja bash curl make llvm18 clang18 lld clang18-static clang18-libclang + apk add mold cmake ninja bash curl make llvm18 llvm18-dev clang18 lld clang18-static clang18-libclang echo "LIBCLANG_STATIC_PATH=/usr/lib/llvm18/lib" >> $GITHUB_ENV - name: Install `ninja` on macOS if: startsWith(matrix.build, 'macos-') From 17fca958cd9c1e8db750f5efe38282f1c4710107 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 18:01:41 +0330 Subject: [PATCH 45/59] remove shared lib --- .github/workflows/build.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 1dbd3a33ec9..f3f6d3c67f2 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -223,8 +223,9 @@ jobs: - name: Install Linux musl tools if: startsWith(matrix.build, 'linux-musl') run: | - apk add mold cmake ninja bash curl make llvm18 llvm18-dev clang18 lld clang18-static clang18-libclang + apk add mold cmake ninja bash curl make llvm18 llvm18-dev clang18 lld clang18-static echo "LIBCLANG_STATIC_PATH=/usr/lib/llvm18/lib" >> $GITHUB_ENV + ls /usr/lib/llvm18/lib - name: Install `ninja` on macOS if: startsWith(matrix.build, 'macos-') shell: bash From ba6d39270b05fe2f07fb5c70a5d8f35e1e976f1e Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 18:17:04 +0330 Subject: [PATCH 46/59] test all builds except musl --- .github/workflows/build.yml | 938 +++++++++++++++++------------------- 1 file changed, 442 insertions(+), 496 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index f3f6d3c67f2..2047f964de0 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -46,162 +46,141 @@ jobs: fail-fast: false matrix: include: - # - build: linux-x64 - # os: ubuntu-22.04 - # artifact_name: 'wasmer-linux-amd64' - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' - # cross_compilation_artifact_name: 'cross_compiled_from_linux' - # use_sccache: false - # use_llvm: true - # build_wasm: true - # - build: linux-x64-v8 - # os: ubuntu-22.04 - # artifact_name: 'wasmer-v8-linux-amd64' - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' - # cross_compilation_artifact_name: 'cross_compiled_from_linux' - # use_sccache: false - # use_llvm: true - # build_wasm: true - # - build: linux-x64-wamr - # os: ubuntu-22.04 - # artifact_name: 'wasmer-wamr-linux-amd64' - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' - # cross_compilation_artifact_name: 'cross_compiled_from_linux' - # use_sccache: false - # use_llvm: true - # build_wasm: true - # - build: linux-x64-wasmi - # os: ubuntu-22.04 - # artifact_name: 'wasmer-wasmi-linux-amd64' - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' - # cross_compilation_artifact_name: 'cross_compiled_from_linux' - # use_sccache: false - # use_llvm: true - # build_wasm: true - # - build: macos-x64 - # os: macos-13 - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' - # artifact_name: 'wasmer-darwin-amd64' - # cross_compilation_artifact_name: 'cross_compiled_from_mac' - # use_sccache: false - # use_llvm: true - # build_wasm: false - # - build: macos-x64-v8 - # os: macos-13 - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' - # artifact_name: 'wasmer-v8-darwin-amd64' - # cross_compilation_artifact_name: 'cross_compiled_from_mac' - # use_sccache: false - # use_llvm: true - # build_wasm: false - # - build: macos-x64-wamr - # os: macos-13 - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' - # artifact_name: 'wasmer-wamr-darwin-amd64' - # cross_compilation_artifact_name: 'cross_compiled_from_mac' - # use_sccache: false - # use_llvm: true - # build_wasm: false - # - build: macos-x64-wasmi - # os: macos-13 - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' - # artifact_name: 'wasmer-wasmi-darwin-amd64' - # cross_compilation_artifact_name: 'cross_compiled_from_mac' - # use_sccache: false - # use_llvm: true - # build_wasm: false - # - build: macos-arm64 - # os: macos-14 - # target: aarch64-apple-darwin - # artifact_name: 'wasmer-darwin-arm64' - # use_sccache: false - # use_llvm: false - # build_wasm: false - # # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' - # - build: macos-arm64-v8 - # os: macos-14 - # target: aarch64-apple-darwin - # artifact_name: 'wasmer-v8-darwin-arm64' - # use_sccache: false - # use_llvm: false - # build_wasm: false - # # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' - # - build: macos-arm64-wamr - # os: macos-14 - # target: aarch64-apple-darwin - # artifact_name: 'wasmer-wamr-darwin-arm64' - # use_sccache: false - # use_llvm: false - # build_wasm: false - # # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' - # - build: macos-arm64-wasmi - # os: macos-14 - # target: aarch64-apple-darwin - # artifact_name: 'wasmer-wasmi-darwin-arm64' - # use_sccache: false - # use_llvm: false - # build_wasm: false - # # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' - # - build: windows-x64 - # os: windows-2019 - # artifact_name: 'wasmer-windows-amd64' - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' - # cross_compilation_artifact_name: 'cross_compiled_from_win' - # use_sccache: false - # use_llvm: true - # build_wasm: false - # - build: windows-x64-v8 - # os: windows-2022 - # artifact_name: 'wasmer-v8-windows-amd64' - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' - # cross_compilation_artifact_name: 'cross_compiled_from_win' - # use_sccache: false - # use_llvm: true - # build_wasm: false - # - build: windows-x64-wamr - # os: windows-2022 - # artifact_name: 'wasmer-wamr-windows-amd64' - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' - # cross_compilation_artifact_name: 'cross_compiled_from_win' - # use_sccache: false - # use_llvm: true - # build_wasm: false - # - build: windows-x64-wasmi - # os: windows-2022 - # artifact_name: 'wasmer-wasmi-windows-amd64' - # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' - # cross_compilation_artifact_name: 'cross_compiled_from_win' - # use_sccache: false - # use_llvm: true - # build_wasm: false - # - build: linux-musl-x64 - # os: ubuntu-latest - # artifact_name: 'wasmer-linux-musl-amd64' - # container: alpine:latest - # use_sccache: false - # use_llvm: false - # build_wasm: true - - build: linux-musl-x64-v8 - os: ubuntu-latest - artifact_name: 'wasmer-v8-linux-musl-amd64' - container: alpine:latest + - build: linux-x64 + os: ubuntu-22.04 + artifact_name: 'wasmer-linux-amd64' + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' + cross_compilation_artifact_name: 'cross_compiled_from_linux' use_sccache: false - use_llvm: false + use_llvm: true build_wasm: true - - build: linux-musl-x64-wamr - os: ubuntu-latest - artifact_name: 'wasmer-wamr-linux-musl-amd64' - container: alpine:latest + - build: linux-x64-v8 + os: ubuntu-22.04 + artifact_name: 'wasmer-v8-linux-amd64' + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' + cross_compilation_artifact_name: 'cross_compiled_from_linux' use_sccache: false - use_llvm: false + use_llvm: true build_wasm: true - - build: linux-musl-x64-wasmi + - build: linux-x64-wamr + os: ubuntu-22.04 + artifact_name: 'wasmer-wamr-linux-amd64' + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' + cross_compilation_artifact_name: 'cross_compiled_from_linux' + use_sccache: false + use_llvm: true + build_wasm: true + - build: linux-x64-wasmi + os: ubuntu-22.04 + artifact_name: 'wasmer-wasmi-linux-amd64' + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' + cross_compilation_artifact_name: 'cross_compiled_from_linux' + use_sccache: false + use_llvm: true + build_wasm: true + - build: macos-x64 + os: macos-13 + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + artifact_name: 'wasmer-darwin-amd64' + cross_compilation_artifact_name: 'cross_compiled_from_mac' + use_sccache: false + use_llvm: true + build_wasm: false + - build: macos-x64-v8 + os: macos-13 + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + artifact_name: 'wasmer-v8-darwin-amd64' + cross_compilation_artifact_name: 'cross_compiled_from_mac' + use_sccache: false + use_llvm: true + build_wasm: false + - build: macos-x64-wamr + os: macos-13 + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + artifact_name: 'wasmer-wamr-darwin-amd64' + cross_compilation_artifact_name: 'cross_compiled_from_mac' + use_sccache: false + use_llvm: true + build_wasm: false + - build: macos-x64-wasmi + os: macos-13 + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + artifact_name: 'wasmer-wasmi-darwin-amd64' + cross_compilation_artifact_name: 'cross_compiled_from_mac' + use_sccache: false + use_llvm: true + build_wasm: false + - build: macos-arm64 + os: macos-14 + target: aarch64-apple-darwin + artifact_name: 'wasmer-darwin-arm64' + use_sccache: false + use_llvm: false + build_wasm: false + # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' + - build: macos-arm64-v8 + os: macos-14 + target: aarch64-apple-darwin + artifact_name: 'wasmer-v8-darwin-arm64' + use_sccache: false + use_llvm: false + build_wasm: false + # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' + - build: macos-arm64-wamr + os: macos-14 + target: aarch64-apple-darwin + artifact_name: 'wasmer-wamr-darwin-arm64' + use_sccache: false + use_llvm: false + build_wasm: false + # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' + - build: macos-arm64-wasmi + os: macos-14 + target: aarch64-apple-darwin + artifact_name: 'wasmer-wasmi-darwin-arm64' + use_sccache: false + use_llvm: false + build_wasm: false + # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' + - build: windows-x64 + os: windows-2019 + artifact_name: 'wasmer-windows-amd64' + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + cross_compilation_artifact_name: 'cross_compiled_from_win' + use_sccache: false + use_llvm: true + build_wasm: false + - build: windows-x64-v8 + os: windows-2022 + artifact_name: 'wasmer-v8-windows-amd64' + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + cross_compilation_artifact_name: 'cross_compiled_from_win' + use_sccache: false + use_llvm: true + build_wasm: false + - build: windows-x64-wamr + os: windows-2022 + artifact_name: 'wasmer-wamr-windows-amd64' + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + cross_compilation_artifact_name: 'cross_compiled_from_win' + use_sccache: false + use_llvm: true + build_wasm: false + - build: windows-x64-wasmi + os: windows-2022 + artifact_name: 'wasmer-wasmi-windows-amd64' + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + cross_compilation_artifact_name: 'cross_compiled_from_win' + use_sccache: false + use_llvm: true + build_wasm: false + - build: linux-musl-x64 os: ubuntu-latest - artifact_name: 'wasmer-wasmi-linux-musl-amd64' + artifact_name: 'wasmer-linux-musl-amd64' container: alpine:latest use_sccache: false use_llvm: false @@ -224,8 +203,6 @@ jobs: if: startsWith(matrix.build, 'linux-musl') run: | apk add mold cmake ninja bash curl make llvm18 llvm18-dev clang18 lld clang18-static - echo "LIBCLANG_STATIC_PATH=/usr/lib/llvm18/lib" >> $GITHUB_ENV - ls /usr/lib/llvm18/lib - name: Install `ninja` on macOS if: startsWith(matrix.build, 'macos-') shell: bash @@ -341,21 +318,21 @@ jobs: '${{ runner.tool_cache }}/cargo-sccache/bin/sccache' -s echo 'RUSTC_WRAPPER=${{ runner.tool_cache }}/cargo-sccache/bin/sccache' >> $GITHUB_ENV shell: bash - # - name: Build C API headless - # shell: bash - # run: | - # make package-capi-headless - # - name: Build C API - # shell: bash - # run: | - # make build-capi - # - name: Build Wasmer binary with LLVM - # if: matrix.use_llvm - # shell: bash - # run: | - # make build-wasmer - # env: - # ENABLE_LLVM: 1 + - name: Build C API headless + shell: bash + run: | + make package-capi-headless + - name: Build C API + shell: bash + run: | + make build-capi + - name: Build Wasmer binary with LLVM + if: matrix.use_llvm + shell: bash + run: | + make build-wasmer + env: + ENABLE_LLVM: 1 - name: Build Wasmer with v8 backend with mold if: ${{ endsWith(matrix.build, 'v8') && startsWith(matrix.build, 'linux-x64') }} run: | @@ -373,41 +350,41 @@ jobs: if: endsWith(matrix.build, 'wasmi') run: | make build-wasmer-wasmi - # - name: Build Wasmer binary without LLVM - # if: matrix.use_llvm != true - # shell: bash - # run: | - # make build-wasmer + - name: Build Wasmer binary without LLVM + if: matrix.use_llvm != true + shell: bash + run: | + make build-wasmer #- name: Build Wasmer binary on Wasm32-WASI without LLVM # if: matrix.build_wasm # shell: bash # run: | # make build-wasmer-wasm - # - name: Install Nightly Rust for Headless - # if: matrix.build != 'linux-musl-x64' - # uses: dtolnay/rust-toolchain@master - # with: - # toolchain: "nightly-2024-07-05" - # target: ${{ matrix.target }} - # components: "rust-src" - # - name: Build Minimal Wasmer Headless - # if: matrix.build != 'linux-musl-x64' - # run: | - # cargo install xargo - # echo "" >> Cargo.toml - # echo "[profile.release]" >> Cargo.toml - # echo "opt-level = 'z'" >> Cargo.toml - # echo "debug = false" >> Cargo.toml - # echo "debug-assertions = false" >> Cargo.toml - # echo "overflow-checks = false" >> Cargo.toml - # echo "lto = true" >> Cargo.toml - # echo "panic = 'abort'" >> Cargo.toml - # echo "incremental = false" >> Cargo.toml - # echo "codegen-units = 1" >> Cargo.toml - # echo "rpath = false" >> Cargo.toml - # rustup override set nightly-2024-07-05 - # make build-wasmer-headless-minimal - # rustup override unset + - name: Install Nightly Rust for Headless + if: matrix.build != 'linux-musl-x64' + uses: dtolnay/rust-toolchain@master + with: + toolchain: "nightly-2024-07-05" + target: ${{ matrix.target }} + components: "rust-src" + - name: Build Minimal Wasmer Headless + if: matrix.build != 'linux-musl-x64' + run: | + cargo install xargo + echo "" >> Cargo.toml + echo "[profile.release]" >> Cargo.toml + echo "opt-level = 'z'" >> Cargo.toml + echo "debug = false" >> Cargo.toml + echo "debug-assertions = false" >> Cargo.toml + echo "overflow-checks = false" >> Cargo.toml + echo "lto = true" >> Cargo.toml + echo "panic = 'abort'" >> Cargo.toml + echo "incremental = false" >> Cargo.toml + echo "codegen-units = 1" >> Cargo.toml + echo "rpath = false" >> Cargo.toml + rustup override set nightly-2024-07-05 + make build-wasmer-headless-minimal + rustup override unset - name: Dist run: | make distribution @@ -419,268 +396,267 @@ jobs: if-no-files-found: error retention-days: 2 - # windows_gnu: - # name: Windows GNU - # runs-on: ubuntu-latest - # steps: - # - uses: actions/checkout@v3 - # - name: Install Windows-GNU linker - # shell: bash - # run: | - # sudo apt install -y mingw-w64 - # - uses: dtolnay/rust-toolchain@stable - # with: - # target: x86_64-pc-windows-gnu - # - name: Install Windows-GNU target - # shell: bash - # run: | - # rustup target add x86_64-pc-windows-gnu - # - name: Install Windows 10 SDK with xwin - # shell: bash - # run: | - # mkdir -p /tmp/xwin - # mkdir -p /tmp/xwindownload - # mkdir -p /tmp/xwincache - # git clone https://github.com/wasmerio/xwin --depth=1 /tmp/xwin - # cargo build --release --manifest-path=/tmp/xwin/Cargo.toml - # /tmp/xwin/target/release/xwin --accept-license --cache-dir /tmp/xwincache splat --output /tmp/xwindownload - # mkdir -p /tmp/winsdk - # cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/WS2_32.lib /tmp/winsdk/ - # cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/KERNEL32.lib /tmp/winsdk/ - # cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/BCRYPT.lib /tmp/winsdk/ - # cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/ADVAPI32.lib /tmp/winsdk/ - # cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/USERENV.lib /tmp/winsdk/ - # echo "WinSDK files:" - # ls -laH /tmp/winsdk - # echo "" - # mkdir -p package - # mkdir -p package/winsdk - # cp -r /tmp/winsdk/* package/winsdk - # - name: Build Wasmer C-API without LLVM - # shell: bash - # run: | - # make build-capi - # env: - # RUSTFLAGS: -Cpanic=abort - # CARGO_TARGET: x86_64-pc-windows-gnu - # ENABLE_LLVM: 0 - # - name: Build Wasmer C-API headless without LLVM - # shell: bash - # run: | - # make build-capi-headless - # env: - # RUSTFLAGS: -Cpanic=abort - # CARGO_TARGET: x86_64-pc-windows-gnu - # ENABLE_LLVM: 0 - # - name: Dist - # run: | - # make distribution-gnu - # env: - # CARGO_TARGET: x86_64-pc-windows-gnu - # TARGET_DIR: target/x86_64-pc-windows-gnu/release - # - name: Upload Artifacts - # uses: actions/upload-artifact@v4 - # with: - # name: 'wasmer-windows-gnu64' - # path: dist - # if-no-files-found: error - # retention-days: 2 + windows_gnu: + name: Windows GNU + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + - name: Install Windows-GNU linker + shell: bash + run: | + sudo apt install -y mingw-w64 + - uses: dtolnay/rust-toolchain@stable + with: + target: x86_64-pc-windows-gnu + - name: Install Windows-GNU target + shell: bash + run: | + rustup target add x86_64-pc-windows-gnu + - name: Install Windows 10 SDK with xwin + shell: bash + run: | + mkdir -p /tmp/xwin + mkdir -p /tmp/xwindownload + mkdir -p /tmp/xwincache + git clone https://github.com/wasmerio/xwin --depth=1 /tmp/xwin + cargo build --release --manifest-path=/tmp/xwin/Cargo.toml + /tmp/xwin/target/release/xwin --accept-license --cache-dir /tmp/xwincache splat --output /tmp/xwindownload + mkdir -p /tmp/winsdk + cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/WS2_32.lib /tmp/winsdk/ + cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/KERNEL32.lib /tmp/winsdk/ + cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/BCRYPT.lib /tmp/winsdk/ + cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/ADVAPI32.lib /tmp/winsdk/ + cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/USERENV.lib /tmp/winsdk/ + echo "WinSDK files:" + ls -laH /tmp/winsdk + echo "" + mkdir -p package + mkdir -p package/winsdk + cp -r /tmp/winsdk/* package/winsdk + - name: Build Wasmer C-API without LLVM + shell: bash + run: | + make build-capi + env: + RUSTFLAGS: -Cpanic=abort + CARGO_TARGET: x86_64-pc-windows-gnu + ENABLE_LLVM: 0 + - name: Build Wasmer C-API headless without LLVM + shell: bash + run: | + make build-capi-headless + env: + RUSTFLAGS: -Cpanic=abort + CARGO_TARGET: x86_64-pc-windows-gnu + ENABLE_LLVM: 0 + - name: Dist + run: | + make distribution-gnu + env: + CARGO_TARGET: x86_64-pc-windows-gnu + TARGET_DIR: target/x86_64-pc-windows-gnu/release + - name: Upload Artifacts + uses: actions/upload-artifact@v4 + with: + name: 'wasmer-windows-gnu64' + path: dist + if-no-files-found: error + retention-days: 2 - # darwin_aarch64_jsc: - # name: macOS aarch64 (JSC) - # runs-on: macos-12 - # steps: - # - uses: actions/checkout@v3 - # - uses: dtolnay/rust-toolchain@stable - # with: - # target: aarch64-apple-darwin - # - name: Install Darwin-aarch64 target - # shell: bash - # run: | - # rustup target add aarch64-apple-darwin - # - name: Build Wasmer C-API (JSC) - # shell: bash - # run: | - # make build-capi-jsc - # env: - # RUSTFLAGS: -Cpanic=abort - # CARGO_TARGET: aarch64-apple-darwin - # - name: Dist - # run: | - # make distribution - # env: - # CARGO_TARGET: aarch64-apple-darwin - # TARGET_DIR: target/aarch64-apple-darwin/release - # - name: Upload Artifacts - # uses: actions/upload-artifact@v4 - # with: - # name: 'aarch64-apple-darwin-jsc' - # path: dist - # if-no-files-found: error - # retention-days: 2 + darwin_aarch64_jsc: + name: macOS aarch64 (JSC) + runs-on: macos-12 + steps: + - uses: actions/checkout@v3 + - uses: dtolnay/rust-toolchain@stable + with: + target: aarch64-apple-darwin + - name: Install Darwin-aarch64 target + shell: bash + run: | + rustup target add aarch64-apple-darwin + - name: Build Wasmer C-API (JSC) + shell: bash + run: | + make build-capi-jsc + env: + RUSTFLAGS: -Cpanic=abort + CARGO_TARGET: aarch64-apple-darwin + - name: Dist + run: | + make distribution + env: + CARGO_TARGET: aarch64-apple-darwin + TARGET_DIR: target/aarch64-apple-darwin/release + - name: Upload Artifacts + uses: actions/upload-artifact@v4 + with: + name: 'aarch64-apple-darwin-jsc' + path: dist + if-no-files-found: error + retention-days: 2 - # darwin_x86_64_jsc: - # name: macOS x86_64 (JSC) - # runs-on: macos-12 - # steps: - # - uses: actions/checkout@v3 - # - uses: dtolnay/rust-toolchain@stable - # with: - # target: x86_64-apple-darwin - # - name: Build Wasmer C-API (JSC) - # shell: bash - # run: | - # make build-capi-jsc - # env: - # RUSTFLAGS: -Cpanic=abort - # CARGO_TARGET: x86_64-apple-darwin - # - name: Dist - # run: | - # make distribution - # env: - # CARGO_TARGET: x86_64-apple-darwin - # TARGET_DIR: target/x86_64-apple-darwin/release - # - name: Upload Artifacts - # uses: actions/upload-artifact@v4 - # with: - # name: 'x86_64-apple-darwin-jsc' - # path: dist - # if-no-files-found: error - # retention-days: 2 + darwin_x86_64_jsc: + name: macOS x86_64 (JSC) + runs-on: macos-12 + steps: + - uses: actions/checkout@v3 + - uses: dtolnay/rust-toolchain@stable + with: + target: x86_64-apple-darwin + - name: Build Wasmer C-API (JSC) + shell: bash + run: | + make build-capi-jsc + env: + RUSTFLAGS: -Cpanic=abort + CARGO_TARGET: x86_64-apple-darwin + - name: Dist + run: | + make distribution + env: + CARGO_TARGET: x86_64-apple-darwin + TARGET_DIR: target/x86_64-apple-darwin/release + - name: Upload Artifacts + uses: actions/upload-artifact@v4 + with: + name: 'x86_64-apple-darwin-jsc' + path: dist + if-no-files-found: error + retention-days: 2 - # linux_aarch64: - # name: Linux aarch64 - # runs-on: ubuntu-latest - # steps: - # - uses: actions/checkout@v3 - # - uses: dtolnay/rust-toolchain@stable - # with: - # target: aarch64-unknown-linux-gnu - # - name: Build cross image - # run: | - # docker build -t wasmer/aarch64 ${GITHUB_WORKSPACE}/.github/cross-linux-aarch64/ - # env: - # CROSS_DOCKER_IN_DOCKER: true - # - name: Build Wasmer binary - # run: | - # make build-wasmer - # env: - # CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross - # CROSS_DOCKER_IN_DOCKER: true - # CARGO_TARGET: aarch64-unknown-linux-gnu - # PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig - # PKG_CONFIG_ALLOW_CROSS: true - # ENABLE_LLVM: 0 - # - name: Build C API headless - # shell: bash - # run: | - # make package-capi-headless - # env: - # CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross - # CROSS_DOCKER_IN_DOCKER: true - # CARGO_TARGET: aarch64-unknown-linux-gnu - # PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig - # PKG_CONFIG_ALLOW_CROSS: true - # ENABLE_LLVM: 0 - # TARGET: aarch64-unknown-linux-gnu - # TARGET_DIR: target/aarch64-unknown-linux-gnu/release - # - name: Build C API - # run: | - # make build-capi - # env: - # CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross - # CROSS_DOCKER_IN_DOCKER: true - # CARGO_TARGET: aarch64-unknown-linux-gnu - # PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig - # PKG_CONFIG_ALLOW_CROSS: true - # ENABLE_LLVM: 0 - # - name: Dist - # run: | - # make distribution - # env: - # CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross - # CROSS_DOCKER_IN_DOCKER: true - # CARGO_TARGET: aarch64-unknown-linux-gnu - # PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig - # PKG_CONFIG_ALLOW_CROSS: true - # TARGET: aarch64-unknown-linux-gnu - # TARGET_DIR: target/aarch64-unknown-linux-gnu/release - # - name: Upload Artifacts - # uses: actions/upload-artifact@v4 - # with: - # name: wasmer-linux-aarch64 - # path: dist - # if-no-files-found: error - # retention-days: 2 + linux_aarch64: + name: Linux aarch64 + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + - uses: dtolnay/rust-toolchain@stable + with: + target: aarch64-unknown-linux-gnu + - name: Build cross image + run: | + docker build -t wasmer/aarch64 ${GITHUB_WORKSPACE}/.github/cross-linux-aarch64/ + env: + CROSS_DOCKER_IN_DOCKER: true + - name: Build Wasmer binary + run: | + make build-wasmer + env: + CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross + CROSS_DOCKER_IN_DOCKER: true + CARGO_TARGET: aarch64-unknown-linux-gnu + PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig + PKG_CONFIG_ALLOW_CROSS: true + ENABLE_LLVM: 0 + - name: Build C API headless + shell: bash + run: | + make package-capi-headless + env: + CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross + CROSS_DOCKER_IN_DOCKER: true + CARGO_TARGET: aarch64-unknown-linux-gnu + PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig + PKG_CONFIG_ALLOW_CROSS: true + ENABLE_LLVM: 0 + TARGET: aarch64-unknown-linux-gnu + TARGET_DIR: target/aarch64-unknown-linux-gnu/release + - name: Build C API + run: | + make build-capi + env: + CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross + CROSS_DOCKER_IN_DOCKER: true + CARGO_TARGET: aarch64-unknown-linux-gnu + PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig + PKG_CONFIG_ALLOW_CROSS: true + ENABLE_LLVM: 0 + - name: Dist + run: | + make distribution + env: + CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross + CROSS_DOCKER_IN_DOCKER: true + CARGO_TARGET: aarch64-unknown-linux-gnu + PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig + PKG_CONFIG_ALLOW_CROSS: true + TARGET: aarch64-unknown-linux-gnu + TARGET_DIR: target/aarch64-unknown-linux-gnu/release + - name: Upload Artifacts + uses: actions/upload-artifact@v4 + with: + name: wasmer-linux-aarch64 + path: dist + if-no-files-found: error + retention-days: 2 - # linux_riscv64: - # name: Linux riscv64 - # runs-on: ubuntu-latest - # steps: - # - uses: actions/checkout@v3 - # - uses: dtolnay/rust-toolchain@stable - # with: - # target: riscv64gc-unknown-linux-gnu - # - name: Build cross image - # run: | - # docker build -t wasmer/riscv64 ${GITHUB_WORKSPACE}/.github/cross-linux-riscv64/ - # env: - # CROSS_DOCKER_IN_DOCKER: true - # - name: Build Wasmer binary - # run: | - # make build-wasmer - # env: - # CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64:latest cargo - # CROSS_DOCKER_IN_DOCKER: true - # CARGO_TARGET: riscv64gc-unknown-linux-gnu - # PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig - # PKG_CONFIG_ALLOW_CROSS: true - # ENABLE_LLVM: 0 - # - name: Build C API headless - # shell: bash - # run: | - # make package-capi-headless - # env: - # CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64:latest cargo - # CROSS_DOCKER_IN_DOCKER: true - # CARGO_TARGET: riscv64gc-unknown-linux-gnu - # PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig - # PKG_CONFIG_ALLOW_CROSS: true - # ENABLE_LLVM: 0 - # TARGET: riscv64gc-unknown-linux-gnu - # TARGET_DIR: target/riscv64gc-unknown-linux-gnu/release - # - name: Build C API - # run: | - # make build-capi - # env: - # CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64:latest cargo - # CROSS_DOCKER_IN_DOCKER: true - # CARGO_TARGET: riscv64gc-unknown-linux-gnu - # PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig - # PKG_CONFIG_ALLOW_CROSS: true - # ENABLE_LLVM: 0 - # - name: Dist - # run: | - # make distribution - # env: - # CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64:latest cargo - # CROSS_DOCKER_IN_DOCKER: true - # CARGO_TARGET: riscv64gc-unknown-linux-gnu - # PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig - # PKG_CONFIG_ALLOW_CROSS: true - # TARGET: riscv64gc-unknown-linux-gnu - # TARGET_DIR: target/riscv64gc-unknown-linux-gnu/release - # - name: Upload Artifacts - # uses: actions/upload-artifact@v4 - # with: - # name: wasmer-linux-riscv64 - # path: dist - # if-no-files-found: error - # retention-days: 2 + linux_riscv64: + name: Linux riscv64 + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + - uses: dtolnay/rust-toolchain@stable + with: + target: riscv64gc-unknown-linux-gnu + - name: Build cross image + run: | + docker build -t wasmer/riscv64 ${GITHUB_WORKSPACE}/.github/cross-linux-riscv64/ + env: + CROSS_DOCKER_IN_DOCKER: true + - name: Build Wasmer binary + run: | + make build-wasmer + env: + CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64:latest cargo + CROSS_DOCKER_IN_DOCKER: true + CARGO_TARGET: riscv64gc-unknown-linux-gnu + PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig + PKG_CONFIG_ALLOW_CROSS: true + ENABLE_LLVM: 0 + - name: Build C API headless + shell: bash + run: | + make package-capi-headless + env: + CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64:latest cargo + CROSS_DOCKER_IN_DOCKER: true + CARGO_TARGET: riscv64gc-unknown-linux-gnu + PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig + PKG_CONFIG_ALLOW_CROSS: true + ENABLE_LLVM: 0 + TARGET: riscv64gc-unknown-linux-gnu + TARGET_DIR: target/riscv64gc-unknown-linux-gnu/release + - name: Build C API + run: | + make build-capi + env: + CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64:latest cargo + CROSS_DOCKER_IN_DOCKER: true + CARGO_TARGET: riscv64gc-unknown-linux-gnu + PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig + PKG_CONFIG_ALLOW_CROSS: true + ENABLE_LLVM: 0 + - name: Dist + run: | + make distribution + env: + CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64:latest cargo + CROSS_DOCKER_IN_DOCKER: true + CARGO_TARGET: riscv64gc-unknown-linux-gnu + PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig + PKG_CONFIG_ALLOW_CROSS: true + TARGET: riscv64gc-unknown-linux-gnu + TARGET_DIR: target/riscv64gc-unknown-linux-gnu/release + - name: Upload Artifacts + uses: actions/upload-artifact@v4 + with: + name: wasmer-linux-riscv64 + path: dist + if-no-files-found: error + retention-days: 2 release: - # needs: [setup, build, linux_aarch64, windows_gnu, linux_riscv64] - needs: [setup, build] + needs: [setup, build, linux_aarch64, windows_gnu, linux_riscv64] runs-on: ubuntu-latest if: needs.setup.outputs.DOING_RELEASE == '1' || github.event.inputs.release != '' steps: @@ -716,7 +692,7 @@ jobs: asset_path: artifacts/wasmer-windows-amd64/wasmer.tar.gz asset_name: wasmer-windows-amd64.tar.gz asset_content_type: application/gzip - - name: Upload Release Asset Windows v8 + - name: Upload Release Asset Windows With v8 uses: actions/upload-release-asset@v1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} @@ -725,7 +701,7 @@ jobs: asset_path: artifacts/wasmer-v8-windows-amd64/wasmer.tar.gz asset_name: wasmer-v8-windows-amd64.tar.gz asset_content_type: application/gzip - - name: Upload Release Asset Windows wamr + - name: Upload Release Asset Windows With wamr uses: actions/upload-release-asset@v1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} @@ -734,7 +710,7 @@ jobs: asset_path: artifacts/wasmer-wamr-windows-amd64/wasmer.tar.gz asset_name: wasmer-wamr-windows-amd64.tar.gz asset_content_type: application/gzip - - name: Upload Release Asset Windows wasmi + - name: Upload Release Asset Windows With wasmi uses: actions/upload-release-asset@v1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} @@ -752,7 +728,7 @@ jobs: asset_path: artifacts/wasmer-linux-amd64/wasmer.tar.gz asset_name: wasmer-linux-amd64.tar.gz asset_content_type: application/gzip - - name: Upload Release Asset v8 Linux amd64 + - name: Upload Release Asset Linux amd64 With v8 uses: actions/upload-release-asset@v1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} @@ -761,7 +737,7 @@ jobs: asset_path: artifacts/wasmer-v8-linux-amd64/wasmer.tar.gz asset_name: wasmer-v8-linux-amd64.tar.gz asset_content_type: application/gzip - - name: Upload Release Asset wamr Linux amd64 + - name: Upload Release Asset Linux amd64 With wamr uses: actions/upload-release-asset@v1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} @@ -770,7 +746,7 @@ jobs: asset_path: artifacts/wasmer-wamr-linux-amd64/wasmer.tar.gz asset_name: wasmer-wamr-linux-amd64.tar.gz asset_content_type: application/gzip - - name: Upload Release Asset wasmi Linux amd64 + - name: Upload Release Asset Linux amd64 with wasmi uses: actions/upload-release-asset@v1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} @@ -816,36 +792,6 @@ jobs: asset_path: artifacts/wasmer-linux-musl-amd64/wasmer.tar.gz asset_name: wasmer-linux-musl-amd64.tar.gz asset_content_type: application/gzip - - name: Upload Release Asset Linux amd64 (musl) v8 - id: upload-release-asset-linux-musl-amd64-v8 - uses: actions/upload-release-asset@v1 - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - with: - upload_url: ${{ steps.create_release.outputs.upload_url }} - asset_path: artifacts/wasmer-v8-linux-musl-amd64/wasmer.tar.gz - asset_name: wasmer-v8-linux-musl-amd64.tar.gz - asset_content_type: application/gzip - - name: Upload Release Asset Linux amd64 (musl) wamr - id: upload-release-asset-linux-musl-amd64-wamr - uses: actions/upload-release-asset@v1 - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - with: - upload_url: ${{ steps.create_release.outputs.upload_url }} - asset_path: artifacts/wasmer-wamr-linux-musl-amd64/wasmer.tar.gz - asset_name: wasmer-wamr-linux-musl-amd64.tar.gz - asset_content_type: application/gzip - - name: Upload Release Asset Linux amd64 (musl) wasmi - id: upload-release-asset-linux-musl-amd64-wasmi - uses: actions/upload-release-asset@v1 - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - with: - upload_url: ${{ steps.create_release.outputs.upload_url }} - asset_path: artifacts/wasmer-wasmi-linux-musl-amd64/wasmer.tar.gz - asset_name: wasmer-wasmi-linux-musl-amd64.tar.gz - asset_content_type: application/gzip - name: Upload Release Asset Mac amd64 uses: actions/upload-release-asset@v1 env: @@ -855,7 +801,7 @@ jobs: asset_path: artifacts/wasmer-darwin-amd64/wasmer.tar.gz asset_name: wasmer-darwin-amd64.tar.gz asset_content_type: application/gzip - - name: Upload Release Asset Mac amd64 v8 + - name: Upload Release Asset Mac amd64 With v8 uses: actions/upload-release-asset@v1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} @@ -864,7 +810,7 @@ jobs: asset_path: artifacts/wasmer-v8-darwin-amd64/wasmer.tar.gz asset_name: wasmer-v8-darwin-amd64.tar.gz asset_content_type: application/gzip - - name: Upload Release Asset Mac amd64 wamr + - name: Upload Release Asset Mac amd64 With wamr uses: actions/upload-release-asset@v1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} @@ -873,7 +819,7 @@ jobs: asset_path: artifacts/wasmer-wamr-darwin-amd64/wasmer.tar.gz asset_name: wasmer-wamr-darwin-amd64.tar.gz asset_content_type: application/gzip - - name: Upload Release Asset Mac amd64 wasmi + - name: Upload Release Asset Mac amd64 With wasmi uses: actions/upload-release-asset@v1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} @@ -891,7 +837,7 @@ jobs: asset_path: artifacts/wasmer-darwin-arm64/wasmer.tar.gz asset_name: wasmer-darwin-arm64.tar.gz asset_content_type: application/gzip - - name: Upload Release Asset Mac arm64 v8 + - name: Upload Release Asset Mac arm64 With v8 uses: actions/upload-release-asset@v1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} @@ -900,7 +846,7 @@ jobs: asset_path: artifacts/wasmer-v8-darwin-arm64/wasmer.tar.gz asset_name: wasmer-v8-darwin-arm64.tar.gz asset_content_type: application/gzip - - name: Upload Release Asset Mac arm64 wamr + - name: Upload Release Asset Mac arm64 With wamr uses: actions/upload-release-asset@v1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} @@ -909,7 +855,7 @@ jobs: asset_path: artifacts/wasmer-wamr-darwin-arm64/wasmer.tar.gz asset_name: wasmer-wamr-darwin-arm64.tar.gz asset_content_type: application/gzip - - name: Upload Release Asset Mac arm64 wasmi + - name: Upload Release Asset Mac arm64 With wasmi uses: actions/upload-release-asset@v1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} From d29ae0f8d6466359559e1e4f3acc26042204236c Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 19:02:26 +0330 Subject: [PATCH 47/59] fix for windows --- .github/workflows/build.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 2047f964de0..fa78c27d018 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -249,7 +249,7 @@ jobs: LLVM_DIR: .llvm - name: Configure LLVM (Windows) # The Custom Windows build does not contains llvm-config.exe, so need to setup manualy here - if: matrix.build == 'windows-x64' && matrix.llvm_url + if: startsWith(matrix.build, 'windows-x64') && matrix.llvm_url shell: bash run: | LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} From e5e0e109c63bc741a0e02ab90ce176cfc5f2b4bb Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Fri, 18 Oct 2024 19:40:41 +0330 Subject: [PATCH 48/59] fix windows version --- .github/workflows/build.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index fa78c27d018..9e2edfd7ab0 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -147,7 +147,7 @@ jobs: # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' - build: windows-x64 - os: windows-2019 + os: windows-2022 artifact_name: 'wasmer-windows-amd64' llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' cross_compilation_artifact_name: 'cross_compiled_from_win' From 6b25ea21af29ffe071b460c2a7d05e2ac9adc05a Mon Sep 17 00:00:00 2001 From: Yage Hu Date: Fri, 18 Oct 2024 16:24:38 -0400 Subject: [PATCH 49/59] path_create_directory shouldn't behave recursively This commit fixes a non-compatible (with other runtimes, intention of WASI, and POSIX) behavior in `path_create_directory` WASI implementation. Instead of creating directories recursively, the function fails if any intermediate component does not exist. fixes #5157 Signed-off-by: Yage Hu --- lib/wasix/src/syscalls/wasi/path_create_directory.rs | 6 +++++- tests/wasi-fyi/fs_create_dir-non_existent.rs | 5 +++++ .../test_fs/fyi/fs_create_dir-non_existent.rs/.ignore | 0 3 files changed, 10 insertions(+), 1 deletion(-) create mode 100644 tests/wasi-fyi/fs_create_dir-non_existent.rs create mode 100644 tests/wasi-fyi/test_fs/fyi/fs_create_dir-non_existent.rs/.ignore diff --git a/lib/wasix/src/syscalls/wasi/path_create_directory.rs b/lib/wasix/src/syscalls/wasi/path_create_directory.rs index 99944f7992c..fe07a65b40a 100644 --- a/lib/wasix/src/syscalls/wasi/path_create_directory.rs +++ b/lib/wasix/src/syscalls/wasi/path_create_directory.rs @@ -82,7 +82,7 @@ pub(crate) fn path_create_directory_internal( let mut cur_dir_inode = working_dir.inode; let mut created_directory = false; - for comp in &path_vec { + for (comp_idx, comp) in path_vec.iter().enumerate() { let processing_cur_dir_inode = cur_dir_inode.clone(); let mut guard = processing_cur_dir_inode.write(); match guard.deref_mut() { @@ -122,6 +122,10 @@ pub(crate) fn path_create_directory_internal( return Err(Errno::Notdir); } } else { + if comp_idx != path_vec.len() - 1 { + return Err(Errno::Noent); + } + created_directory = true; state.fs_create_dir(&adjusted_path)?; } diff --git a/tests/wasi-fyi/fs_create_dir-non_existent.rs b/tests/wasi-fyi/fs_create_dir-non_existent.rs new file mode 100644 index 00000000000..278c96909a6 --- /dev/null +++ b/tests/wasi-fyi/fs_create_dir-non_existent.rs @@ -0,0 +1,5 @@ +use std::fs; + +fn main() { + assert!(fs::create_dir("/fyi/fs_create_dir-non_existent.dir/not-exist/new-directory").is_err()); +} diff --git a/tests/wasi-fyi/test_fs/fyi/fs_create_dir-non_existent.rs/.ignore b/tests/wasi-fyi/test_fs/fyi/fs_create_dir-non_existent.rs/.ignore new file mode 100644 index 00000000000..e69de29bb2d From 5115ce04551c35da9f6dd25d82bfc3772ebf3ce3 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Mon, 21 Oct 2024 12:31:26 +0330 Subject: [PATCH 50/59] re-enable other workflows --- .github/workflows/build.yml | 3 - .github/workflows/test.yaml | 2176 ++++++++--------- .github/workflows/wasmer-config.yaml | 98 +- .../workflows/wasmer-integration-tests.yaml | 98 +- 4 files changed, 1186 insertions(+), 1189 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 9e2edfd7ab0..523846c70d4 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -12,9 +12,6 @@ on: tags: # this is _not_ a regex, see: https://docs.github.com/en/actions/reference/workflow-syntax-for-github-actions#filter-pattern-cheat-sheet - '[0-9]+.[0-9]+.[0-9]+*' - pull_request: # TODO: MUST BE REMOVED! ONLY FOR TESTING - branches: - - 'main' # Run jobs on PRs targeting the 'main' branch workflow_dispatch: inputs: release: diff --git a/.github/workflows/test.yaml b/.github/workflows/test.yaml index 7ea3b591c00..ddffe58f499 100644 --- a/.github/workflows/test.yaml +++ b/.github/workflows/test.yaml @@ -1,1135 +1,1135 @@ -# name: test-sys +name: test-sys -# on: -# push: -# branches: -# - main -# - 'with-ci-.*' -# - 'v3.0.x' -# - 'v3.1.x' -# pull_request: -# workflow_dispatch: -# inputs: -# release: -# description: 'Make release' +on: + push: + branches: + - main + - 'with-ci-.*' + - 'v3.0.x' + - 'v3.1.x' + pull_request: + workflow_dispatch: + inputs: + release: + description: 'Make release' -# # Automatically cancel previous workflow runs when a new commit is pushed. -# concurrency: -# group: ${{ github.workflow }}-${{ github.ref }} -# cancel-in-progress: true +# Automatically cancel previous workflow runs when a new commit is pushed. +concurrency: + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true -# env: -# RUST_BACKTRACE: 1 -# # Sparse will be enabled by dtolnay/rust-toolchain when installing nightly -# # Rust, but it's not stable on 1.69 yet. By explicitly setting the protocol we -# # can override that behaviour -# CARGO_REGISTRIES_CRATES_IO_PROTOCOL: git -# MSRV: "1.81" -# NEXTEST_PROFILE: "ci" -# RUSTUP_WINDOWS_PATH_ADD_BIN: 1 -# WASI_SDK_VERSION: "22" +env: + RUST_BACKTRACE: 1 + # Sparse will be enabled by dtolnay/rust-toolchain when installing nightly + # Rust, but it's not stable on 1.69 yet. By explicitly setting the protocol we + # can override that behaviour + CARGO_REGISTRIES_CRATES_IO_PROTOCOL: git + MSRV: "1.81" + NEXTEST_PROFILE: "ci" + RUSTUP_WINDOWS_PATH_ADD_BIN: 1 + WASI_SDK_VERSION: "22" -# jobs: -# setup: -# name: Set up -# runs-on: ubuntu-22.04 -# outputs: -# VERSION: ${{ steps.setup.outputs.VERSION }} -# DOING_RELEASE: ${{ steps.setup.outputs.DOING_RELEASE }} -# steps: -# - name: Set up env vars -# id: setup -# shell: bash -# run: | -# VERSION=${GITHUB_REF/refs\/tags\//} -# echo "VERSION=${VERSION}" >> $GITHUB_OUTPUT -# DOING_RELEASE=$(echo $VERSION | grep -c '^[0-9]\+\.[0-9]\+\.[0-9]\+\(-\([a-zA-Z]\+\)\?[0-9]*\)\?$' || true) -# echo "DOING_RELEASE=${DOING_RELEASE}" >> $GITHUB_OUTPUT -# echo $VERSION -# echo $DOING_RELEASE +jobs: + setup: + name: Set up + runs-on: ubuntu-22.04 + outputs: + VERSION: ${{ steps.setup.outputs.VERSION }} + DOING_RELEASE: ${{ steps.setup.outputs.DOING_RELEASE }} + steps: + - name: Set up env vars + id: setup + shell: bash + run: | + VERSION=${GITHUB_REF/refs\/tags\//} + echo "VERSION=${VERSION}" >> $GITHUB_OUTPUT + DOING_RELEASE=$(echo $VERSION | grep -c '^[0-9]\+\.[0-9]\+\.[0-9]\+\(-\([a-zA-Z]\+\)\?[0-9]*\)\?$' || true) + echo "DOING_RELEASE=${DOING_RELEASE}" >> $GITHUB_OUTPUT + echo $VERSION + echo $DOING_RELEASE -# lint: -# name: Code lint -# runs-on: ubuntu-22.04 -# steps: -# - uses: actions/checkout@v3 -# - name: Install Rust -# uses: dtolnay/rust-toolchain@stable -# with: -# toolchain: ${{ env.MSRV }} -# components: rustfmt, clippy -# - name: Install libtinfo -# shell: bash -# run: | -# sudo apt install -y libtinfo5 -# - name: Install LLVM (Linux) -# run: | -# curl --proto '=https' --tlsv1.2 -sSf https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz -L -o /opt/llvm.tar.xz -# mkdir -p /opt/llvm-18 -# tar xf /opt/llvm.tar.xz --strip-components=1 -C /opt/llvm-18 -# echo '/opt/llvm-18/bin' >> $GITHUB_PATH -# echo 'LLVM_SYS_180_PREFIX=/opt/llvm-18' >> $GITHUB_ENV -# - name: Cache -# uses: whywaita/actions-cache-s3@v2 -# with: -# path: | -# ~/.cargo/* -# ./target/* -# key: r22-${{ github.repository }}-${{ runner.os }}-${{ hashFiles('Cargo.lock') }}-wasmer-make-lint-linux-x64 -# aws-s3-bucket: wasmer-rust-artifacts-cache -# aws-access-key-id: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_TOKEN }} -# aws-secret-access-key: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_KEY }} -# aws-region: auto -# aws-endpoint: https://1541b1e8a3fc6ad155ce67ef38899700.r2.cloudflarestorage.com -# aws-s3-bucket-endpoint: false -# aws-s3-force-path-style: true -# - run: make lint -# env: -# ENABLE_CRANELIFT: "1" -# ENABLE_LLVM: "1" -# ENABLE_SINGLEPASS: "1" -# - name: Assert no files have changed -# run: | -# git status -# ! [[ $(git status -s) ]] + lint: + name: Code lint + runs-on: ubuntu-22.04 + steps: + - uses: actions/checkout@v3 + - name: Install Rust + uses: dtolnay/rust-toolchain@stable + with: + toolchain: ${{ env.MSRV }} + components: rustfmt, clippy + - name: Install libtinfo + shell: bash + run: | + sudo apt install -y libtinfo5 + - name: Install LLVM (Linux) + run: | + curl --proto '=https' --tlsv1.2 -sSf https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz -L -o /opt/llvm.tar.xz + mkdir -p /opt/llvm-18 + tar xf /opt/llvm.tar.xz --strip-components=1 -C /opt/llvm-18 + echo '/opt/llvm-18/bin' >> $GITHUB_PATH + echo 'LLVM_SYS_180_PREFIX=/opt/llvm-18' >> $GITHUB_ENV + - name: Cache + uses: whywaita/actions-cache-s3@v2 + with: + path: | + ~/.cargo/* + ./target/* + key: r22-${{ github.repository }}-${{ runner.os }}-${{ hashFiles('Cargo.lock') }}-wasmer-make-lint-linux-x64 + aws-s3-bucket: wasmer-rust-artifacts-cache + aws-access-key-id: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_TOKEN }} + aws-secret-access-key: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_KEY }} + aws-region: auto + aws-endpoint: https://1541b1e8a3fc6ad155ce67ef38899700.r2.cloudflarestorage.com + aws-s3-bucket-endpoint: false + aws-s3-force-path-style: true + - run: make lint + env: + ENABLE_CRANELIFT: "1" + ENABLE_LLVM: "1" + ENABLE_SINGLEPASS: "1" + - name: Assert no files have changed + run: | + git status + ! [[ $(git status -s) ]] -# cargo_deny: -# name: cargo-deny -# runs-on: ubuntu-22.04 -# steps: -# - uses: actions/checkout@v3 -# - uses: EmbarkStudios/cargo-deny-action@v1 -# with: -# log-level: error + cargo_deny: + name: cargo-deny + runs-on: ubuntu-22.04 + steps: + - uses: actions/checkout@v3 + - uses: EmbarkStudios/cargo-deny-action@v1 + with: + log-level: error -# test_nodejs: -# name: Test on NodeJS -# runs-on: ubuntu-22.04 -# steps: -# - uses: actions/checkout@v3 -# - name: Install Rust -# uses: dtolnay/rust-toolchain@stable -# with: -# toolchain: ${{ env.MSRV }} -# - name: Install NodeJS -# uses: actions/setup-node@v2 -# with: -# node-version: 16 -# - name: Install wasm-pack -# run: | -# curl https://rustwasm.github.io/wasm-pack/installer/init.sh -sSf | sh -# - name: make test-js -# run: | -# make test-js + test_nodejs: + name: Test on NodeJS + runs-on: ubuntu-22.04 + steps: + - uses: actions/checkout@v3 + - name: Install Rust + uses: dtolnay/rust-toolchain@stable + with: + toolchain: ${{ env.MSRV }} + - name: Install NodeJS + uses: actions/setup-node@v2 + with: + node-version: 16 + - name: Install wasm-pack + run: | + curl https://rustwasm.github.io/wasm-pack/installer/init.sh -sSf | sh + - name: make test-js + run: | + make test-js -# test_wasi_fyi: -# name: Test wasi-fyi -# runs-on: ubuntu-22.04 -# steps: -# - uses: actions/checkout@v3 -# - name: Install Rust -# uses: dtolnay/rust-toolchain@stable -# with: -# toolchain: nightly -# targets: "wasm32-wasi" -# - name: Install wasm-pack -# run: | -# curl https://rustwasm.github.io/wasm-pack/installer/init.sh -sSf | sh -# - name: Install LLVM 18 -# run: | -# curl --proto '=https' --tlsv1.2 -sSf https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz -L -o llvm.tar.xz -# LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} -# mkdir ${LLVM_DIR} -# tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} -# echo "ENABLE_LLVM=1" >> $GITHUB_ENV -# echo "${LLVM_DIR}/bin" >> $GITHUB_PATH -# echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH -# echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV -# env: -# LLVM_DIR: .llvm -# - name: make test-wasi-fyi -# run: | -# make test-wasi-fyi + test_wasi_fyi: + name: Test wasi-fyi + runs-on: ubuntu-22.04 + steps: + - uses: actions/checkout@v3 + - name: Install Rust + uses: dtolnay/rust-toolchain@stable + with: + toolchain: nightly + targets: "wasm32-wasi" + - name: Install wasm-pack + run: | + curl https://rustwasm.github.io/wasm-pack/installer/init.sh -sSf | sh + - name: Install LLVM 18 + run: | + curl --proto '=https' --tlsv1.2 -sSf https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz -L -o llvm.tar.xz + LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} + mkdir ${LLVM_DIR} + tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} + echo "ENABLE_LLVM=1" >> $GITHUB_ENV + echo "${LLVM_DIR}/bin" >> $GITHUB_PATH + echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH + echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV + env: + LLVM_DIR: .llvm + - name: make test-wasi-fyi + run: | + make test-wasi-fyi -# # The no_std functionality doesn't work at the moment - no point in testing it. -# # - name: make test-js-core -# # run: | -# # make test-js-core + # The no_std functionality doesn't work at the moment - no point in testing it. + # - name: make test-js-core + # run: | + # make test-js-core -# test_wasix: -# name: Test WASIX -# runs-on: ubuntu-22.04 -# steps: -# - uses: actions/checkout@v3 -# - name: Install Rust -# uses: dtolnay/rust-toolchain@stable -# with: -# toolchain: ${{ env.MSRV }} -# - name: Install Tools -# run: | -# sudo apt-get update -# sudo apt-get install -y git llvm clang make lld curl -# - name: Build wasix sysroot -# run: | -# cd ~ -# git clone --recurse-submodules https://github.com/wasix-org/wasix-libc -# cd wasix-libc -# ./build32.sh -# rm -rf /opt/wasix-sysroot -# cp -r sysroot32 ~/wasix-sysroot -# - name: Install wasi-sdk Tools -# run: | -# cd ~ -# curl -L "https://github.com/WebAssembly/wasi-sdk/releases/download/wasi-sdk-${{ env.WASI_SDK_VERSION }}/wasi-sdk-${{ env.WASI_SDK_VERSION }}.0-linux.tar.gz" -o wasi-sdk.tar.gz -# tar -xzf wasi-sdk.tar.gz -# cp -r wasi-sdk-${{ env.WASI_SDK_VERSION }}.0 ~/wasi-sdk -# - name: Install LLVM 18 -# run: | -# curl --proto '=https' --tlsv1.2 -sSf https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz -L -o llvm.tar.xz -# LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} -# mkdir ${LLVM_DIR} -# tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} -# echo "ENABLE_LLVM=1" >> $GITHUB_ENV -# echo "${LLVM_DIR}/bin" >> $GITHUB_PATH -# echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH -# echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV -# env: -# LLVM_DIR: .llvm -# - name: Install wasm-opt -# run: | -# sudo apt-get install -y binaryen -# - name: make test-wasix -# run: | -# WASI_SDK=~/wasi-sdk WASIX_SYSROOT=~/wasix-sysroot make test-wasix + test_wasix: + name: Test WASIX + runs-on: ubuntu-22.04 + steps: + - uses: actions/checkout@v3 + - name: Install Rust + uses: dtolnay/rust-toolchain@stable + with: + toolchain: ${{ env.MSRV }} + - name: Install Tools + run: | + sudo apt-get update + sudo apt-get install -y git llvm clang make lld curl + - name: Build wasix sysroot + run: | + cd ~ + git clone --recurse-submodules https://github.com/wasix-org/wasix-libc + cd wasix-libc + ./build32.sh + rm -rf /opt/wasix-sysroot + cp -r sysroot32 ~/wasix-sysroot + - name: Install wasi-sdk Tools + run: | + cd ~ + curl -L "https://github.com/WebAssembly/wasi-sdk/releases/download/wasi-sdk-${{ env.WASI_SDK_VERSION }}/wasi-sdk-${{ env.WASI_SDK_VERSION }}.0-linux.tar.gz" -o wasi-sdk.tar.gz + tar -xzf wasi-sdk.tar.gz + cp -r wasi-sdk-${{ env.WASI_SDK_VERSION }}.0 ~/wasi-sdk + - name: Install LLVM 18 + run: | + curl --proto '=https' --tlsv1.2 -sSf https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz -L -o llvm.tar.xz + LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} + mkdir ${LLVM_DIR} + tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} + echo "ENABLE_LLVM=1" >> $GITHUB_ENV + echo "${LLVM_DIR}/bin" >> $GITHUB_PATH + echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH + echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV + env: + LLVM_DIR: .llvm + - name: Install wasm-opt + run: | + sudo apt-get install -y binaryen + - name: make test-wasix + run: | + WASI_SDK=~/wasi-sdk WASIX_SYSROOT=~/wasix-sysroot make test-wasix -# test_wasm_build: -# name: Test wasm build -# runs-on: ubuntu-22.04 -# steps: -# - uses: actions/checkout@v3 -# - name: rustup target add wasm32-wasi -# run: rustup target add wasm32-wasi -# - name: make build-wasmer-wasm -# run: make build-wasmer-wasm + test_wasm_build: + name: Test wasm build + runs-on: ubuntu-22.04 + steps: + - uses: actions/checkout@v3 + - name: rustup target add wasm32-wasi + run: rustup target add wasm32-wasi + - name: make build-wasmer-wasm + run: make build-wasmer-wasm -# test_build_jsc: -# name: Test JSC build -# runs-on: ubuntu-22.04 -# steps: -# - uses: actions/checkout@v3 -# - uses: dtolnay/rust-toolchain@stable -# with: -# toolchain: ${{ env.MSRV }} -# target: x86_64-unknown-linux-gnu -# - name: Install NodeJS -# uses: actions/setup-node@v2 -# with: -# node-version: 16 -# - name: Install libjavascriptcoregtk-4.0-dev -# run: sudo apt update && sudo apt install -y libjavascriptcoregtk-4.0-dev -# - name: make build-wasmer-jsc -# run: make build-wasmer-jsc + test_build_jsc: + name: Test JSC build + runs-on: ubuntu-22.04 + steps: + - uses: actions/checkout@v3 + - uses: dtolnay/rust-toolchain@stable + with: + toolchain: ${{ env.MSRV }} + target: x86_64-unknown-linux-gnu + - name: Install NodeJS + uses: actions/setup-node@v2 + with: + node-version: 16 + - name: Install libjavascriptcoregtk-4.0-dev + run: sudo apt update && sudo apt install -y libjavascriptcoregtk-4.0-dev + - name: make build-wasmer-jsc + run: make build-wasmer-jsc -# test_interpreter_api: -# name: ${{ matrix.build-what.name }} on ${{ matrix.metadata.build }} -# runs-on: ${{ matrix.metadata.os }} -# strategy: -# fail-fast: false -# matrix: -# build-what: [ -# { -# key: wamr, -# build-cmd: 'make test-wamr-api', -# name: 'Test API for wamr feature' -# }, -# { -# key: wasmi, -# build-cmd: 'make test-wasmi-api', -# name: 'Test API for wasmi feature' -# }, -# { -# key: v8, -# build-cmd: 'make test-v8-api', -# name: 'Test API for v8 feature' -# } + test_interpreter_api: + name: ${{ matrix.build-what.name }} on ${{ matrix.metadata.build }} + runs-on: ${{ matrix.metadata.os }} + strategy: + fail-fast: false + matrix: + build-what: [ + { + key: wamr, + build-cmd: 'make test-wamr-api', + name: 'Test API for wamr feature' + }, + { + key: wasmi, + build-cmd: 'make test-wasmi-api', + name: 'Test API for wasmi feature' + }, + { + key: v8, + build-cmd: 'make test-v8-api', + name: 'Test API for v8 feature' + } -# ] -# metadata: [ -# { -# build: linux-x64, -# os: ubuntu-22.04, -# }, -# { -# build: macos-arm, -# os: macos-14, -# }, -# { -# build: windows-x64, -# os: windows-2022, -# } -# ] -# container: ${{ matrix.metadata.container }} -# steps: -# - uses: actions/checkout@v3 + ] + metadata: [ + { + build: linux-x64, + os: ubuntu-22.04, + }, + { + build: macos-arm, + os: macos-14, + }, + { + build: windows-x64, + os: windows-2022, + } + ] + container: ${{ matrix.metadata.container }} + steps: + - uses: actions/checkout@v3 -# - name: Setup MSVC (Windows) -# uses: ilammy/msvc-dev-cmd@v1 -# if: matrix.metadata.build == 'windows-x64' + - name: Setup MSVC (Windows) + uses: ilammy/msvc-dev-cmd@v1 + if: matrix.metadata.build == 'windows-x64' -# - uses: dtolnay/rust-toolchain@stable -# with: -# toolchain: ${{ env.MSRV }} + - uses: dtolnay/rust-toolchain@stable + with: + toolchain: ${{ env.MSRV }} -# - name: Install Nextest -# uses: taiki-e/install-action@nextest + - name: Install Nextest + uses: taiki-e/install-action@nextest -# - name: Install `ninja`, clang` and `mold` on Ubuntu -# if: startsWith(matrix.metadata.build, 'linux-') -# shell: bash -# run: | -# sudo apt-get update -y && sudo apt-get install ninja-build clang mold -y + - name: Install `ninja`, clang` and `mold` on Ubuntu + if: startsWith(matrix.metadata.build, 'linux-') + shell: bash + run: | + sudo apt-get update -y && sudo apt-get install ninja-build clang mold -y -# - name: Install `ninja` on macOS -# if: startsWith(matrix.metadata.build, 'macos-') -# shell: bash -# run: | -# brew install ninja + - name: Install `ninja` on macOS + if: startsWith(matrix.metadata.build, 'macos-') + shell: bash + run: | + brew install ninja -# - name: Install `ninja` on Windows -# if: startsWith(matrix.metadata.build, 'windows-') -# shell: bash -# run: | -# choco install ninja + - name: Install `ninja` on Windows + if: startsWith(matrix.metadata.build, 'windows-') + shell: bash + run: | + choco install ninja -# - name: Delete unwanted link to stop it from interfering (Windows) -# shell: bash -# run: rm /usr/bin/link.exe -# if: startsWith(matrix.metadata.build, 'windows-') + - name: Delete unwanted link to stop it from interfering (Windows) + shell: bash + run: rm /usr/bin/link.exe + if: startsWith(matrix.metadata.build, 'windows-') -# - name: Test WAMR API -# if: ${{ matrix.build-what.key == 'wamr' }} -# run: ${{ matrix.build-what.build-cmd }} + - name: Test WAMR API + if: ${{ matrix.build-what.key == 'wamr' }} + run: ${{ matrix.build-what.build-cmd }} -# - name: Test wasmi API -# if: ${{ matrix.build-what.key == 'wasmi' }} -# run: ${{ matrix.build-what.build-cmd }} + - name: Test wasmi API + if: ${{ matrix.build-what.key == 'wasmi' }} + run: ${{ matrix.build-what.build-cmd }} -# - name: Test v8 API (Linux + mold) -# if: ${{ matrix.build-what.key == 'v8' && startsWith(matrix.metadata.build, 'linux-')}} -# run: RUSTFLAGS="-C linker=clang -C link-arg=-fuse-ld=mold" CARGO_TERM_VERBOSE=true cargo nextest run --package=wasmer --release --features=v8 --no-default-features + - name: Test v8 API (Linux + mold) + if: ${{ matrix.build-what.key == 'v8' && startsWith(matrix.metadata.build, 'linux-')}} + run: RUSTFLAGS="-C linker=clang -C link-arg=-fuse-ld=mold" CARGO_TERM_VERBOSE=true cargo nextest run --package=wasmer --release --features=v8 --no-default-features -# - name: Test v8 API -# if: ${{ matrix.build-what.key == 'v8' && !startsWith(matrix.metadata.build, 'linux-')}} -# run: ${{ matrix.build-what.build-cmd }} + - name: Test v8 API + if: ${{ matrix.build-what.key == 'v8' && !startsWith(matrix.metadata.build, 'linux-')}} + run: ${{ matrix.build-what.build-cmd }} -# test_build_docs_rs: -# name: Test build docs rs -# runs-on: ubuntu-22.04 -# steps: -# - uses: actions/checkout@v3 -# - uses: dtolnay/rust-toolchain@master -# with: -# toolchain: "nightly-2024-08-21" -# target: x86_64-unknown-linux-gnu -# - run: cargo install toml-cli # toml-cli is required to run `make test-build-docs-rs` + test_build_docs_rs: + name: Test build docs rs + runs-on: ubuntu-22.04 + steps: + - uses: actions/checkout@v3 + - uses: dtolnay/rust-toolchain@master + with: + toolchain: "nightly-2024-08-21" + target: x86_64-unknown-linux-gnu + - run: cargo install toml-cli # toml-cli is required to run `make test-build-docs-rs` -# - name: Install `ninja` on Ubuntu -# shell: bash -# run: | -# sudo apt-get install ninja-build -y + - name: Install `ninja` on Ubuntu + shell: bash + run: | + sudo apt-get install ninja-build -y -# - name: Install LLVM 18 -# run: | -# curl --proto '=https' --tlsv1.2 -sSf https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz -L -o llvm.tar.xz -# LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} -# mkdir ${LLVM_DIR} -# tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} -# echo "ENABLE_LLVM=1" >> $GITHUB_ENV -# echo "${LLVM_DIR}/bin" >> $GITHUB_PATH -# echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH -# echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV -# env: -# LLVM_DIR: .llvm -# - name: make test-build-docs-rs-ci -# run: make test-build-docs-rs-ci + - name: Install LLVM 18 + run: | + curl --proto '=https' --tlsv1.2 -sSf https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz -L -o llvm.tar.xz + LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} + mkdir ${LLVM_DIR} + tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} + echo "ENABLE_LLVM=1" >> $GITHUB_ENV + echo "${LLVM_DIR}/bin" >> $GITHUB_PATH + echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH + echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV + env: + LLVM_DIR: .llvm + - name: make test-build-docs-rs-ci + run: make test-build-docs-rs-ci -# build_linux_aarch64: -# name: ${{ matrix.build-what.name }} on linux-aarch64 -# runs-on: ubuntu-22.04 -# strategy: -# fail-fast: false -# matrix: -# build-what: [ -# { -# key: capi, -# build-cmd: 'make build-capi && make package-capi', -# name: 'Build C-API' -# }, -# { -# key: wasmer, -# build-cmd: 'make build-wasmer && make package-wasmer && make tar-wasmer', -# name: 'Build wasmer-cli' -# } -# ] -# steps: -# - uses: actions/checkout@v3 -# - uses: dtolnay/rust-toolchain@stable -# with: -# toolchain: ${{ env.MSRV }} -# target: aarch64-unknown-linux-gnu -# - name: Build cross image -# run: | -# docker build -t wasmer/aarch64 ${GITHUB_WORKSPACE}/.github/cross-linux-aarch64/ -# env: -# CROSS_DOCKER_IN_DOCKER: true -# - name: Build ${{ matrix.build-what.key }} -# run: | -# ${{ matrix.build-what.build-cmd }} -# env: -# CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross -# CROSS_DOCKER_IN_DOCKER: true -# CARGO_TARGET: aarch64-unknown-linux-gnu -# PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig -# PKG_CONFIG_ALLOW_CROSS: true -# ENABLE_LLVM: 0 -# - name: Dist -# if: ${{ matrix.build-what.key == 'capi' }} -# run: | -# make distribution -# env: -# CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross -# CROSS_DOCKER_IN_DOCKER: true -# CARGO_TARGET: aarch64-unknown-linux-gnu -# PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig -# PKG_CONFIG_ALLOW_CROSS: true -# TARGET: aarch64-unknown-linux-gnu -# TARGET_DIR: target/aarch64-unknown-linux-gnu/release -# - name: Upload Artifacts -# if: ${{ matrix.build-what.key == 'capi' }} -# uses: actions/upload-artifact@v4 -# with: -# name: capi-linux-aarch64 -# path: dist -# if-no-files-found: error -# retention-days: 2 + build_linux_aarch64: + name: ${{ matrix.build-what.name }} on linux-aarch64 + runs-on: ubuntu-22.04 + strategy: + fail-fast: false + matrix: + build-what: [ + { + key: capi, + build-cmd: 'make build-capi && make package-capi', + name: 'Build C-API' + }, + { + key: wasmer, + build-cmd: 'make build-wasmer && make package-wasmer && make tar-wasmer', + name: 'Build wasmer-cli' + } + ] + steps: + - uses: actions/checkout@v3 + - uses: dtolnay/rust-toolchain@stable + with: + toolchain: ${{ env.MSRV }} + target: aarch64-unknown-linux-gnu + - name: Build cross image + run: | + docker build -t wasmer/aarch64 ${GITHUB_WORKSPACE}/.github/cross-linux-aarch64/ + env: + CROSS_DOCKER_IN_DOCKER: true + - name: Build ${{ matrix.build-what.key }} + run: | + ${{ matrix.build-what.build-cmd }} + env: + CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross + CROSS_DOCKER_IN_DOCKER: true + CARGO_TARGET: aarch64-unknown-linux-gnu + PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig + PKG_CONFIG_ALLOW_CROSS: true + ENABLE_LLVM: 0 + - name: Dist + if: ${{ matrix.build-what.key == 'capi' }} + run: | + make distribution + env: + CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/aarch64 cross + CROSS_DOCKER_IN_DOCKER: true + CARGO_TARGET: aarch64-unknown-linux-gnu + PKG_CONFIG_PATH: /usr/lib/aarch64-linux-gnu/pkgconfig + PKG_CONFIG_ALLOW_CROSS: true + TARGET: aarch64-unknown-linux-gnu + TARGET_DIR: target/aarch64-unknown-linux-gnu/release + - name: Upload Artifacts + if: ${{ matrix.build-what.key == 'capi' }} + uses: actions/upload-artifact@v4 + with: + name: capi-linux-aarch64 + path: dist + if-no-files-found: error + retention-days: 2 -# build_linux_riscv64: -# name: ${{ matrix.build-what.name }} on linux-riscv64 -# runs-on: ubuntu-22.04 -# strategy: -# fail-fast: false -# matrix: -# build-what: [ -# { -# key: capi, -# build-cmd: 'make build-capi && make package-capi', -# name: 'Build C-API' -# }, -# { -# key: wasmer, -# build-cmd: 'make build-wasmer && make package-wasmer && make tar-wasmer', -# name: 'Build wasmer-cli' -# } -# ] -# steps: -# - uses: actions/checkout@v3 -# #- uses: dtolnay/rust-toolchain@stable -# # with: -# # toolchain: ${{ env.MSRV }} -# # target: riscv64gc-unknown-linux-gnu -# - name: Build cross image -# run: | -# docker build -t wasmer/riscv64 ${GITHUB_WORKSPACE}/.github/cross-linux-riscv64/ -# env: -# CROSS_DOCKER_IN_DOCKER: true -# - name: Build ${{ matrix.build-what.key }} -# run: | -# ${{ matrix.build-what.build-cmd }} -# env: -# CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64 cargo -# CROSS_DOCKER_IN_DOCKER: true -# CARGO_TARGET: riscv64gc-unknown-linux-gnu -# ENABLE_LLVM: 0 -# - name: Dist -# if: ${{ matrix.build-what.key == 'capi' }} -# run: | -# make distribution -# env: -# CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64 cargo -# CROSS_DOCKER_IN_DOCKER: true -# CARGO_TARGET: riscv64gc-unknown-linux-gnu -# PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig -# PKG_CONFIG_ALLOW_CROSS: true -# TARGET: riscv64gc-unknown-linux-gnu -# TARGET_DIR: target/riscv64gc-unknown-linux-gnu/release -# - name: Upload Artifacts -# if: ${{ matrix.build-what.key == 'capi' }} -# uses: actions/upload-artifact@v4 -# with: -# name: capi-linux-riscv64 -# path: dist -# if-no-files-found: error -# retention-days: 2 + build_linux_riscv64: + name: ${{ matrix.build-what.name }} on linux-riscv64 + runs-on: ubuntu-22.04 + strategy: + fail-fast: false + matrix: + build-what: [ + { + key: capi, + build-cmd: 'make build-capi && make package-capi', + name: 'Build C-API' + }, + { + key: wasmer, + build-cmd: 'make build-wasmer && make package-wasmer && make tar-wasmer', + name: 'Build wasmer-cli' + } + ] + steps: + - uses: actions/checkout@v3 + #- uses: dtolnay/rust-toolchain@stable + # with: + # toolchain: ${{ env.MSRV }} + # target: riscv64gc-unknown-linux-gnu + - name: Build cross image + run: | + docker build -t wasmer/riscv64 ${GITHUB_WORKSPACE}/.github/cross-linux-riscv64/ + env: + CROSS_DOCKER_IN_DOCKER: true + - name: Build ${{ matrix.build-what.key }} + run: | + ${{ matrix.build-what.build-cmd }} + env: + CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64 cargo + CROSS_DOCKER_IN_DOCKER: true + CARGO_TARGET: riscv64gc-unknown-linux-gnu + ENABLE_LLVM: 0 + - name: Dist + if: ${{ matrix.build-what.key == 'capi' }} + run: | + make distribution + env: + CARGO_BINARY: docker run -v /var/run/docker.sock:/var/run/docker.sock -v ${GITHUB_WORKSPACE}:/project -w /project wasmer/riscv64 cargo + CROSS_DOCKER_IN_DOCKER: true + CARGO_TARGET: riscv64gc-unknown-linux-gnu + PKG_CONFIG_PATH: /usr/lib/riscv64-linux-gnu/pkgconfig + PKG_CONFIG_ALLOW_CROSS: true + TARGET: riscv64gc-unknown-linux-gnu + TARGET_DIR: target/riscv64gc-unknown-linux-gnu/release + - name: Upload Artifacts + if: ${{ matrix.build-what.key == 'capi' }} + uses: actions/upload-artifact@v4 + with: + name: capi-linux-riscv64 + path: dist + if-no-files-found: error + retention-days: 2 -# build: -# name: ${{ matrix.build-what.name }} on ${{ matrix.metadata.build }} -# runs-on: ${{ matrix.metadata.os }} -# needs: setup -# strategy: -# fail-fast: false -# matrix: -# build-what: [ -# { -# key: capi, -# build-cmd: 'make build-capi && make build-capi-headless && make package-capi && make tar-capi', -# name: 'Build and test C-API' -# }, -# { -# key: wasmer, -# build-cmd: 'make build-wasmer && make package-wasmer && make tar-wasmer', -# name: 'Build wasmer-cli' -# } -# ] -# metadata: [ -# { -# build: linux-x64, -# os: ubuntu-22.04, -# target: x86_64-unknown-linux-gnu, -# exe: '', -# llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' -# }, -# { -# build: macos-x64, -# os: macos-12, -# target: x86_64-apple-darwin, -# exe: '', -# llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + build: + name: ${{ matrix.build-what.name }} on ${{ matrix.metadata.build }} + runs-on: ${{ matrix.metadata.os }} + needs: setup + strategy: + fail-fast: false + matrix: + build-what: [ + { + key: capi, + build-cmd: 'make build-capi && make build-capi-headless && make package-capi && make tar-capi', + name: 'Build and test C-API' + }, + { + key: wasmer, + build-cmd: 'make build-wasmer && make package-wasmer && make tar-wasmer', + name: 'Build wasmer-cli' + } + ] + metadata: [ + { + build: linux-x64, + os: ubuntu-22.04, + target: x86_64-unknown-linux-gnu, + exe: '', + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' + }, + { + build: macos-x64, + os: macos-12, + target: x86_64-apple-darwin, + exe: '', + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' -# }, -# { -# build: macos-arm, -# os: macos-14, -# target: aarch64-apple-darwin, -# exe: '', -# # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. -# # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' -# }, -# { -# build: windows-x64, -# os: windows-2022, -# target: x86_64-pc-windows-msvc, -# exe: '.exe', -# # For now, disable LLVM in `windows-x64.` -# # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' -# }, -# { -# build: windows-gnu, -# target: x86_64-pc-windows-gnu, -# os: ubuntu-22.04, -# }, -# { -# build: linux-musl, -# target: x86_64-unknown-linux-musl, -# os: ubuntu-22.04, -# exe: '', -# container: 'alpine:latest' -# } + }, + { + build: macos-arm, + os: macos-14, + target: aarch64-apple-darwin, + exe: '', + # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' + }, + { + build: windows-x64, + os: windows-2022, + target: x86_64-pc-windows-msvc, + exe: '.exe', + # For now, disable LLVM in `windows-x64.` + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + }, + { + build: windows-gnu, + target: x86_64-pc-windows-gnu, + os: ubuntu-22.04, + }, + { + build: linux-musl, + target: x86_64-unknown-linux-musl, + os: ubuntu-22.04, + exe: '', + container: 'alpine:latest' + } -# ] -# container: ${{ matrix.metadata.container }} -# env: -# SCCACHE_AZURE_BLOB_CONTAINER: wasmerstoragesccacheblob -# SCCACHE_AZURE_CONNECTION_STRING: ${{ secrets.SCCACHE_AZURE_CONNECTION_STRING }} -# steps: -# - uses: actions/checkout@v3 -# - name: Set up libstdc++ on Linux -# if: matrix.metadata.build == 'linux-x64' -# run: | -# sudo apt-get update -y -# sudo apt-get install -y --allow-downgrades libstdc++6 libtinfo5 -# sudo apt-get install --reinstall g++ -# - name: Set up base deps on musl -# if: matrix.metadata.build == 'linux-musl' -# run: ./scripts/alpine-linux-install-deps.sh -# - name: Set up dependencies for Mac OS -# run: | -# brew install automake -# # using gnu-tar is a workaround for https://github.com/actions/cache/issues/403 -# brew install gnu-tar -# echo PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH" >> $GITHUB_ENV -# if: matrix.metadata.os == 'macos-12' -# - name: Install Rust -# uses: dtolnay/rust-toolchain@stable -# with: -# toolchain: ${{ env.MSRV }} -# target: ${{ matrix.metadata.target }} -# - name: Install Nextest -# uses: taiki-e/install-action@nextest -# - name: Install MSVC dev-cmd (Windows) -# uses: ilammy/msvc-dev-cmd@v1 -# if: ${{ matrix.metadata.build == 'windows-x64' }} -# - name: Delete unwanted link to stop it from interfering (Windows) -# shell: bash -# run: rm /usr/bin/link.exe -# if: ${{ matrix.metadata.build == 'windows-x64' }} -# - name: Install Windows-GNU linker -# if: ${{ matrix.metadata.build == 'windows-gnu' }} -# shell: bash -# run: | -# sudo apt install -y mingw-w64 -# - name: Install Windows-GNU target -# if: ${{ matrix.metadata.build == 'windows-gnu' }} -# shell: bash -# run: | -# rustup target add x86_64-pc-windows-gnu -# - name: Install Windows 10 SDK with xwin -# if: ${{ matrix.metadata.build == 'windows-gnu' }} -# shell: bash -# run: | -# mkdir -p /tmp/xwin -# mkdir -p /tmp/xwindownload -# mkdir -p /tmp/xwincache -# git clone https://github.com/wasmerio/xwin --depth=1 /tmp/xwin -# cargo build --release --manifest-path=/tmp/xwin/Cargo.toml -# /tmp/xwin/target/release/xwin --accept-license --cache-dir /tmp/xwincache splat --output /tmp/xwindownload -# mkdir -p /tmp/winsdk -# cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/WS2_32.lib /tmp/winsdk/ -# cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/KERNEL32.lib /tmp/winsdk/ -# cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/BCRYPT.lib /tmp/winsdk/ -# cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/ADVAPI32.lib /tmp/winsdk/ -# cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/USERENV.lib /tmp/winsdk/ -# echo "WinSDK files:" -# ls -laH /tmp/winsdk -# echo "" -# mkdir -p package -# mkdir -p package/winsdk -# cp -r /tmp/winsdk/* package/winsdk -# - name: Install LLVM (macOS Apple Silicon) -# if: matrix.metadata.os == 'macos-12' && !matrix.metadata.llvm_url -# run: | -# brew install llvm -# - name: Install LLVM -# shell: bash -# if: matrix.metadata.llvm_url -# run: | -# curl --proto '=https' --tlsv1.2 -sSf ${{ matrix.metadata.llvm_url }} -L -o llvm.tar.xz -# LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} -# mkdir ${LLVM_DIR} -# tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} -# echo "ENABLE_LLVM=1" >> $GITHUB_ENV -# echo "${LLVM_DIR}/bin" >> $GITHUB_PATH -# echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH -# echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV -# env: -# LLVM_DIR: .llvm -# - name: Add `brew` libs to `RUSTFLAGS` -# if: matrix.metadata.os == 'macos-14' -# shell: bash -# run: | -# echo "RUSTFLAGS=-L/opt/homebrew/lib" >> $GITHUB_ENV -# - name: Setup Rust target -# shell: bash -# run: | -# mkdir -p .cargo -# cat << EOF > .cargo/config.toml -# [build] -# target = "${{ matrix.metadata.target }}" -# EOF -# if: matrix.metadata.target -# - name: which cargo -# if: ${{ matrix.build-what.key == 'capi' && matrix.metadata.build == 'windows-x64' }} -# run: which cargo -# - name: Set cargo env -# run: echo "CARGO_ROOT_DIR=$(dirname $(dirname $( which cargo )))" >> $GITHUB_ENV -# - name: List root dir -# shell: bash -# if: ${{ matrix.build-what.key == 'capi' && matrix.metadata.build == 'windows-x64' }} -# run: ls -R $CARGO_ROOT_DIR -# - name: Cache -# uses: whywaita/actions-cache-s3@v2 -# with: -# path: | -# ~/.cargo/* -# ./target/* -# $CARGO_ROOT_DIR/* -# key: r22-${{ github.repository }}-${{ runner.os }}-${{ hashFiles('Cargo.lock') }}-wasmer-make-build-wasmer-${{ matrix.build-what.key }}-${{ matrix.metadata.build }} -# aws-s3-bucket: wasmer-rust-artifacts-cache -# aws-access-key-id: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_TOKEN }} -# aws-secret-access-key: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_KEY }} -# aws-region: auto -# aws-endpoint: https://1541b1e8a3fc6ad155ce67ef38899700.r2.cloudflarestorage.com -# aws-s3-bucket-endpoint: false -# aws-s3-force-path-style: true -# - name: Build C-API -# shell: bash -# run: ${{ matrix.build-what.build-cmd }} -# if: ${{ matrix.build-what.key == 'capi' }} -# env: -# TARGET: ${{ matrix.metadata.target }} -# TARGET_DIR: target/${{ matrix.metadata.target }}/release -# CARGO_TARGET: ${{ matrix.metadata.target }} -# - name: Build Wasmer -# shell: bash -# if: ${{ matrix.build-what.key == 'wasmer' && matrix.metadata.build != 'windows-gnu' }} -# run: ${{ matrix.build-what.build-cmd }} -# env: -# TARGET: ${{ matrix.metadata.target }} -# TARGET_DIR: target/${{ matrix.metadata.target }}/release -# CARGO_TARGET: ${{ matrix.metadata.target }} -# - name: Test C-API -# shell: bash -# if: ${{ matrix.build-what.key == 'capi' && !(matrix.metadata.build == 'linux-musl' || matrix.metadata.build == 'windows-gnu') }} -# run: make test-capi-ci -# env: -# TARGET: ${{ matrix.metadata.target }} -# TARGET_DIR: target/${{ matrix.metadata.target }}/release -# CARGO_TARGET: ${{ matrix.metadata.target }} -# # C-API tests were disabled for linux-musl and macos-arm (we can't run them) -# - name: Test C-API integration -# shell: bash -# if: ${{ matrix.build-what.key == 'capi' && !(matrix.metadata.build == 'linux-musl' || matrix.metadata.build == 'windows-gnu') }} -# run: export WASMER_DIR=`pwd`/package && make test-stage-7-capi-integration-tests -# env: -# TARGET: ${{ matrix.metadata.target }} -# TARGET_DIR: target/${{ matrix.metadata.target }}/release -# CARGO_TARGET: ${{ matrix.metadata.target }} -# - name: Archive production artifacts -# uses: actions/upload-artifact@v4 -# with: -# name: wasmer-cli-${{ matrix.metadata.build }} -# path: build-wasmer.tar.gz -# if-no-files-found: ignore -# retention-days: 2 -# - name: Archive production artifacts -# uses: actions/upload-artifact@v4 -# with: -# name: capi-${{ matrix.metadata.build }} -# path: build-capi.tar.gz -# if-no-files-found: ignore -# retention-days: 2 + ] + container: ${{ matrix.metadata.container }} + env: + SCCACHE_AZURE_BLOB_CONTAINER: wasmerstoragesccacheblob + SCCACHE_AZURE_CONNECTION_STRING: ${{ secrets.SCCACHE_AZURE_CONNECTION_STRING }} + steps: + - uses: actions/checkout@v3 + - name: Set up libstdc++ on Linux + if: matrix.metadata.build == 'linux-x64' + run: | + sudo apt-get update -y + sudo apt-get install -y --allow-downgrades libstdc++6 libtinfo5 + sudo apt-get install --reinstall g++ + - name: Set up base deps on musl + if: matrix.metadata.build == 'linux-musl' + run: ./scripts/alpine-linux-install-deps.sh + - name: Set up dependencies for Mac OS + run: | + brew install automake + # using gnu-tar is a workaround for https://github.com/actions/cache/issues/403 + brew install gnu-tar + echo PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH" >> $GITHUB_ENV + if: matrix.metadata.os == 'macos-12' + - name: Install Rust + uses: dtolnay/rust-toolchain@stable + with: + toolchain: ${{ env.MSRV }} + target: ${{ matrix.metadata.target }} + - name: Install Nextest + uses: taiki-e/install-action@nextest + - name: Install MSVC dev-cmd (Windows) + uses: ilammy/msvc-dev-cmd@v1 + if: ${{ matrix.metadata.build == 'windows-x64' }} + - name: Delete unwanted link to stop it from interfering (Windows) + shell: bash + run: rm /usr/bin/link.exe + if: ${{ matrix.metadata.build == 'windows-x64' }} + - name: Install Windows-GNU linker + if: ${{ matrix.metadata.build == 'windows-gnu' }} + shell: bash + run: | + sudo apt install -y mingw-w64 + - name: Install Windows-GNU target + if: ${{ matrix.metadata.build == 'windows-gnu' }} + shell: bash + run: | + rustup target add x86_64-pc-windows-gnu + - name: Install Windows 10 SDK with xwin + if: ${{ matrix.metadata.build == 'windows-gnu' }} + shell: bash + run: | + mkdir -p /tmp/xwin + mkdir -p /tmp/xwindownload + mkdir -p /tmp/xwincache + git clone https://github.com/wasmerio/xwin --depth=1 /tmp/xwin + cargo build --release --manifest-path=/tmp/xwin/Cargo.toml + /tmp/xwin/target/release/xwin --accept-license --cache-dir /tmp/xwincache splat --output /tmp/xwindownload + mkdir -p /tmp/winsdk + cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/WS2_32.lib /tmp/winsdk/ + cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/KERNEL32.lib /tmp/winsdk/ + cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/BCRYPT.lib /tmp/winsdk/ + cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/ADVAPI32.lib /tmp/winsdk/ + cp /tmp/xwindownload/sdk/lib/10.0.20348/um/x86_64/USERENV.lib /tmp/winsdk/ + echo "WinSDK files:" + ls -laH /tmp/winsdk + echo "" + mkdir -p package + mkdir -p package/winsdk + cp -r /tmp/winsdk/* package/winsdk + - name: Install LLVM (macOS Apple Silicon) + if: matrix.metadata.os == 'macos-12' && !matrix.metadata.llvm_url + run: | + brew install llvm + - name: Install LLVM + shell: bash + if: matrix.metadata.llvm_url + run: | + curl --proto '=https' --tlsv1.2 -sSf ${{ matrix.metadata.llvm_url }} -L -o llvm.tar.xz + LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} + mkdir ${LLVM_DIR} + tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} + echo "ENABLE_LLVM=1" >> $GITHUB_ENV + echo "${LLVM_DIR}/bin" >> $GITHUB_PATH + echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH + echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV + env: + LLVM_DIR: .llvm + - name: Add `brew` libs to `RUSTFLAGS` + if: matrix.metadata.os == 'macos-14' + shell: bash + run: | + echo "RUSTFLAGS=-L/opt/homebrew/lib" >> $GITHUB_ENV + - name: Setup Rust target + shell: bash + run: | + mkdir -p .cargo + cat << EOF > .cargo/config.toml + [build] + target = "${{ matrix.metadata.target }}" + EOF + if: matrix.metadata.target + - name: which cargo + if: ${{ matrix.build-what.key == 'capi' && matrix.metadata.build == 'windows-x64' }} + run: which cargo + - name: Set cargo env + run: echo "CARGO_ROOT_DIR=$(dirname $(dirname $( which cargo )))" >> $GITHUB_ENV + - name: List root dir + shell: bash + if: ${{ matrix.build-what.key == 'capi' && matrix.metadata.build == 'windows-x64' }} + run: ls -R $CARGO_ROOT_DIR + - name: Cache + uses: whywaita/actions-cache-s3@v2 + with: + path: | + ~/.cargo/* + ./target/* + $CARGO_ROOT_DIR/* + key: r22-${{ github.repository }}-${{ runner.os }}-${{ hashFiles('Cargo.lock') }}-wasmer-make-build-wasmer-${{ matrix.build-what.key }}-${{ matrix.metadata.build }} + aws-s3-bucket: wasmer-rust-artifacts-cache + aws-access-key-id: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_TOKEN }} + aws-secret-access-key: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_KEY }} + aws-region: auto + aws-endpoint: https://1541b1e8a3fc6ad155ce67ef38899700.r2.cloudflarestorage.com + aws-s3-bucket-endpoint: false + aws-s3-force-path-style: true + - name: Build C-API + shell: bash + run: ${{ matrix.build-what.build-cmd }} + if: ${{ matrix.build-what.key == 'capi' }} + env: + TARGET: ${{ matrix.metadata.target }} + TARGET_DIR: target/${{ matrix.metadata.target }}/release + CARGO_TARGET: ${{ matrix.metadata.target }} + - name: Build Wasmer + shell: bash + if: ${{ matrix.build-what.key == 'wasmer' && matrix.metadata.build != 'windows-gnu' }} + run: ${{ matrix.build-what.build-cmd }} + env: + TARGET: ${{ matrix.metadata.target }} + TARGET_DIR: target/${{ matrix.metadata.target }}/release + CARGO_TARGET: ${{ matrix.metadata.target }} + - name: Test C-API + shell: bash + if: ${{ matrix.build-what.key == 'capi' && !(matrix.metadata.build == 'linux-musl' || matrix.metadata.build == 'windows-gnu') }} + run: make test-capi-ci + env: + TARGET: ${{ matrix.metadata.target }} + TARGET_DIR: target/${{ matrix.metadata.target }}/release + CARGO_TARGET: ${{ matrix.metadata.target }} + # C-API tests were disabled for linux-musl and macos-arm (we can't run them) + - name: Test C-API integration + shell: bash + if: ${{ matrix.build-what.key == 'capi' && !(matrix.metadata.build == 'linux-musl' || matrix.metadata.build == 'windows-gnu') }} + run: export WASMER_DIR=`pwd`/package && make test-stage-7-capi-integration-tests + env: + TARGET: ${{ matrix.metadata.target }} + TARGET_DIR: target/${{ matrix.metadata.target }}/release + CARGO_TARGET: ${{ matrix.metadata.target }} + - name: Archive production artifacts + uses: actions/upload-artifact@v4 + with: + name: wasmer-cli-${{ matrix.metadata.build }} + path: build-wasmer.tar.gz + if-no-files-found: ignore + retention-days: 2 + - name: Archive production artifacts + uses: actions/upload-artifact@v4 + with: + name: capi-${{ matrix.metadata.build }} + path: build-capi.tar.gz + if-no-files-found: ignore + retention-days: 2 -# test: -# name: ${{ matrix.stage.description }} on ${{ matrix.metadata.build }} -# runs-on: ${{ matrix.metadata.os }} -# needs: setup -# strategy: -# fail-fast: false -# matrix: -# stage: [ -# { -# description: 'Run wast test suite for all compilers', -# make: 'test-stage-0-wast', -# }, -# { -# description: 'Unit-test packages on std', -# make: 'test-stage-1-test-all', -# }, -# { -# description: 'Unit-test cranelift on no-std', -# make: 'test-stage-2-test-compiler-cranelift-nostd', -# }, -# { -# description: 'Unit-test singlepass on no-std', -# make: 'test-stage-3-test-compiler-singlepass-nostd', -# }, -# { -# description: 'Unit-test wasmer-cli', -# make: 'test-stage-4-wasmer-cli', -# }, -# { -# description: 'Unit-test examples', -# make: 'test-stage-5-test-examples', -# } -# ] -# metadata: [ -# # We cannot test on macos-arm since we don't have ARM runners -# { -# build: linux-x64, -# os: ubuntu-22.04, -# target: x86_64-unknown-linux-gnu, -# exe: '', -# llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' -# }, -# { -# build: macos-x64, -# os: macos-12, -# target: x86_64-apple-darwin, -# exe: '', -# llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' + test: + name: ${{ matrix.stage.description }} on ${{ matrix.metadata.build }} + runs-on: ${{ matrix.metadata.os }} + needs: setup + strategy: + fail-fast: false + matrix: + stage: [ + { + description: 'Run wast test suite for all compilers', + make: 'test-stage-0-wast', + }, + { + description: 'Unit-test packages on std', + make: 'test-stage-1-test-all', + }, + { + description: 'Unit-test cranelift on no-std', + make: 'test-stage-2-test-compiler-cranelift-nostd', + }, + { + description: 'Unit-test singlepass on no-std', + make: 'test-stage-3-test-compiler-singlepass-nostd', + }, + { + description: 'Unit-test wasmer-cli', + make: 'test-stage-4-wasmer-cli', + }, + { + description: 'Unit-test examples', + make: 'test-stage-5-test-examples', + } + ] + metadata: [ + # We cannot test on macos-arm since we don't have ARM runners + { + build: linux-x64, + os: ubuntu-22.04, + target: x86_64-unknown-linux-gnu, + exe: '', + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' + }, + { + build: macos-x64, + os: macos-12, + target: x86_64-apple-darwin, + exe: '', + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-amd64.tar.xz' -# }, -# { -# build: macos-arm64, -# os: macos-14, -# target: aarch64-apple-darwin, -# exe: '', -# # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. -# # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' -# }, -# { -# build: windows-x64, -# os: windows-2022, -# target: x86_64-pc-windows-msvc, -# exe: '.exe', -# # For now, disable LLVM in `windows-x64.` -# # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' -# }, -# { -# build: linux-musl, -# target: x86_64-unknown-linux-musl, -# os: ubuntu-22.04, -# exe: '', -# container: 'alpine:latest' -# } -# ] -# container: ${{ matrix.metadata.container }} -# env: -# SCCACHE_AZURE_BLOB_CONTAINER: wasmerstoragesccacheblob -# SCCACHE_AZURE_CONNECTION_STRING: ${{ secrets.SCCACHE_AZURE_CONNECTION_STRING }} -# steps: -# - uses: actions/checkout@v3 -# - name: Set up libstdc++ on Linux -# if: matrix.metadata.build == 'linux-x64' -# run: | -# sudo apt-get update -y -# sudo apt-get install -y --allow-downgrades libstdc++6 -# sudo apt-get install --reinstall g++ -# - name: Set up base deps on musl -# if: matrix.metadata.build == 'linux-musl' -# run: ./scripts/alpine-linux-install-deps.sh -# - name: Install MSVC dev-cmd (Windows) -# uses: ilammy/msvc-dev-cmd@v1 -# if: ${{ matrix.metadata.build == 'windows-x64' }} -# - name: Delete unwanted link to stop it from interfering (Windows) -# shell: bash -# run: rm /usr/bin/link.exe -# if: ${{ matrix.metadata.build == 'windows-x64' }} + }, + { + build: macos-arm64, + os: macos-14, + target: aarch64-apple-darwin, + exe: '', + # [todo] xdoardo: Reinstate when the code we generate for aarch64 is working correctly. + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-darwin-aarch64.tar.xz' + }, + { + build: windows-x64, + os: windows-2022, + target: x86_64-pc-windows-msvc, + exe: '.exe', + # For now, disable LLVM in `windows-x64.` + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + }, + { + build: linux-musl, + target: x86_64-unknown-linux-musl, + os: ubuntu-22.04, + exe: '', + container: 'alpine:latest' + } + ] + container: ${{ matrix.metadata.container }} + env: + SCCACHE_AZURE_BLOB_CONTAINER: wasmerstoragesccacheblob + SCCACHE_AZURE_CONNECTION_STRING: ${{ secrets.SCCACHE_AZURE_CONNECTION_STRING }} + steps: + - uses: actions/checkout@v3 + - name: Set up libstdc++ on Linux + if: matrix.metadata.build == 'linux-x64' + run: | + sudo apt-get update -y + sudo apt-get install -y --allow-downgrades libstdc++6 + sudo apt-get install --reinstall g++ + - name: Set up base deps on musl + if: matrix.metadata.build == 'linux-musl' + run: ./scripts/alpine-linux-install-deps.sh + - name: Install MSVC dev-cmd (Windows) + uses: ilammy/msvc-dev-cmd@v1 + if: ${{ matrix.metadata.build == 'windows-x64' }} + - name: Delete unwanted link to stop it from interfering (Windows) + shell: bash + run: rm /usr/bin/link.exe + if: ${{ matrix.metadata.build == 'windows-x64' }} -# - name: Set up dependencies for Mac OS -# run: | -# brew install automake -# # using gnu-tar is a workaround for https://github.com/actions/cache/issues/403 -# brew install gnu-tar -# echo PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH" >> $GITHUB_ENV -# if: matrix.metadata.os == 'macos-12' -# - name: Install Rust -# uses: dtolnay/rust-toolchain@stable -# with: -# toolchain: ${{ env.MSRV }} -# target: ${{ matrix.metadata.target }} -# - name: Install Nextest -# uses: taiki-e/install-action@nextest -# - name: Install LLVM (macOS Apple Silicon) -# if: matrix.metadata.os == 'macos-12' && !matrix.metadata.llvm_url -# run: | -# brew install llvm -# - name: Install LLVM -# shell: bash -# if: matrix.metadata.llvm_url -# run: | -# curl --proto '=https' --tlsv1.2 -sSf ${{ matrix.metadata.llvm_url }} -L -o llvm.tar.xz -# LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} -# mkdir ${LLVM_DIR} -# tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} -# echo "${LLVM_DIR}/bin" >> $GITHUB_PATH -# echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH -# echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV -# echo "ENABLE_LLVM=1" >> $GITHUB_ENV -# env: -# LLVM_DIR: .llvm -# - name: Add `brew` libs to `RUSTFLAGS` -# if: matrix.metadata.os == 'macos-14' -# shell: bash -# run: | -# echo "RUSTFLAGS=-L/opt/homebrew/lib" >> $GITHUB_ENV -# - name: Setup Rust target -# shell: bash -# run: | -# mkdir -p .cargo -# cat << EOF > .cargo/config.toml -# [build] -# target = "${{ matrix.metadata.target }}" -# EOF -# if: matrix.metadata.target -# - name: Cache -# uses: whywaita/actions-cache-s3@v2 -# with: -# path: | -# ~/.cargo/* -# ./target/* -# key: r22-${{ github.repository }}-${{ runner.os }}-${{ hashFiles('Cargo.lock') }}-wasmer-make-test-stage-${{ matrix.stage.make }}-${{ matrix.metadata.build }} -# aws-s3-bucket: wasmer-rust-artifacts-cache -# aws-access-key-id: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_TOKEN }} -# aws-secret-access-key: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_KEY }} -# aws-region: auto -# aws-endpoint: https://1541b1e8a3fc6ad155ce67ef38899700.r2.cloudflarestorage.com -# aws-s3-bucket-endpoint: false -# aws-s3-force-path-style: true -# - name: ${{ matrix.stage.description }} -# shell: bash -# run: make ${{ matrix.stage.make }} -# env: -# TARGET: ${{ matrix.metadata.target }} -# TARGET_DIR: target/${{ matrix.metadata.target }}/release -# CARGO_TARGET: ${{ matrix.metadata.target }} + - name: Set up dependencies for Mac OS + run: | + brew install automake + # using gnu-tar is a workaround for https://github.com/actions/cache/issues/403 + brew install gnu-tar + echo PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH" >> $GITHUB_ENV + if: matrix.metadata.os == 'macos-12' + - name: Install Rust + uses: dtolnay/rust-toolchain@stable + with: + toolchain: ${{ env.MSRV }} + target: ${{ matrix.metadata.target }} + - name: Install Nextest + uses: taiki-e/install-action@nextest + - name: Install LLVM (macOS Apple Silicon) + if: matrix.metadata.os == 'macos-12' && !matrix.metadata.llvm_url + run: | + brew install llvm + - name: Install LLVM + shell: bash + if: matrix.metadata.llvm_url + run: | + curl --proto '=https' --tlsv1.2 -sSf ${{ matrix.metadata.llvm_url }} -L -o llvm.tar.xz + LLVM_DIR=$(pwd)/${{ env.LLVM_DIR }} + mkdir ${LLVM_DIR} + tar xf llvm.tar.xz --strip-components=1 -C ${LLVM_DIR} + echo "${LLVM_DIR}/bin" >> $GITHUB_PATH + echo "${LLVM_DIR}/usr/bin" >> $GITHUB_PATH + echo "LLVM_SYS_180_PREFIX=${LLVM_DIR}" >> $GITHUB_ENV + echo "ENABLE_LLVM=1" >> $GITHUB_ENV + env: + LLVM_DIR: .llvm + - name: Add `brew` libs to `RUSTFLAGS` + if: matrix.metadata.os == 'macos-14' + shell: bash + run: | + echo "RUSTFLAGS=-L/opt/homebrew/lib" >> $GITHUB_ENV + - name: Setup Rust target + shell: bash + run: | + mkdir -p .cargo + cat << EOF > .cargo/config.toml + [build] + target = "${{ matrix.metadata.target }}" + EOF + if: matrix.metadata.target + - name: Cache + uses: whywaita/actions-cache-s3@v2 + with: + path: | + ~/.cargo/* + ./target/* + key: r22-${{ github.repository }}-${{ runner.os }}-${{ hashFiles('Cargo.lock') }}-wasmer-make-test-stage-${{ matrix.stage.make }}-${{ matrix.metadata.build }} + aws-s3-bucket: wasmer-rust-artifacts-cache + aws-access-key-id: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_TOKEN }} + aws-secret-access-key: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_KEY }} + aws-region: auto + aws-endpoint: https://1541b1e8a3fc6ad155ce67ef38899700.r2.cloudflarestorage.com + aws-s3-bucket-endpoint: false + aws-s3-force-path-style: true + - name: ${{ matrix.stage.description }} + shell: bash + run: make ${{ matrix.stage.make }} + env: + TARGET: ${{ matrix.metadata.target }} + TARGET_DIR: target/${{ matrix.metadata.target }}/release + CARGO_TARGET: ${{ matrix.metadata.target }} -# test_integration_cli: -# name: CLI integration tests on ${{ matrix.build }} -# runs-on: ${{ matrix.os }} -# needs: [build, build_linux_aarch64, build_linux_riscv64] -# strategy: -# fail-fast: false -# matrix: -# include: -# - build: linux-x64 -# os: ubuntu-22.04 -# target: x86_64-unknown-linux-gnu -# llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' -# - build: macos-x64 -# os: macos-12 -# target: x86_64-apple-darwin -# # we only build the integration-test CLI, we don't run tests -# - build: macos-arm64 -# os: macos-12 -# target: aarch64-apple-darwin, -# - build: linux-musl -# target: x86_64-unknown-linux-musl -# os: ubuntu-22.04 -# container: alpine:latest -# - build: windows-x64 -# os: windows-2019 -# target: x86_64-pc-windows-msvc -# # For now, disable LLVM in `windows-x64.` -# # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' + test_integration_cli: + name: CLI integration tests on ${{ matrix.build }} + runs-on: ${{ matrix.os }} + needs: [build, build_linux_aarch64, build_linux_riscv64] + strategy: + fail-fast: false + matrix: + include: + - build: linux-x64 + os: ubuntu-22.04 + target: x86_64-unknown-linux-gnu + llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-linux-amd64.tar.xz' + - build: macos-x64 + os: macos-12 + target: x86_64-apple-darwin + # we only build the integration-test CLI, we don't run tests + - build: macos-arm64 + os: macos-12 + target: aarch64-apple-darwin, + - build: linux-musl + target: x86_64-unknown-linux-musl + os: ubuntu-22.04 + container: alpine:latest + - build: windows-x64 + os: windows-2019 + target: x86_64-pc-windows-msvc + # For now, disable LLVM in `windows-x64.` + # llvm_url: 'https://github.com/wasmerio/llvm-custom-builds/releases/download/18.x/llvm-windows-amd64.tar.xz' -# container: ${{ matrix.container }} -# env: -# SCCACHE_AZURE_BLOB_CONTAINER: wasmerstoragesccacheblob -# SCCACHE_AZURE_CONNECTION_STRING: ${{ secrets.SCCACHE_AZURE_CONNECTION_STRING }} -# steps: -# - uses: actions/checkout@v3 -# - uses: goto-bus-stop/setup-zig@v2 -# with: -# version: 0.10.0 -# - name: Set up base deps on musl -# if: matrix.build == 'linux-musl' -# run: ./scripts/alpine-linux-install-deps.sh -# - uses: actions/download-artifact@v4 -# id: download -# with: -# name: capi-${{ matrix.build }} -# - uses: actions/download-artifact@v4 -# with: -# name: wasmer-cli-${{ matrix.build }} -# - name: 'Echo download path' -# run: echo ${{steps.download.outputs.download-path}} -# - name: Install Rust -# uses: dtolnay/rust-toolchain@stable -# with: -# toolchain: ${{ env.MSRV }} -# target: ${{ matrix.metadata.target }} -# - name: Install Nextest -# uses: taiki-e/install-action@nextest -# - name: Cache -# uses: whywaita/actions-cache-s3@v2 -# with: -# path: | -# ~/.cargo/* -# ./target/* -# key: r22-${{ github.repository }}-${{ runner.os }}-${{ hashFiles('Cargo.lock') }}-wasmer-make-test-integration-cli-${{ matrix.build }} -# aws-s3-bucket: wasmer-rust-artifacts-cache -# aws-access-key-id: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_TOKEN }} -# aws-secret-access-key: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_KEY }} -# aws-region: auto -# aws-endpoint: https://1541b1e8a3fc6ad155ce67ef38899700.r2.cloudflarestorage.com -# aws-s3-bucket-endpoint: false -# aws-s3-force-path-style: true -# - name: Prepare package directory -# shell: bash -# run: | -# mkdir -p package -# mkdir -p package/cache -# - uses: actions/download-artifact@v4 -# with: -# name: capi-linux-aarch64 -# path: package/cache/wasmercache1 -# - uses: actions/download-artifact@v4 -# with: -# name: capi-windows-x64 -# path: package/cache/wasmercache2 -# - uses: actions/download-artifact@v4 -# with: -# name: capi-macos-arm -# path: package/cache/wasmercache3 -# - uses: actions/download-artifact@v4 -# with: -# name: capi-macos-x64 -# path: package/cache/wasmercache4 -# - uses: actions/download-artifact@v4 -# with: -# name: capi-linux-x64 -# path: package/cache/wasmercache5 -# - uses: actions/download-artifact@v4 -# with: -# name: capi-linux-riscv64 -# path: package/cache/wasmercache6 -# - name: Copy .tar.gz files to proper location -# shell: bash -# run: | -# ls package/cache/wasmercache1 -# ls package/cache/wasmercache2 -# ls package/cache/wasmercache3 -# ls package/cache/wasmercache4 -# ls package/cache/wasmercache5 -# cp package/cache/wasmercache1/wasmer.tar.gz package/cache/wasmer-linux-aarch64.tar.gz -# cp package/cache/wasmercache2/build-capi.tar.gz package/cache/wasmer-windows-gnu64.tar.gz -# cp package/cache/wasmercache3/build-capi.tar.gz package/cache/wasmer-darwin-arm64.tar.gz -# cp package/cache/wasmercache4/build-capi.tar.gz package/cache/wasmer-darwin-amd64.tar.gz -# cp package/cache/wasmercache5/build-capi.tar.gz package/cache/wasmer-linux-amd64.tar.gz -# cp package/cache/wasmercache6/wasmer.tar.gz package/cache/wasmer-linux-riscv64.tar.gz -# - uses: actions/download-artifact@v4 -# if: ${{ matrix.build == 'windows-x64' }} -# with: -# name: capi-windows-x64 -# path: download_link -# - uses: actions/download-artifact@v4 -# if: ${{ matrix.build == 'linux-musl' }} -# with: -# name: capi-linux-musl -# path: download_link -# - uses: actions/download-artifact@v4 -# if: ${{ matrix.build == 'macos-arm64' }} -# with: -# name: capi-macos-arm -# path: download_link -# - uses: actions/download-artifact@v4 -# if: ${{ matrix.build == 'macos-x64' }} -# with: -# name: capi-macos-x64 -# path: download_link -# - uses: actions/download-artifact@v4 -# if: ${{ matrix.build == 'linux-x64' }} -# with: -# name: capi-linux-x64 -# path: download_link -# - name: Copy build-capi.tar.gz to link.tar.gz -# shell: bash -# run: | -# cp download_link/build-capi.tar.gz link.tar.gz -# - name: Unzip Artifacts -# shell: bash -# run: | -# make untar-capi -# - name: Unzip Artifacts -# shell: bash -# run: | -# make untar-wasmer + container: ${{ matrix.container }} + env: + SCCACHE_AZURE_BLOB_CONTAINER: wasmerstoragesccacheblob + SCCACHE_AZURE_CONNECTION_STRING: ${{ secrets.SCCACHE_AZURE_CONNECTION_STRING }} + steps: + - uses: actions/checkout@v3 + - uses: goto-bus-stop/setup-zig@v2 + with: + version: 0.10.0 + - name: Set up base deps on musl + if: matrix.build == 'linux-musl' + run: ./scripts/alpine-linux-install-deps.sh + - uses: actions/download-artifact@v4 + id: download + with: + name: capi-${{ matrix.build }} + - uses: actions/download-artifact@v4 + with: + name: wasmer-cli-${{ matrix.build }} + - name: 'Echo download path' + run: echo ${{steps.download.outputs.download-path}} + - name: Install Rust + uses: dtolnay/rust-toolchain@stable + with: + toolchain: ${{ env.MSRV }} + target: ${{ matrix.metadata.target }} + - name: Install Nextest + uses: taiki-e/install-action@nextest + - name: Cache + uses: whywaita/actions-cache-s3@v2 + with: + path: | + ~/.cargo/* + ./target/* + key: r22-${{ github.repository }}-${{ runner.os }}-${{ hashFiles('Cargo.lock') }}-wasmer-make-test-integration-cli-${{ matrix.build }} + aws-s3-bucket: wasmer-rust-artifacts-cache + aws-access-key-id: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_TOKEN }} + aws-secret-access-key: ${{ secrets.CLOUDFLARE_ARTIFACTS_CACHE_ACCESS_KEY }} + aws-region: auto + aws-endpoint: https://1541b1e8a3fc6ad155ce67ef38899700.r2.cloudflarestorage.com + aws-s3-bucket-endpoint: false + aws-s3-force-path-style: true + - name: Prepare package directory + shell: bash + run: | + mkdir -p package + mkdir -p package/cache + - uses: actions/download-artifact@v4 + with: + name: capi-linux-aarch64 + path: package/cache/wasmercache1 + - uses: actions/download-artifact@v4 + with: + name: capi-windows-x64 + path: package/cache/wasmercache2 + - uses: actions/download-artifact@v4 + with: + name: capi-macos-arm + path: package/cache/wasmercache3 + - uses: actions/download-artifact@v4 + with: + name: capi-macos-x64 + path: package/cache/wasmercache4 + - uses: actions/download-artifact@v4 + with: + name: capi-linux-x64 + path: package/cache/wasmercache5 + - uses: actions/download-artifact@v4 + with: + name: capi-linux-riscv64 + path: package/cache/wasmercache6 + - name: Copy .tar.gz files to proper location + shell: bash + run: | + ls package/cache/wasmercache1 + ls package/cache/wasmercache2 + ls package/cache/wasmercache3 + ls package/cache/wasmercache4 + ls package/cache/wasmercache5 + cp package/cache/wasmercache1/wasmer.tar.gz package/cache/wasmer-linux-aarch64.tar.gz + cp package/cache/wasmercache2/build-capi.tar.gz package/cache/wasmer-windows-gnu64.tar.gz + cp package/cache/wasmercache3/build-capi.tar.gz package/cache/wasmer-darwin-arm64.tar.gz + cp package/cache/wasmercache4/build-capi.tar.gz package/cache/wasmer-darwin-amd64.tar.gz + cp package/cache/wasmercache5/build-capi.tar.gz package/cache/wasmer-linux-amd64.tar.gz + cp package/cache/wasmercache6/wasmer.tar.gz package/cache/wasmer-linux-riscv64.tar.gz + - uses: actions/download-artifact@v4 + if: ${{ matrix.build == 'windows-x64' }} + with: + name: capi-windows-x64 + path: download_link + - uses: actions/download-artifact@v4 + if: ${{ matrix.build == 'linux-musl' }} + with: + name: capi-linux-musl + path: download_link + - uses: actions/download-artifact@v4 + if: ${{ matrix.build == 'macos-arm64' }} + with: + name: capi-macos-arm + path: download_link + - uses: actions/download-artifact@v4 + if: ${{ matrix.build == 'macos-x64' }} + with: + name: capi-macos-x64 + path: download_link + - uses: actions/download-artifact@v4 + if: ${{ matrix.build == 'linux-x64' }} + with: + name: capi-linux-x64 + path: download_link + - name: Copy build-capi.tar.gz to link.tar.gz + shell: bash + run: | + cp download_link/build-capi.tar.gz link.tar.gz + - name: Unzip Artifacts + shell: bash + run: | + make untar-capi + - name: Unzip Artifacts + shell: bash + run: | + make untar-wasmer -# # Removed in favour of freestanding integration tests -# # -# # - name: Test integration CLI -# # if: false # matrix.build != 'macos-arm' -# # shell: bash -# # run: | -# # export WASMER_PATH=`pwd`/target/${{ matrix.target }}/release/wasmer${{ matrix.exe }} -# # export WASMER_DIR=`pwd`/package && make test-integration-cli-ci -# # env: -# # TARGET: ${{ matrix.target }} -# # TARGET_DIR: target/${{ matrix.target }}/release -# # CARGO_TARGET: ${{ matrix.target }} -# # WAPM_DEV_TOKEN: ${{ secrets.WAPM_DEV_TOKEN }} -# # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + # Removed in favour of freestanding integration tests + # + # - name: Test integration CLI + # if: false # matrix.build != 'macos-arm' + # shell: bash + # run: | + # export WASMER_PATH=`pwd`/target/${{ matrix.target }}/release/wasmer${{ matrix.exe }} + # export WASMER_DIR=`pwd`/package && make test-integration-cli-ci + # env: + # TARGET: ${{ matrix.target }} + # TARGET_DIR: target/${{ matrix.target }}/release + # CARGO_TARGET: ${{ matrix.target }} + # WAPM_DEV_TOKEN: ${{ secrets.WAPM_DEV_TOKEN }} + # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} -# # ---- -# # Note (xdoardo on 2024/10/07): -# # --- -# # As of now the WAMR, WASMI (and V8) backends are not that mature enough. We will re-enable these tests -# # when they've been used and matured. -# # ---- -# # -# # - name: Test CLI integration (WAMR) -# # shell: bash -# # run: | -# # export WASMER_PATH=`pwd`/target/${{ matrix.target }}/release/wasmer${{ matrix.exe }} -# # export WASMER_DIR=`pwd`/package && make test-integration-cli-wamr-ci -# # env: -# # TARGET: ${{ matrix.target }} -# # TARGET_DIR: target/${{ matrix.target }}/release -# # CARGO_TARGET: ${{ matrix.target }} -# # WAPM_DEV_TOKEN: ${{ secrets.WAPM_DEV_TOKEN }} -# # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + # ---- + # Note (xdoardo on 2024/10/07): + # --- + # As of now the WAMR, WASMI (and V8) backends are not that mature enough. We will re-enable these tests + # when they've been used and matured. + # ---- + # + # - name: Test CLI integration (WAMR) + # shell: bash + # run: | + # export WASMER_PATH=`pwd`/target/${{ matrix.target }}/release/wasmer${{ matrix.exe }} + # export WASMER_DIR=`pwd`/package && make test-integration-cli-wamr-ci + # env: + # TARGET: ${{ matrix.target }} + # TARGET_DIR: target/${{ matrix.target }}/release + # CARGO_TARGET: ${{ matrix.target }} + # WAPM_DEV_TOKEN: ${{ secrets.WAPM_DEV_TOKEN }} + # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} -# # - name: Test CLI integration (WASMI) -# # shell: bash -# # run: | -# # export WASMER_PATH=`pwd`/target/${{ matrix.target }}/release/wasmer${{ matrix.exe }} -# # export WASMER_DIR=`pwd`/package && make test-integration-cli-wasmi-ci -# # env: -# # TARGET: ${{ matrix.target }} -# # TARGET_DIR: target/${{ matrix.target }}/release -# # CARGO_TARGET: ${{ matrix.target }} -# # WAPM_DEV_TOKEN: ${{ secrets.WAPM_DEV_TOKEN }} -# # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + # - name: Test CLI integration (WASMI) + # shell: bash + # run: | + # export WASMER_PATH=`pwd`/target/${{ matrix.target }}/release/wasmer${{ matrix.exe }} + # export WASMER_DIR=`pwd`/package && make test-integration-cli-wasmi-ci + # env: + # TARGET: ${{ matrix.target }} + # TARGET_DIR: target/${{ matrix.target }}/release + # CARGO_TARGET: ${{ matrix.target }} + # WAPM_DEV_TOKEN: ${{ secrets.WAPM_DEV_TOKEN }} + # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} -# # there is another set of integration tests in 'wasmer-integration-tests' repo. Run those -# test-wasmer-integration-tests: -# needs: [build] -# runs-on: ubuntu-22.04 -# steps: -# - name: Checkout wasmer-integration-tests repository -# uses: actions/checkout@v3 -# with: -# repository: wasmerio/wasmer-integration-tests -# submodules: true -# token: ${{ secrets.CLONE_WASMER_INTEGRATION_TESTS }} -# - uses: actions/download-artifact@v4 -# with: -# name: wasmer-cli-linux-x64 -# - name: Cargo Registry Cache -# uses: actions/cache@v3 -# with: -# path: | -# ~/.cargo/advisory-db -# ~/.cargo/git -# ~/.cargo/registry -# key: cargo-registry-${{ hashFiles('**/Cargo.lock') }} -# - name: Cargo target cache -# uses: actions/cache@v3 -# with: -# path: | -# target/ -# key: cargo-release-${{ hashFiles('**/Cargo.lock') }} -# - run: | -# # install rust toolchain -# curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y -# . "$HOME/.cargo/env" + # there is another set of integration tests in 'wasmer-integration-tests' repo. Run those + test-wasmer-integration-tests: + needs: [build] + runs-on: ubuntu-22.04 + steps: + - name: Checkout wasmer-integration-tests repository + uses: actions/checkout@v3 + with: + repository: wasmerio/wasmer-integration-tests + submodules: true + token: ${{ secrets.CLONE_WASMER_INTEGRATION_TESTS }} + - uses: actions/download-artifact@v4 + with: + name: wasmer-cli-linux-x64 + - name: Cargo Registry Cache + uses: actions/cache@v3 + with: + path: | + ~/.cargo/advisory-db + ~/.cargo/git + ~/.cargo/registry + key: cargo-registry-${{ hashFiles('**/Cargo.lock') }} + - name: Cargo target cache + uses: actions/cache@v3 + with: + path: | + target/ + key: cargo-release-${{ hashFiles('**/Cargo.lock') }} + - run: | + # install rust toolchain + curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y + . "$HOME/.cargo/env" -# # add wasmer cli to PATH -# tar -xzf build-wasmer.tar.gz + # add wasmer cli to PATH + tar -xzf build-wasmer.tar.gz -# docker build -t tmp . -# docker run -v $PWD:/app -w /app tmp bash -c " \ -# cp ./bin/wasmer /root/.wasmer/bin/wasmer &&\ -# export MYSQL_HOST='${{ vars.INTEGRATION_TEST_MYSQL_HOST }}' &&\ -# export MYSQL_DBNAME='${{ vars.INTEGRATION_TEST_MYSQL_DBNAME }}' &&\ -# export MYSQL_USERNAME='${{ secrets.INTEGRATION_TEST_MYSQL_USERNAME }}' &&\ -# export MYSQL_PASSWORD='${{ secrets.INTEGRATION_TEST_MYSQL_PASSWORD }}' &&\ -# export MYSQL_PORT='${{ vars.INTEGRATION_TEST_MYSQL_PORT }}' &&\ -# export MYSQL_CERT='${{ secrets.INTEGRATION_TEST_MYSQL_CERT }}' &&\ -# export PG_HOST='${{ vars.INTEGRATION_TEST_PG_HOST }}' &&\ -# export PG_DBNAME='${{ vars.INTEGRATION_TEST_PG_DBNAME }}' &&\ -# export PG_USERNAME='${{ secrets.INTEGRATION_TEST_PG_USERNAME }}' &&\ -# export PG_PASSWORD='${{ secrets.INTEGRATION_TEST_PG_PASSWORD }}' &&\ -# export PG_PORT='${{ vars.INTEGRATION_TEST_PG_PORT }}' &&\ -# wasmer config set registry.url https://registry.wasmer.io/graphql &&\ -# wasmer login '${{ secrets.WAPM_PROD_TOKEN }}' &&\ -# wasmer config set registry.url https://registry.wasmer.wtf/graphql &&\ -# wasmer login '${{ secrets.WAPM_DEV_TOKEN }}' &&\ -# cargo test --no-fail-fast" -# - name: notify failure in slack -# if: failure() -# run: | -# curl -X POST -H 'Content-type: application/json' --data '{"text":"Integration tests failed ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}"}' ${{ secrets.INTEGRATION_TEST_SLACK_WEBHOOK }} + docker build -t tmp . + docker run -v $PWD:/app -w /app tmp bash -c " \ + cp ./bin/wasmer /root/.wasmer/bin/wasmer &&\ + export MYSQL_HOST='${{ vars.INTEGRATION_TEST_MYSQL_HOST }}' &&\ + export MYSQL_DBNAME='${{ vars.INTEGRATION_TEST_MYSQL_DBNAME }}' &&\ + export MYSQL_USERNAME='${{ secrets.INTEGRATION_TEST_MYSQL_USERNAME }}' &&\ + export MYSQL_PASSWORD='${{ secrets.INTEGRATION_TEST_MYSQL_PASSWORD }}' &&\ + export MYSQL_PORT='${{ vars.INTEGRATION_TEST_MYSQL_PORT }}' &&\ + export MYSQL_CERT='${{ secrets.INTEGRATION_TEST_MYSQL_CERT }}' &&\ + export PG_HOST='${{ vars.INTEGRATION_TEST_PG_HOST }}' &&\ + export PG_DBNAME='${{ vars.INTEGRATION_TEST_PG_DBNAME }}' &&\ + export PG_USERNAME='${{ secrets.INTEGRATION_TEST_PG_USERNAME }}' &&\ + export PG_PASSWORD='${{ secrets.INTEGRATION_TEST_PG_PASSWORD }}' &&\ + export PG_PORT='${{ vars.INTEGRATION_TEST_PG_PORT }}' &&\ + wasmer config set registry.url https://registry.wasmer.io/graphql &&\ + wasmer login '${{ secrets.WAPM_PROD_TOKEN }}' &&\ + wasmer config set registry.url https://registry.wasmer.wtf/graphql &&\ + wasmer login '${{ secrets.WAPM_DEV_TOKEN }}' &&\ + cargo test --no-fail-fast" + - name: notify failure in slack + if: failure() + run: | + curl -X POST -H 'Content-type: application/json' --data '{"text":"Integration tests failed ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}"}' ${{ secrets.INTEGRATION_TEST_SLACK_WEBHOOK }} diff --git a/.github/workflows/wasmer-config.yaml b/.github/workflows/wasmer-config.yaml index 90a36b31efd..9091574b1e3 100644 --- a/.github/workflows/wasmer-config.yaml +++ b/.github/workflows/wasmer-config.yaml @@ -1,54 +1,54 @@ -# # Dedicated workflow just for the wasmer-config crate -# name: wasmer-config +# Dedicated workflow just for the wasmer-config crate +name: wasmer-config -# on: -# push: -# branches: -# - main -# pull_request: +on: + push: + branches: + - main + pull_request: -# # Automatically cancel previous workflow runs when a new commit is pushed. -# concurrency: -# group: ${{ github.workflow }}-${{ github.ref }} -# cancel-in-progress: true +# Automatically cancel previous workflow runs when a new commit is pushed. +concurrency: + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true -# env: -# DEFAULT_CRATE_NAME: wasmer_toml +env: + DEFAULT_CRATE_NAME: wasmer_toml -# jobs: -# check: -# name: Compile and Test -# runs-on: ubuntu-latest -# steps: -# - uses: actions/checkout@v2 -# - name: Rust Cache -# uses: Swatinem/rust-cache@v2 -# - name: Setup Rust -# uses: dsherret/rust-toolchain-file@v1 -# - name: Install Nextest -# uses: taiki-e/install-action@nextest -# - name: Type Checking -# run: | -# cd lib/config && cargo check --verbose --locked -# - name: Build -# run: | -# cd lib/config && cargo build --verbose --locked -# - name: Test -# run: | -# cd lib/config && cargo nextest run --verbose --locked +jobs: + check: + name: Compile and Test + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v2 + - name: Rust Cache + uses: Swatinem/rust-cache@v2 + - name: Setup Rust + uses: dsherret/rust-toolchain-file@v1 + - name: Install Nextest + uses: taiki-e/install-action@nextest + - name: Type Checking + run: | + cd lib/config && cargo check --verbose --locked + - name: Build + run: | + cd lib/config && cargo build --verbose --locked + - name: Test + run: | + cd lib/config && cargo nextest run --verbose --locked -# lints: -# name: Linting and Formatting -# runs-on: ubuntu-latest -# steps: -# - uses: actions/checkout@v2 -# - name: Rust Cache -# uses: Swatinem/rust-cache@v2 -# - name: Setup Rust -# uses: dsherret/rust-toolchain-file@v1 -# - name: Check Formatting -# run: | -# cd lib/config && cargo fmt --verbose --check -# - name: Clippy -# run: | -# cd lib/config && cargo clippy --verbose + lints: + name: Linting and Formatting + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v2 + - name: Rust Cache + uses: Swatinem/rust-cache@v2 + - name: Setup Rust + uses: dsherret/rust-toolchain-file@v1 + - name: Check Formatting + run: | + cd lib/config && cargo fmt --verbose --check + - name: Clippy + run: | + cd lib/config && cargo clippy --verbose diff --git a/.github/workflows/wasmer-integration-tests.yaml b/.github/workflows/wasmer-integration-tests.yaml index f06a96fd5c8..8cbf068de8f 100644 --- a/.github/workflows/wasmer-integration-tests.yaml +++ b/.github/workflows/wasmer-integration-tests.yaml @@ -1,51 +1,51 @@ -# name: test-sys +name: test-sys -# on: -# push: -# branches: -# - sre-383-re-enable-ignored-integration-test-test_php_extensions +on: + push: + branches: + - sre-383-re-enable-ignored-integration-test-test_php_extensions -# jobs: -# # there is another set of integration tests in 'wasmer-integration-tests' repo. Run those -# test-wasmer-integration-tests: -# runs-on: ubuntu-22.04 -# steps: -# - name: Checkout wasmer-integration-tests repository -# uses: actions/checkout@v3 -# with: -# repository: wasmerio/wasmer-integration-tests -# submodules: true -# token: ${{ secrets.CLONE_WASMER_INTEGRATION_TESTS }} -# - name: Cargo Registry Cache -# uses: actions/cache@v3 -# with: -# path: | -# ~/.cargo/advisory-db -# ~/.cargo/git -# ~/.cargo/registry -# key: cargo-registry-${{ hashFiles('**/Cargo.lock') }} -# - name: Cargo target cache -# uses: actions/cache@v3 -# with: -# path: | -# target/ -# key: cargo-release-${{ hashFiles('**/Cargo.lock') }} -# - run: | -# docker build -t tmp . -# docker run -v $PWD:/app -w /app tmp bash -c " \ -# export MYSQL_HOST='${{ vars.INTEGRATION_TEST_MYSQL_HOST }}' &&\ -# export MYSQL_DBNAME='${{ vars.INTEGRATION_TEST_MYSQL_DBNAME }}' &&\ -# export MYSQL_USERNAME='${{ secrets.INTEGRATION_TEST_MYSQL_USERNAME }}' &&\ -# export MYSQL_PASSWORD='${{ secrets.INTEGRATION_TEST_MYSQL_PASSWORD }}' &&\ -# export MYSQL_PORT='${{ vars.INTEGRATION_TEST_MYSQL_PORT }}' &&\ -# export MYSQL_CERT='${{ secrets.INTEGRATION_TEST_MYSQL_CERT }}' &&\ -# export PG_HOST='${{ vars.INTEGRATION_TEST_PG_HOST }}' &&\ -# export PG_DBNAME='${{ vars.INTEGRATION_TEST_PG_DBNAME }}' &&\ -# export PG_USERNAME='${{ secrets.INTEGRATION_TEST_PG_USERNAME }}' &&\ -# export PG_PASSWORD='${{ secrets.INTEGRATION_TEST_PG_PASSWORD }}' &&\ -# export PG_PORT='${{ vars.INTEGRATION_TEST_PG_PORT }}' &&\ -# wasmer config set registry.url https://registry.wasmer.io/graphql &&\ -# wasmer login ${{ secrets.WAPM_PROD_TOKEN }} &&\ -# wasmer config set registry.url https://registry.wasmer.wtf/graphql &&\ -# wasmer login ${{ secrets.WAPM_DEV_TOKEN }} &&\ -# cargo test --no-fail-fast" \ No newline at end of file +jobs: + # there is another set of integration tests in 'wasmer-integration-tests' repo. Run those + test-wasmer-integration-tests: + runs-on: ubuntu-22.04 + steps: + - name: Checkout wasmer-integration-tests repository + uses: actions/checkout@v3 + with: + repository: wasmerio/wasmer-integration-tests + submodules: true + token: ${{ secrets.CLONE_WASMER_INTEGRATION_TESTS }} + - name: Cargo Registry Cache + uses: actions/cache@v3 + with: + path: | + ~/.cargo/advisory-db + ~/.cargo/git + ~/.cargo/registry + key: cargo-registry-${{ hashFiles('**/Cargo.lock') }} + - name: Cargo target cache + uses: actions/cache@v3 + with: + path: | + target/ + key: cargo-release-${{ hashFiles('**/Cargo.lock') }} + - run: | + docker build -t tmp . + docker run -v $PWD:/app -w /app tmp bash -c " \ + export MYSQL_HOST='${{ vars.INTEGRATION_TEST_MYSQL_HOST }}' &&\ + export MYSQL_DBNAME='${{ vars.INTEGRATION_TEST_MYSQL_DBNAME }}' &&\ + export MYSQL_USERNAME='${{ secrets.INTEGRATION_TEST_MYSQL_USERNAME }}' &&\ + export MYSQL_PASSWORD='${{ secrets.INTEGRATION_TEST_MYSQL_PASSWORD }}' &&\ + export MYSQL_PORT='${{ vars.INTEGRATION_TEST_MYSQL_PORT }}' &&\ + export MYSQL_CERT='${{ secrets.INTEGRATION_TEST_MYSQL_CERT }}' &&\ + export PG_HOST='${{ vars.INTEGRATION_TEST_PG_HOST }}' &&\ + export PG_DBNAME='${{ vars.INTEGRATION_TEST_PG_DBNAME }}' &&\ + export PG_USERNAME='${{ secrets.INTEGRATION_TEST_PG_USERNAME }}' &&\ + export PG_PASSWORD='${{ secrets.INTEGRATION_TEST_PG_PASSWORD }}' &&\ + export PG_PORT='${{ vars.INTEGRATION_TEST_PG_PORT }}' &&\ + wasmer config set registry.url https://registry.wasmer.io/graphql &&\ + wasmer login ${{ secrets.WAPM_PROD_TOKEN }} &&\ + wasmer config set registry.url https://registry.wasmer.wtf/graphql &&\ + wasmer login ${{ secrets.WAPM_DEV_TOKEN }} &&\ + cargo test --no-fail-fast" From ab0f3d3d27221dc59f5c41ed3f77d3624ea0e7d4 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Mon, 21 Oct 2024 12:39:03 +0330 Subject: [PATCH 51/59] disable riscv and aarch64 on Linux as requirements for release --- .github/workflows/build.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 523846c70d4..08760131562 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -653,7 +653,8 @@ jobs: retention-days: 2 release: - needs: [setup, build, linux_aarch64, windows_gnu, linux_riscv64] + # needs: [setup, build, linux_aarch64, windows_gnu, linux_riscv64] + needs: [setup, build, windows_gnu] runs-on: ubuntu-latest if: needs.setup.outputs.DOING_RELEASE == '1' || github.event.inputs.release != '' steps: From fb537fd89c535f25995fb49218250f6e916cf6ec Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Mon, 21 Oct 2024 12:47:52 +0330 Subject: [PATCH 52/59] disable asset upload for riscv and aarch64 --- .github/workflows/build.yml | 36 ++++++++++++++++++------------------ 1 file changed, 18 insertions(+), 18 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 08760131562..d493f7e8b28 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -753,24 +753,24 @@ jobs: asset_path: artifacts/wasmer-wasmi-linux-amd64/wasmer.tar.gz asset_name: wasmer-wasmi-linux-amd64.tar.gz asset_content_type: application/gzip - - name: Upload Release Asset Linux aarch64 - uses: actions/upload-release-asset@v1 - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - with: - upload_url: ${{ steps.create_release.outputs.upload_url }} - asset_path: artifacts/wasmer-linux-aarch64/wasmer.tar.gz - asset_name: wasmer-linux-aarch64.tar.gz - asset_content_type: application/gzip - - name: Upload Release Asset Linux riscv64 - uses: actions/upload-release-asset@v1 - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - with: - upload_url: ${{ steps.create_release.outputs.upload_url }} - asset_path: artifacts/wasmer-linux-riscv64/wasmer.tar.gz - asset_name: wasmer-linux-riscv64.tar.gz - asset_content_type: application/gzip + # - name: Upload Release Asset Linux aarch64 + # uses: actions/upload-release-asset@v1 + # env: + # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + # with: + # upload_url: ${{ steps.create_release.outputs.upload_url }} + # asset_path: artifacts/wasmer-linux-aarch64/wasmer.tar.gz + # asset_name: wasmer-linux-aarch64.tar.gz + # asset_content_type: application/gzip + # - name: Upload Release Asset Linux riscv64 + # uses: actions/upload-release-asset@v1 + # env: + # GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + # with: + # upload_url: ${{ steps.create_release.outputs.upload_url }} + # asset_path: artifacts/wasmer-linux-riscv64/wasmer.tar.gz + # asset_name: wasmer-linux-riscv64.tar.gz + # asset_content_type: application/gzip - name: Upload Release Asset Windows gnu64 uses: actions/upload-release-asset@v1 env: From 43ce44697c542c73136b2ccb0bba96c7b44b4899 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Mon, 21 Oct 2024 13:13:43 +0330 Subject: [PATCH 53/59] fix artifact missing on macos-arm --- .github/workflows/test.yaml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/test.yaml b/.github/workflows/test.yaml index ddffe58f499..112367d6beb 100644 --- a/.github/workflows/test.yaml +++ b/.github/workflows/test.yaml @@ -759,7 +759,7 @@ jobs: }, { - build: macos-arm64, + build: macos-arm, os: macos-14, target: aarch64-apple-darwin, exe: '', @@ -890,7 +890,7 @@ jobs: os: macos-12 target: x86_64-apple-darwin # we only build the integration-test CLI, we don't run tests - - build: macos-arm64 + - build: macos-arm os: macos-12 target: aarch64-apple-darwin, - build: linux-musl @@ -999,7 +999,7 @@ jobs: name: capi-linux-musl path: download_link - uses: actions/download-artifact@v4 - if: ${{ matrix.build == 'macos-arm64' }} + if: ${{ matrix.build == 'macos-arm' }} with: name: capi-macos-arm path: download_link From c42e76684646d6e9e274dcd04f2a4e9719450b58 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Mon, 21 Oct 2024 13:50:15 +0330 Subject: [PATCH 54/59] Update CHANGELOG --- CHANGELOG.md | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 5f57062ecb2..846e850bcce 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -9,6 +9,37 @@ Looking for changes that affect our C API? See the [C API Changelog](lib/c-api/C ## **Unreleased** +## 5.0.0-rc.1 - 21/10/2024 + +## Added + + - [#5154](https://github.com/wasmerio/wasmer/pull/5154) Add build steps for interpreter backends + - [#5138](https://github.com/wasmerio/wasmer/pull/5138) Experimental: Add support for v8 + - [#5129](https://github.com/wasmerio/wasmer/pull/5129) Experimental: Add support for WASMI + - [#4515](https://github.com/wasmerio/wasmer/pull/4515) Experimental: Add interpreter support for Wasmer + +## Changed + + - [#5158](https://github.com/wasmerio/wasmer/pull/5158) path_create_directory shouldn't behave recursively + - [#5156](https://github.com/wasmerio/wasmer/pull/5156) Resolve double-free error in c-api + - [#5149](https://github.com/wasmerio/wasmer/pull/5149) Merge 5.0 release candidate into main + - [#5148](https://github.com/wasmerio/wasmer/pull/5148) Remove deprecated methods and types + - [#5147](https://github.com/wasmerio/wasmer/pull/5147) Feat(compiler/llvm): Replace runtime assertions (in debug mode) with errors + - [#5146](https://github.com/wasmerio/wasmer/pull/5146) feat(api/build/v8): Use blob to build v8 + - [#5142](https://github.com/wasmerio/wasmer/pull/5142) Upgrade `rkyv` + - [#5098](https://github.com/wasmerio/wasmer/pull/5098) `js::module`: leave warning comment on the `Send` impl + - [#5139](https://github.com/wasmerio/wasmer/pull/5139) deps: Update corosensei + - [#5136](https://github.com/wasmerio/wasmer/pull/5136) Replace v3 usage of download-artifact + - [#5135](https://github.com/wasmerio/wasmer/pull/5135) Use upload/download artifact v4 + +## Fixed + + - [#4834](https://github.com/wasmerio/wasmer/pull/4834) Fix `path_open` trailing slash edge case + - [#4821](https://github.com/wasmerio/wasmer/pull/4821) Fix `path_open` sometimes ignoring trailing slash + - [#5137](https://github.com/wasmerio/wasmer/pull/5137) Trying to fix js build + + + ## 4.4.0 - 04/10/2024 This release adds support for object size estimation, adds better proxy support, improves executable spawning, and contains various bug fixes. From 193cba137952996bcdee7a685ea697d1b0e9dfe3 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Mon, 21 Oct 2024 13:50:15 +0330 Subject: [PATCH 55/59] Release 5.0.0-rc.1 --- Cargo.toml | 26 +++++++++---------- lib/api/Cargo.toml | 22 ++++++++-------- .../macro-wasmer-universal-test/Cargo.toml | 2 +- lib/c-api/Cargo.toml | 16 ++++++------ .../wasmer-capi-examples-runner/Cargo.toml | 2 +- .../tests/wasmer-c-api-test-runner/Cargo.toml | 2 +- lib/cache/Cargo.toml | 6 ++--- lib/cli-compiler/Cargo.toml | 16 ++++++------ lib/cli/Cargo.toml | 24 ++++++++--------- lib/compiler-cranelift/Cargo.toml | 4 +-- lib/compiler-llvm/Cargo.toml | 6 ++--- lib/compiler-singlepass/Cargo.toml | 4 +-- lib/compiler/Cargo.toml | 6 ++--- lib/emscripten/Cargo.toml | 4 +-- lib/journal/Cargo.toml | 2 +- lib/middlewares/Cargo.toml | 8 +++--- lib/object/Cargo.toml | 2 +- lib/registry/Cargo.toml | 4 +-- lib/swift/Cargo.toml | 2 +- lib/sys-utils/Cargo.toml | 8 +++--- lib/vm/Cargo.toml | 2 +- lib/wai-bindgen-wasmer/Cargo.toml | 2 +- lib/wasi-types/Cargo.toml | 6 ++--- lib/wasix/Cargo.toml | 10 +++---- scripts/update-version.py | 4 +-- scripts/windows-installer/wasmer.iss | 2 +- tests/integration/cli/Cargo.toml | 2 +- tests/integration/ios/Cargo.toml | 2 +- tests/lib/wast/Cargo.toml | 4 +-- tests/wasi-wast/Cargo.toml | 2 +- tests/wasmer-argus/Cargo.toml | 2 +- 31 files changed, 102 insertions(+), 102 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 845f00f316e..d8f9d4ac0b9 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -12,20 +12,20 @@ rust-version.workspace = true version.workspace = true [dependencies] -wasmer = { version = "=4.4.0", path = "lib/api", default-features = false } -wasmer-compiler = { version = "=4.4.0", path = "lib/compiler", features = [ +wasmer = { version = "=5.0.0-rc.1", path = "lib/api", default-features = false } +wasmer-compiler = { version = "=5.0.0-rc.1", path = "lib/compiler", features = [ "compiler", ], optional = true } -wasmer-compiler-cranelift = { version = "=4.4.0", path = "lib/compiler-cranelift", optional = true } -wasmer-compiler-singlepass = { version = "=4.4.0", path = "lib/compiler-singlepass", optional = true } -wasmer-compiler-llvm = { version = "=4.4.0", path = "lib/compiler-llvm", optional = true } -wasmer-emscripten = { version = "=4.4.0", path = "lib/emscripten", optional = true } +wasmer-compiler-cranelift = { version = "=5.0.0-rc.1", path = "lib/compiler-cranelift", optional = true } +wasmer-compiler-singlepass = { version = "=5.0.0-rc.1", path = "lib/compiler-singlepass", optional = true } +wasmer-compiler-llvm = { version = "=5.0.0-rc.1", path = "lib/compiler-llvm", optional = true } +wasmer-emscripten = { version = "=5.0.0-rc.1", path = "lib/emscripten", optional = true } wasmer-wasix = { path = "lib/wasix", optional = true } -wasmer-wast = { version = "=4.4.0", path = "tests/lib/wast", optional = true } -wasi-test-generator = { version = "=4.4.0", path = "tests/wasi-wast", optional = true } -wasmer-cache = { version = "=4.4.0", path = "lib/cache", optional = true } -wasmer-types = { version = "=4.4.0", path = "lib/types" } -wasmer-middlewares = { version = "=4.4.0", path = "lib/middlewares", optional = true } +wasmer-wast = { version = "=5.0.0-rc.1", path = "tests/lib/wast", optional = true } +wasi-test-generator = { version = "=5.0.0-rc.1", path = "tests/wasi-wast", optional = true } +wasmer-cache = { version = "=5.0.0-rc.1", path = "lib/cache", optional = true } +wasmer-types = { version = "=5.0.0-rc.1", path = "lib/types" } +wasmer-middlewares = { version = "=5.0.0-rc.1", path = "lib/middlewares", optional = true } # Third party dependencies cfg-if = "1.0" @@ -89,7 +89,7 @@ homepage = "https://wasmer.io/" license = "MIT" repository = "https://github.com/wasmerio/wasmer" rust-version = "1.74" -version = "4.4.0" +version = "5.0.0-rc.1" [workspace.dependencies] # Repo-local crates @@ -133,7 +133,7 @@ glob = "0.3" rustc_version = "0.4" [dev-dependencies] -wasmer = { version = "=4.4.0", path = "lib/api", features = [ +wasmer = { version = "=5.0.0-rc.1", path = "lib/api", features = [ "compiler", "singlepass", "sys", diff --git a/lib/api/Cargo.toml b/lib/api/Cargo.toml index 65d3f600a6c..59173c75ca7 100644 --- a/lib/api/Cargo.toml +++ b/lib/api/Cargo.toml @@ -51,15 +51,15 @@ loupe = { version = "0.1.3", optional = true, features = [ # Dependencies and Development Dependencies for `sys`. [target.'cfg(not(target_arch = "wasm32"))'.dependencies] # - Mandatory dependencies for `sys`. -wasmer-vm = { path = "../vm", version = "=4.4.0" } -wasmer-compiler = { path = "../compiler", version = "=4.4.0" } -wasmer-derive = { path = "../derive", version = "=4.4.0" } -wasmer-types = { path = "../types", version = "=4.4.0" } +wasmer-vm = { path = "../vm", version = "=5.0.0-rc.1" } +wasmer-compiler = { path = "../compiler", version = "=5.0.0-rc.1" } +wasmer-derive = { path = "../derive", version = "=5.0.0-rc.1" } +wasmer-types = { path = "../types", version = "=5.0.0-rc.1" } target-lexicon = { version = "0.12.2", default-features = false } # - Optional dependencies for `sys`. -wasmer-compiler-singlepass = { path = "../compiler-singlepass", version = "=4.4.0", optional = true } -wasmer-compiler-cranelift = { path = "../compiler-cranelift", version = "=4.4.0", optional = true } -wasmer-compiler-llvm = { path = "../compiler-llvm", version = "=4.4.0", optional = true } +wasmer-compiler-singlepass = { path = "../compiler-singlepass", version = "=5.0.0-rc.1", optional = true } +wasmer-compiler-cranelift = { path = "../compiler-cranelift", version = "=5.0.0-rc.1", optional = true } +wasmer-compiler-llvm = { path = "../compiler-llvm", version = "=5.0.0-rc.1", optional = true } wasm-bindgen = { version = "0.2.74", optional = true } js-sys = { version = "0.3.51", optional = true } @@ -74,17 +74,17 @@ windows-sys = "0.59" wat = "1.0" tempfile = "3.6.0" anyhow = "1.0" -macro-wasmer-universal-test = { version = "4.4.0", path = "./macro-wasmer-universal-test" } +macro-wasmer-universal-test = { version = "5.0.0-rc.1", path = "./macro-wasmer-universal-test" } # Dependencies and Develoment Dependencies for `js`. [target.'cfg(target_arch = "wasm32")'.dependencies] # - Mandatory dependencies for `js`. -wasmer-types = { path = "../types", version = "=4.4.0", default-features = false, features = [ +wasmer-types = { path = "../types", version = "=5.0.0-rc.1", default-features = false, features = [ "std", ] } wasm-bindgen = "0.2.74" js-sys = "0.3.51" -wasmer-derive = { path = "../derive", version = "=4.4.0" } +wasmer-derive = { path = "../derive", version = "=5.0.0-rc.1" } # - Optional dependencies for `js`. wasmparser = { workspace = true, default-features = false, optional = true } hashbrown = { version = "0.11", optional = true } @@ -96,7 +96,7 @@ serde = { version = "1.0", features = ["derive"] } wat = "1.0" anyhow = "1.0" wasm-bindgen-test = "0.3.0" -macro-wasmer-universal-test = { version = "4.4.0", path = "./macro-wasmer-universal-test" } +macro-wasmer-universal-test = { version = "5.0.0-rc.1", path = "./macro-wasmer-universal-test" } # Specific to `js`. # diff --git a/lib/api/macro-wasmer-universal-test/Cargo.toml b/lib/api/macro-wasmer-universal-test/Cargo.toml index 2156a5c6b42..2a856b4eb82 100644 --- a/lib/api/macro-wasmer-universal-test/Cargo.toml +++ b/lib/api/macro-wasmer-universal-test/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "macro-wasmer-universal-test" -version = "4.4.0" +version = "5.0.0-rc.1" edition = "2021" license = "MIT" description = "Universal test macro for wasmer-test" diff --git a/lib/c-api/Cargo.toml b/lib/c-api/Cargo.toml index ade9ac88870..a2e18914eac 100644 --- a/lib/c-api/Cargo.toml +++ b/lib/c-api/Cargo.toml @@ -24,14 +24,14 @@ crate-type = ["staticlib", "cdylib"] #"cdylib", "rlib", "staticlib"] [dependencies] # We rename `wasmer` to `wasmer-api` to avoid the conflict with this # library name (see `[lib]`). -wasmer-api = { version = "=4.4.0", path = "../api", default-features = false, package = "wasmer" } -wasmer-compiler = { version = "=4.4.0", path = "../compiler", optional = true } -wasmer-compiler-cranelift = { version = "=4.4.0", path = "../compiler-cranelift", optional = true } -wasmer-compiler-llvm = { version = "=4.4.0", path = "../compiler-llvm", optional = true } -wasmer-compiler-singlepass = { version = "=4.4.0", path = "../compiler-singlepass", optional = true } -wasmer-emscripten = { version = "=4.4.0", path = "../emscripten", optional = true } -wasmer-middlewares = { version = "=4.4.0", path = "../middlewares", optional = true } -wasmer-types = { version = "=4.4.0", path = "../types" } +wasmer-api = { version = "=5.0.0-rc.1", path = "../api", default-features = false, package = "wasmer" } +wasmer-compiler = { version = "=5.0.0-rc.1", path = "../compiler", optional = true } +wasmer-compiler-cranelift = { version = "=5.0.0-rc.1", path = "../compiler-cranelift", optional = true } +wasmer-compiler-llvm = { version = "=5.0.0-rc.1", path = "../compiler-llvm", optional = true } +wasmer-compiler-singlepass = { version = "=5.0.0-rc.1", path = "../compiler-singlepass", optional = true } +wasmer-emscripten = { version = "=5.0.0-rc.1", path = "../emscripten", optional = true } +wasmer-middlewares = { version = "=5.0.0-rc.1", path = "../middlewares", optional = true } +wasmer-types = { version = "=5.0.0-rc.1", path = "../types" } wasmer-wasix = { path = "../wasix", version="=0.28.0", features = ["host-fs", "host-vnet"], optional = true } webc = { workspace = true, optional = true } virtual-fs = { version = "0.17.0", path = "../virtual-fs", optional = true, default-features = false, features = ["static-fs"] } diff --git a/lib/c-api/examples/wasmer-capi-examples-runner/Cargo.toml b/lib/c-api/examples/wasmer-capi-examples-runner/Cargo.toml index 7d57dcda0a9..96d7c9f8810 100644 --- a/lib/c-api/examples/wasmer-capi-examples-runner/Cargo.toml +++ b/lib/c-api/examples/wasmer-capi-examples-runner/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "wasmer-capi-examples-runner" -version = "4.4.0" +version = "5.0.0-rc.1" edition = "2021" license = "MIT" description = "wasmer-capi-examples-runner" diff --git a/lib/c-api/tests/wasmer-c-api-test-runner/Cargo.toml b/lib/c-api/tests/wasmer-c-api-test-runner/Cargo.toml index 3bce6d91005..64336f11f4c 100644 --- a/lib/c-api/tests/wasmer-c-api-test-runner/Cargo.toml +++ b/lib/c-api/tests/wasmer-c-api-test-runner/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "wasmer-c-api-test-runner" -version = "4.4.0" +version = "5.0.0-rc.1" edition = "2021" license = "MIT" description = "wasmer-c-api-test-runner" diff --git a/lib/cache/Cargo.toml b/lib/cache/Cargo.toml index 37d553879b9..9c696e59033 100644 --- a/lib/cache/Cargo.toml +++ b/lib/cache/Cargo.toml @@ -13,7 +13,7 @@ rust-version.workspace = true version.workspace = true [dependencies] -wasmer = { path = "../api", version = "=4.4.0", default-features = false } +wasmer = { path = "../api", version = "=5.0.0-rc.1", default-features = false } hex = "0.4" thiserror = "1" blake3 = "1.0" @@ -26,8 +26,8 @@ clap_derive = { version = "=4.4.7" } clap_lex = { version = "=0.6.0" } tempfile = "3.6.0" rand = "0.8.3" -wasmer = { path = "../api", version = "=4.4.0", default-features = false, features = ["sys", "cranelift"] } -wasmer-compiler-singlepass = { path = "../compiler-singlepass", version = "=4.4.0" } +wasmer = { path = "../api", version = "=5.0.0-rc.1", default-features = false, features = ["sys", "cranelift"] } +wasmer-compiler-singlepass = { path = "../compiler-singlepass", version = "=5.0.0-rc.1" } [features] default = ["filesystem"] diff --git a/lib/cli-compiler/Cargo.toml b/lib/cli-compiler/Cargo.toml index b540288180d..9a40b9a13fc 100644 --- a/lib/cli-compiler/Cargo.toml +++ b/lib/cli-compiler/Cargo.toml @@ -20,8 +20,8 @@ path = "src/bin/wasmer_compiler.rs" doc = false [dependencies] -wasmer-compiler = { version = "=4.4.0", path = "../compiler", features = ["compiler"] } -wasmer-types = { version = "=4.4.0", path = "../types" } +wasmer-compiler = { version = "=5.0.0-rc.1", path = "../compiler", features = ["compiler"] } +wasmer-types = { version = "=5.0.0-rc.1", path = "../types" } is-terminal = "0.4.7" colored = "2.0" anyhow = "1.0" @@ -36,16 +36,16 @@ log = { version = "0.4", optional = true } target-lexicon = { version = "0.12", features = ["std"] } [target.'cfg(not(target_arch = "wasm32"))'.dependencies] -wasmer-compiler-singlepass = { version = "=4.4.0", path = "../compiler-singlepass", optional = true } -wasmer-compiler-cranelift = { version = "=4.4.0", path = "../compiler-cranelift", optional = true } -clap = { version = "4.4.0", features = ["derive", "env"] } +wasmer-compiler-singlepass = { version = "=5.0.0-rc.1", path = "../compiler-singlepass", optional = true } +wasmer-compiler-cranelift = { version = "=5.0.0-rc.1", path = "../compiler-cranelift", optional = true } +clap = { version = "5.0.0-rc.1", features = ["derive", "env"] } [target.'cfg(target_arch = "wasm32")'.dependencies] -wasmer-compiler-singlepass = { version = "=4.4.0", path = "../compiler-singlepass", optional = true, default-features = false, features = ["wasm"] } -wasmer-compiler-cranelift = { version = "=4.4.0", path = "../compiler-cranelift", optional = true, default-features = false, features = ["wasm"] } +wasmer-compiler-singlepass = { version = "=5.0.0-rc.1", path = "../compiler-singlepass", optional = true, default-features = false, features = ["wasm"] } +wasmer-compiler-cranelift = { version = "=5.0.0-rc.1", path = "../compiler-cranelift", optional = true, default-features = false, features = ["wasm"] } # NOTE: Must use different features for clap because the "color" feature does not # work on wasi, due to the anstream dependency not compiling. -clap = { version = "4.4.0", default-features = false, features = [ +clap = { version = "5.0.0-rc.1", default-features = false, features = [ "std", "help", "usage", diff --git a/lib/cli/Cargo.toml b/lib/cli/Cargo.toml index 76e67809a81..07d4fe642f0 100644 --- a/lib/cli/Cargo.toml +++ b/lib/cli/Cargo.toml @@ -111,17 +111,17 @@ enable-serde = [ [dependencies] # Repo-local dependencies. -wasmer = { version = "=4.4.0", path = "../api", default-features = false } -wasmer-compiler = { version = "=4.4.0", path = "../compiler", features = [ +wasmer = { version = "=5.0.0-rc.1", path = "../api", default-features = false } +wasmer-compiler = { version = "=5.0.0-rc.1", path = "../compiler", features = [ "compiler", ], optional = true } -wasmer-compiler-cranelift = { version = "=4.4.0", path = "../compiler-cranelift", optional = true } -wasmer-compiler-singlepass = { version = "=4.4.0", path = "../compiler-singlepass", optional = true } -wasmer-compiler-llvm = { version = "=4.4.0", path = "../compiler-llvm", optional = true } -wasmer-emscripten = { version = "=4.4.0", path = "../emscripten" } +wasmer-compiler-cranelift = { version = "=5.0.0-rc.1", path = "../compiler-cranelift", optional = true } +wasmer-compiler-singlepass = { version = "=5.0.0-rc.1", path = "../compiler-singlepass", optional = true } +wasmer-compiler-llvm = { version = "=5.0.0-rc.1", path = "../compiler-llvm", optional = true } +wasmer-emscripten = { version = "=5.0.0-rc.1", path = "../emscripten" } wasmer-package = { version = "=0.1.0", path = "../package" } -wasmer-vm = { version = "=4.4.0", path = "../vm", optional = true } +wasmer-vm = { version = "=5.0.0-rc.1", path = "../vm", optional = true } wasmer-wasix = { path = "../wasix", version = "=0.28.0", features = [ "logging", "webc_runner_rt_wcgi", @@ -131,15 +131,15 @@ wasmer-wasix = { path = "../wasix", version = "=0.28.0", features = [ "host-fs", "ctrlc", ] } -wasmer-wast = { version = "=4.4.0", path = "../../tests/lib/wast", optional = true } -wasmer-types = { version = "=4.4.0", path = "../types", features = [ +wasmer-wast = { version = "=5.0.0-rc.1", path = "../../tests/lib/wast", optional = true } +wasmer-types = { version = "=5.0.0-rc.1", path = "../types", features = [ "enable-serde", ] } wasmer-registry = { version = "=5.20.0", path = "../registry", features = [ "build-package", "clap", ] } -wasmer-object = { version = "=4.4.0", path = "../object", optional = true } +wasmer-object = { version = "=5.0.0-rc.1", path = "../object", optional = true } virtual-fs = { version = "0.17.0", path = "../virtual-fs", default-features = false, features = [ "host-fs", ] } @@ -240,9 +240,9 @@ dotenvy = "0.15.7" # NOTE: Must use different features for clap because the "color" feature does not # work on wasi due to the anstream dependency not compiling. [target.'cfg(not(target_family = "wasm"))'.dependencies] -clap = { version = "4.4.0", features = ["derive", "env"] } +clap = { version = "5.0.0-rc.1", features = ["derive", "env"] } [target.'cfg(target_family = "wasm")'.dependencies] -clap = { version = "4.4.0", default-features = false, features = [ +clap = { version = "5.0.0-rc.1", default-features = false, features = [ "std", "help", "usage", diff --git a/lib/compiler-cranelift/Cargo.toml b/lib/compiler-cranelift/Cargo.toml index 81c128f205b..19c04ee925a 100644 --- a/lib/compiler-cranelift/Cargo.toml +++ b/lib/compiler-cranelift/Cargo.toml @@ -14,11 +14,11 @@ rust-version.workspace = true version.workspace = true [dependencies] -wasmer-compiler = { path = "../compiler", version = "=4.4.0", features = [ +wasmer-compiler = { path = "../compiler", version = "=5.0.0-rc.1", features = [ "translator", "compiler", ], default-features = false } -wasmer-types = { path = "../types", version = "=4.4.0", default-features = false, features = [ +wasmer-types = { path = "../types", version = "=5.0.0-rc.1", default-features = false, features = [ "std", ] } cranelift-entity = { version = "=0.110.2", default-features = false } diff --git a/lib/compiler-llvm/Cargo.toml b/lib/compiler-llvm/Cargo.toml index db6eb865254..98a1e84ac48 100644 --- a/lib/compiler-llvm/Cargo.toml +++ b/lib/compiler-llvm/Cargo.toml @@ -14,11 +14,11 @@ rust-version.workspace = true version.workspace = true [dependencies] -wasmer-compiler = { path = "../compiler", version = "=4.4.0", features = [ +wasmer-compiler = { path = "../compiler", version = "=5.0.0-rc.1", features = [ "translator", "compiler" ] } -wasmer-vm = { path = "../vm", version = "=4.4.0" } -wasmer-types = { path = "../types", version = "=4.4.0" } +wasmer-vm = { path = "../vm", version = "=5.0.0-rc.1" } +wasmer-types = { path = "../types", version = "=5.0.0-rc.1" } target-lexicon = { version = "0.12.2", default-features = false } smallvec = "1.6" object = { version = "0.28.3", default-features = false, features = ["read"] } diff --git a/lib/compiler-singlepass/Cargo.toml b/lib/compiler-singlepass/Cargo.toml index 528c510af8d..499e31747a7 100644 --- a/lib/compiler-singlepass/Cargo.toml +++ b/lib/compiler-singlepass/Cargo.toml @@ -14,8 +14,8 @@ rust-version.workspace = true version.workspace = true [dependencies] -wasmer-compiler = { path = "../compiler", version = "=4.4.0", features = ["translator", "compiler"], default-features = false } -wasmer-types = { path = "../types", version = "=4.4.0", default-features = false, features = ["std"] } +wasmer-compiler = { path = "../compiler", version = "=5.0.0-rc.1", features = ["translator", "compiler"], default-features = false } +wasmer-types = { path = "../types", version = "=5.0.0-rc.1", default-features = false, features = ["std"] } hashbrown = { version = "0.11", optional = true } gimli = { workspace = true, optional = true } enumset.workspace = true diff --git a/lib/compiler/Cargo.toml b/lib/compiler/Cargo.toml index a5561f4334c..f5d68578125 100644 --- a/lib/compiler/Cargo.toml +++ b/lib/compiler/Cargo.toml @@ -13,8 +13,8 @@ rust-version.workspace = true version.workspace = true [dependencies] -wasmer-types = { path = "../types", version = "=4.4.0", default-features = false } -wasmer-object = { path = "../object", version = "=4.4.0", optional = true } +wasmer-types = { path = "../types", version = "=5.0.0-rc.1", default-features = false } +wasmer-object = { path = "../object", version = "=5.0.0-rc.1", optional = true } wasmparser = { workspace = true, optional = true, default-features = false } enumset.workspace = true hashbrown = { version = "0.11", optional = true } @@ -45,7 +45,7 @@ shared-buffer = { workspace = true } libc.workspace = true [target.'cfg(not(target_arch = "wasm32"))'.dependencies] -wasmer-vm = { path = "../vm", version = "=4.4.0" } +wasmer-vm = { path = "../vm", version = "=5.0.0-rc.1" } region = { version = "3.0" } [target.'cfg(target_os = "windows")'.dependencies] diff --git a/lib/emscripten/Cargo.toml b/lib/emscripten/Cargo.toml index c0b8cf4dca2..57dcd953937 100644 --- a/lib/emscripten/Cargo.toml +++ b/lib/emscripten/Cargo.toml @@ -18,8 +18,8 @@ lazy_static = "1.4" libc = { workspace = true, default-features = true } log = "0.4" time = { version = "0.3", features = ["std", "formatting"] } -wasmer = { path = "../api", version = "=4.4.0", default-features = false } -wasmer-types = { path = "../types", version = "=4.4.0" } +wasmer = { path = "../api", version = "=5.0.0-rc.1", default-features = false } +wasmer-types = { path = "../types", version = "=5.0.0-rc.1" } [target.'cfg(windows)'.dependencies] getrandom = "0.2" diff --git a/lib/journal/Cargo.toml b/lib/journal/Cargo.toml index 57da03c541a..802241b14b3 100644 --- a/lib/journal/Cargo.toml +++ b/lib/journal/Cargo.toml @@ -14,7 +14,7 @@ default = ["log-file", "wasmer/sys"] log-file = ["shared-buffer"] [dependencies] -wasmer = { default-features = false, path = "../api", version = "=4.4.0" } +wasmer = { default-features = false, path = "../api", version = "=5.0.0-rc.1" } wasmer-wasix-types = { path = "../wasi-types", version = "0.28.0", features = [ "enable-serde", ] } diff --git a/lib/middlewares/Cargo.toml b/lib/middlewares/Cargo.toml index 3e66a888b4f..1256a88a314 100644 --- a/lib/middlewares/Cargo.toml +++ b/lib/middlewares/Cargo.toml @@ -13,12 +13,12 @@ rust-version.workspace = true version.workspace = true [dependencies] -wasmer = { path = "../api", version = "=4.4.0", default-features = false, features = ["compiler"] } -wasmer-types = { path = "../types", version = "=4.4.0" } -wasmer-vm = { path = "../vm", version = "=4.4.0" } +wasmer = { path = "../api", version = "=5.0.0-rc.1", default-features = false, features = ["compiler"] } +wasmer-types = { path = "../types", version = "=5.0.0-rc.1" } +wasmer-vm = { path = "../vm", version = "=5.0.0-rc.1" } [dev-dependencies] -wasmer = { path = "../api", version = "=4.4.0", features = ["compiler"] } +wasmer = { path = "../api", version = "=5.0.0-rc.1", features = ["compiler"] } [badges] maintenance = { status = "actively-developed" } diff --git a/lib/object/Cargo.toml b/lib/object/Cargo.toml index befb66441bd..5500d84dc61 100644 --- a/lib/object/Cargo.toml +++ b/lib/object/Cargo.toml @@ -13,7 +13,7 @@ rust-version.workspace = true version.workspace = true [dependencies] -wasmer-types = { path = "../types", version = "=4.4.0" } +wasmer-types = { path = "../types", version = "=5.0.0-rc.1" } object = { version = "0.29.0", default-features = false, features = ["write"] } thiserror = "1.0" diff --git a/lib/registry/Cargo.toml b/lib/registry/Cargo.toml index 2df12235a63..f39cb1154f1 100644 --- a/lib/registry/Cargo.toml +++ b/lib/registry/Cargo.toml @@ -23,7 +23,7 @@ full = [] [dependencies] anyhow = "1.0.65" -clap = { version = "4.4.0", default-features = false, features = [ +clap = { version = "5.0.0-rc.1", default-features = false, features = [ "derive", "env", ], optional = true } @@ -74,7 +74,7 @@ toml.workspace = true tracing = "0.1.40" url = "2.5.0" wasmer-config = { version = "0.9.0", path = "../config" } -wasmer-wasm-interface = { version = "4.4.0", path = "../wasm-interface", optional = true } +wasmer-wasm-interface = { version = "5.0.0-rc.1", path = "../wasm-interface", optional = true } wasmparser = { workspace = true, optional = true } whoami = "1.2.3" webc.workspace = true diff --git a/lib/swift/Cargo.toml b/lib/swift/Cargo.toml index 9d37efbf4c0..6870c1ae390 100644 --- a/lib/swift/Cargo.toml +++ b/lib/swift/Cargo.toml @@ -16,7 +16,7 @@ uniffi = "0.27" virtual-fs = { path = "../virtual-fs", version = "0.17.0", default-features = false, features = [ "webc-fs", ] } -wasmer = { version = "4.4.0", path = "../api", default-features = false, features = [ +wasmer = { version = "5.0.0-rc.1", path = "../api", default-features = false, features = [ "wamr", "std", ] } diff --git a/lib/sys-utils/Cargo.toml b/lib/sys-utils/Cargo.toml index 5b147cb2fad..dc9099825db 100644 --- a/lib/sys-utils/Cargo.toml +++ b/lib/sys-utils/Cargo.toml @@ -12,9 +12,9 @@ repository.workspace = true rust-version.workspace = true [dependencies] -wasmer = { path = "../api", version = "=4.4.0", default-features = false, features = ["sys", "compiler"] } -wasmer-vm = { path = "../vm", version = "=4.4.0" } -wasmer-types = { path = "../types", version = "=4.4.0" } +wasmer = { path = "../api", version = "=5.0.0-rc.1", default-features = false, features = ["sys", "compiler"] } +wasmer-vm = { path = "../vm", version = "=5.0.0-rc.1" } +wasmer-types = { path = "../types", version = "=5.0.0-rc.1" } region = { version = "3.0" } tracing = "0.1.37" @@ -23,7 +23,7 @@ libc.workspace = true [dev-dependencies] wasmer-wasix.workspace = true -wasmer = { path = "../api", version = "=4.4.0", default-features = false, features = ["sys", "compiler", "cranelift"] } +wasmer = { path = "../api", version = "=5.0.0-rc.1", default-features = false, features = ["sys", "compiler", "cranelift"] } tracing-subscriber = { version = "0.3.16", features = ["fmt"] } tracing = "0.1.37" diff --git a/lib/vm/Cargo.toml b/lib/vm/Cargo.toml index f8e7f6b0b91..ce20b731af2 100644 --- a/lib/vm/Cargo.toml +++ b/lib/vm/Cargo.toml @@ -15,7 +15,7 @@ version.workspace = true [dependencies] memoffset.workspace = true dashmap.workspace = true -wasmer-types = { path = "../types", version = "=4.4.0" } +wasmer-types = { path = "../types", version = "=5.0.0-rc.1" } libc.workspace = true indexmap = { workspace = true } thiserror = "1.0" diff --git a/lib/wai-bindgen-wasmer/Cargo.toml b/lib/wai-bindgen-wasmer/Cargo.toml index bf20d712c03..1e63bb17962 100644 --- a/lib/wai-bindgen-wasmer/Cargo.toml +++ b/lib/wai-bindgen-wasmer/Cargo.toml @@ -20,7 +20,7 @@ once_cell = "1.13" thiserror = "1.0" tracing-lib = { version = "0.1.26", optional = true, package = "tracing" } wai-bindgen-wasmer-impl = { version = "0.2.2" } -wasmer = { version = "=4.4.0", path = "../api", default-features = false } +wasmer = { version = "=5.0.0-rc.1", path = "../api", default-features = false } [features] # Enables generated code to emit events via the `tracing` crate whenever wasm is diff --git a/lib/wasi-types/Cargo.toml b/lib/wasi-types/Cargo.toml index 325d4d5e5e5..af11a41882e 100644 --- a/lib/wasi-types/Cargo.toml +++ b/lib/wasi-types/Cargo.toml @@ -15,9 +15,9 @@ rust-version.workspace = true # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html [dependencies] -wasmer = { default-features = false, path = "../api", version = "=4.4.0" } -wasmer-types = { path = "../types", version = "=4.4.0" } -wasmer-derive = { path = "../derive", version = "=4.4.0" } +wasmer = { default-features = false, path = "../api", version = "=5.0.0-rc.1" } +wasmer-types = { path = "../types", version = "=5.0.0-rc.1" } +wasmer-derive = { path = "../derive", version = "=5.0.0-rc.1" } wai-bindgen-gen-rust = "0.2.1" wai-bindgen-rust = { version = "0.2.1", default-features = false, features = ["macros"] } wai-bindgen-gen-rust-wasm = "0.2.1" diff --git a/lib/wasix/Cargo.toml b/lib/wasix/Cargo.toml index fe217a40241..8de25b0be7c 100644 --- a/lib/wasix/Cargo.toml +++ b/lib/wasix/Cargo.toml @@ -14,13 +14,13 @@ rust-version.workspace = true [dependencies] wasmer-wasix-types = { path = "../wasi-types", version = "0.28.0", features = [ "enable-serde" ] } -wasmer-types = { path = "../types", version = "=4.4.0", default-features = false } -wasmer = { path = "../api", version = "=4.4.0", default-features = false, features = ["wat", "js-serializable-module"] } +wasmer-types = { path = "../types", version = "=5.0.0-rc.1", default-features = false } +wasmer = { path = "../api", version = "=5.0.0-rc.1", default-features = false, features = ["wat", "js-serializable-module"] } virtual-mio = { path = "../virtual-io", version = "0.4.0", default-features = false } virtual-fs = { path = "../virtual-fs", version = "0.17.0", default-features = false, features = ["webc-fs"] } virtual-net = { path = "../virtual-net", version = "0.9.0", default-features = false, features = ["rkyv"] } wasmer-journal = { path = "../journal", version = "0.10.0", default-features = false } -wasmer-emscripten = { path = "../emscripten", version = "=4.4.0", optional = true } +wasmer-emscripten = { path = "../emscripten", version = "=5.0.0-rc.1", optional = true } wasmer-config = { version = "0.9.0", path = "../config" } http.workspace = true @@ -131,7 +131,7 @@ windows-sys = { version = "0.59", features = ["Win32_System_SystemInformation"] terminal_size = { version = "0.3.0" } [dev-dependencies] -wasmer = { path = "../api", version = "=4.4.0", default-features = false, features = ["wat", "js-serializable-module"] } +wasmer = { path = "../api", version = "=5.0.0-rc.1", default-features = false, features = ["wat", "js-serializable-module"] } tokio = { workspace = true, features = [ "sync", "macros", "rt" ], default-features = false } pretty_assertions.workspace = true tracing-test = "0.2.4" @@ -143,7 +143,7 @@ tracing-wasm = "0.2" [target.'cfg(not(target_arch = "wasm32"))'.dev-dependencies] tracing-subscriber = { version = "^0.3" } -wasmer = { path = "../api", version = "=4.4.0", default-features = false, features = ["wat", "js-serializable-module", "cranelift"] } +wasmer = { path = "../api", version = "=5.0.0-rc.1", default-features = false, features = ["wat", "js-serializable-module", "cranelift"] } [features] default = ["sys-default"] diff --git a/scripts/update-version.py b/scripts/update-version.py index b86faf44ab2..0767737b49d 100644 --- a/scripts/update-version.py +++ b/scripts/update-version.py @@ -1,7 +1,7 @@ #!/usr/bin/python -PREVIOUS_VERSION='4.3.7' -NEXT_VERSION='4.4.0' +PREVIOUS_VERSION='4.4.0' +NEXT_VERSION='5.0.0-rc.1' import os import re diff --git a/scripts/windows-installer/wasmer.iss b/scripts/windows-installer/wasmer.iss index c59320d5529..79d129967ff 100644 --- a/scripts/windows-installer/wasmer.iss +++ b/scripts/windows-installer/wasmer.iss @@ -1,6 +1,6 @@ [Setup] AppName=Wasmer -AppVersion=4.4.0 +AppVersion=5.0.0-rc.1 DefaultDirName={pf}\Wasmer DefaultGroupName=Wasmer Compression=lzma2 diff --git a/tests/integration/cli/Cargo.toml b/tests/integration/cli/Cargo.toml index 75e305596e6..18c238bf2c2 100644 --- a/tests/integration/cli/Cargo.toml +++ b/tests/integration/cli/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "wasmer-integration-tests-cli" -version = "4.4.0" +version = "5.0.0-rc.1" authors = ["Wasmer Engineering Team "] description = "CLI integration tests" repository = "https://github.com/wasmerio/wasmer" diff --git a/tests/integration/ios/Cargo.toml b/tests/integration/ios/Cargo.toml index 5b6d03fb55d..38339b06ae0 100644 --- a/tests/integration/ios/Cargo.toml +++ b/tests/integration/ios/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "wasmer-integration-tests-ios" -version = "4.4.0" +version = "5.0.0-rc.1" authors = ["Wasmer Engineering Team "] description = "iOS integration tests" repository = "https://github.com/wasmerio/wasmer" diff --git a/tests/lib/wast/Cargo.toml b/tests/lib/wast/Cargo.toml index 1728df86dfc..526d3fca481 100644 --- a/tests/lib/wast/Cargo.toml +++ b/tests/lib/wast/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "wasmer-wast" -version = "4.4.0" +version = "5.0.0-rc.1" authors = ["Wasmer Engineering Team "] description = "wast testing support for wasmer" license = "MIT OR Apache-2.0 WITH LLVM-exception" @@ -13,7 +13,7 @@ edition = "2018" [dependencies] wasmer-types = { path = "../../../lib/types", version="=4.4.0" } wasmer-wasix = { path = "../../../lib/wasix", version="=0.28.0" } -wasmer = { path = "../../../lib/api", version = "=4.4.0", default-features = false } +wasmer = { path = "../../../lib/api", version = "=5.0.0-rc.1", default-features = false } virtual-fs = { path = "../../../lib/virtual-fs", version = "0.17.0" } anyhow = "1.0" diff --git a/tests/wasi-wast/Cargo.toml b/tests/wasi-wast/Cargo.toml index 6cc2d1bbaab..9848e2b63c8 100644 --- a/tests/wasi-wast/Cargo.toml +++ b/tests/wasi-wast/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "wasi-test-generator" -version = "4.4.0" +version = "5.0.0-rc.1" description = "Tests for our WASI implementation" license = "MIT" authors = ["Wasmer Engineering Team "] diff --git a/tests/wasmer-argus/Cargo.toml b/tests/wasmer-argus/Cargo.toml index a7db128d63e..92150278856 100644 --- a/tests/wasmer-argus/Cargo.toml +++ b/tests/wasmer-argus/Cargo.toml @@ -24,7 +24,7 @@ clap = {version = "4.4.11", features = ["derive", "string"]} tracing-subscriber = { version = "0.3.18", features = ["env-filter"] } serde = { version = "1.0.197", features = ["derive"] } serde_json = "1.0.114" -wasmer = { version = "4.4.0", path = "../../lib/api", features = ["engine", "core", "singlepass", "cranelift", "llvm"], optional = true } +wasmer = { version = "5.0.0-rc.1", path = "../../lib/api", features = ["engine", "core", "singlepass", "cranelift", "llvm"], optional = true } derive_more = "0.99.17" webc.workspace = true async-trait = "0.1.77" From cab3bba6d38cfc83d4a0fe48f7cd0efc75cd4196 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Mon, 21 Oct 2024 13:56:46 +0330 Subject: [PATCH 56/59] fix build issues --- Cargo.lock | 52 ++++++++++++++++++------------------- lib/cli-compiler/Cargo.toml | 4 +-- lib/cli/Cargo.toml | 4 +-- lib/registry/Cargo.toml | 2 +- tests/lib/wast/Cargo.toml | 2 +- 5 files changed, 32 insertions(+), 32 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 2e716e90a9a..4e6e52dfa10 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -2957,7 +2957,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4979f22fdb869068da03c9f7528f8297c6fd2606bc3a4affe42e6a823fdb8da4" dependencies = [ "cfg-if 1.0.0", - "windows-targets 0.52.6", + "windows-targets 0.48.5", ] [[package]] @@ -3184,7 +3184,7 @@ dependencies = [ [[package]] name = "macro-wasmer-universal-test" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "proc-macro2", "quote", @@ -6738,7 +6738,7 @@ checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" [[package]] name = "wasi-test-generator" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "glob", "gumdrop", @@ -6928,7 +6928,7 @@ dependencies = [ [[package]] name = "wasmer" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "anyhow", "bindgen", @@ -6998,7 +6998,7 @@ dependencies = [ [[package]] name = "wasmer-argus" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "anyhow", "async-trait", @@ -7039,7 +7039,7 @@ dependencies = [ [[package]] name = "wasmer-c-api" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "cbindgen", "cfg-if 1.0.0", @@ -7070,7 +7070,7 @@ dependencies = [ [[package]] name = "wasmer-c-api-test-runner" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "cc", "regex", @@ -7080,7 +7080,7 @@ dependencies = [ [[package]] name = "wasmer-cache" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "blake3", "clap", @@ -7098,7 +7098,7 @@ dependencies = [ [[package]] name = "wasmer-capi-examples-runner" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "cc", "regex", @@ -7108,7 +7108,7 @@ dependencies = [ [[package]] name = "wasmer-cli" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "anyhow", "assert_cmd 2.0.16", @@ -7206,7 +7206,7 @@ dependencies = [ [[package]] name = "wasmer-compiler" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "backtrace", "bytes 1.7.2", @@ -7238,7 +7238,7 @@ dependencies = [ [[package]] name = "wasmer-compiler-cli" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "anyhow", "bytesize", @@ -7259,7 +7259,7 @@ dependencies = [ [[package]] name = "wasmer-compiler-cranelift" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "cranelift-codegen", "cranelift-entity", @@ -7279,7 +7279,7 @@ dependencies = [ [[package]] name = "wasmer-compiler-llvm" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "byteorder", "cc", @@ -7301,7 +7301,7 @@ dependencies = [ [[package]] name = "wasmer-compiler-singlepass" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "byteorder", "dynasm", @@ -7364,7 +7364,7 @@ dependencies = [ [[package]] name = "wasmer-derive" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "compiletest_rs", "proc-macro-error", @@ -7376,7 +7376,7 @@ dependencies = [ [[package]] name = "wasmer-emscripten" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "byteorder", "getrandom", @@ -7418,7 +7418,7 @@ dependencies = [ [[package]] name = "wasmer-integration-tests-cli" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "anyhow", "assert_cmd 2.0.16", @@ -7447,7 +7447,7 @@ dependencies = [ [[package]] name = "wasmer-integration-tests-ios" -version = "4.4.0" +version = "5.0.0-rc.1" [[package]] name = "wasmer-journal" @@ -7478,7 +7478,7 @@ dependencies = [ [[package]] name = "wasmer-middlewares" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "wasmer", "wasmer-types", @@ -7487,7 +7487,7 @@ dependencies = [ [[package]] name = "wasmer-object" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "object 0.29.0", "thiserror", @@ -7583,7 +7583,7 @@ dependencies = [ [[package]] name = "wasmer-types" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "bytecheck 0.6.12", "enum-iterator", @@ -7605,7 +7605,7 @@ dependencies = [ [[package]] name = "wasmer-vm" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "backtrace", "cc", @@ -7743,7 +7743,7 @@ dependencies = [ [[package]] name = "wasmer-wasm-interface" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "bincode", "either", @@ -7755,7 +7755,7 @@ dependencies = [ [[package]] name = "wasmer-wast" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "anyhow", "futures 0.3.31", @@ -7772,7 +7772,7 @@ dependencies = [ [[package]] name = "wasmer-workspace" -version = "4.4.0" +version = "5.0.0-rc.1" dependencies = [ "anyhow", "build-deps", diff --git a/lib/cli-compiler/Cargo.toml b/lib/cli-compiler/Cargo.toml index 9a40b9a13fc..e71ab7d8e27 100644 --- a/lib/cli-compiler/Cargo.toml +++ b/lib/cli-compiler/Cargo.toml @@ -38,14 +38,14 @@ target-lexicon = { version = "0.12", features = ["std"] } [target.'cfg(not(target_arch = "wasm32"))'.dependencies] wasmer-compiler-singlepass = { version = "=5.0.0-rc.1", path = "../compiler-singlepass", optional = true } wasmer-compiler-cranelift = { version = "=5.0.0-rc.1", path = "../compiler-cranelift", optional = true } -clap = { version = "5.0.0-rc.1", features = ["derive", "env"] } +clap = { version = "4.4.0", features = ["derive", "env"] } [target.'cfg(target_arch = "wasm32")'.dependencies] wasmer-compiler-singlepass = { version = "=5.0.0-rc.1", path = "../compiler-singlepass", optional = true, default-features = false, features = ["wasm"] } wasmer-compiler-cranelift = { version = "=5.0.0-rc.1", path = "../compiler-cranelift", optional = true, default-features = false, features = ["wasm"] } # NOTE: Must use different features for clap because the "color" feature does not # work on wasi, due to the anstream dependency not compiling. -clap = { version = "5.0.0-rc.1", default-features = false, features = [ +clap = { version = "4.4.0", default-features = false, features = [ "std", "help", "usage", diff --git a/lib/cli/Cargo.toml b/lib/cli/Cargo.toml index 07d4fe642f0..4f2901e6359 100644 --- a/lib/cli/Cargo.toml +++ b/lib/cli/Cargo.toml @@ -240,9 +240,9 @@ dotenvy = "0.15.7" # NOTE: Must use different features for clap because the "color" feature does not # work on wasi due to the anstream dependency not compiling. [target.'cfg(not(target_family = "wasm"))'.dependencies] -clap = { version = "5.0.0-rc.1", features = ["derive", "env"] } +clap = { version = "4.4.0", features = ["derive", "env"] } [target.'cfg(target_family = "wasm")'.dependencies] -clap = { version = "5.0.0-rc.1", default-features = false, features = [ +clap = { version = "4.4.0", default-features = false, features = [ "std", "help", "usage", diff --git a/lib/registry/Cargo.toml b/lib/registry/Cargo.toml index f39cb1154f1..190c76a505d 100644 --- a/lib/registry/Cargo.toml +++ b/lib/registry/Cargo.toml @@ -23,7 +23,7 @@ full = [] [dependencies] anyhow = "1.0.65" -clap = { version = "5.0.0-rc.1", default-features = false, features = [ +clap = { version = "4.4.0", default-features = false, features = [ "derive", "env", ], optional = true } diff --git a/tests/lib/wast/Cargo.toml b/tests/lib/wast/Cargo.toml index 526d3fca481..1b9bb841608 100644 --- a/tests/lib/wast/Cargo.toml +++ b/tests/lib/wast/Cargo.toml @@ -11,7 +11,7 @@ readme = "README.md" edition = "2018" [dependencies] -wasmer-types = { path = "../../../lib/types", version="=4.4.0" } +wasmer-types = { path = "../../../lib/types", version="=5.0.0-rc.1" } wasmer-wasix = { path = "../../../lib/wasix", version="=0.28.0" } wasmer = { path = "../../../lib/api", version = "=5.0.0-rc.1", default-features = false } virtual-fs = { path = "../../../lib/virtual-fs", version = "0.17.0" } From 6072a709d361e8f1bf06c7ff0df2268aaa26a15d Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Mon, 21 Oct 2024 14:27:05 +0330 Subject: [PATCH 57/59] update 0.x package versions --- Cargo.lock | 18 +++++++++--------- lib/c-api/Cargo.toml | 4 ++-- lib/cli/Cargo.toml | 10 +++++----- lib/journal/Cargo.toml | 8 ++++---- lib/registry/Cargo.toml | 2 +- lib/swift/Cargo.toml | 2 +- lib/sys-utils/Cargo.toml | 2 +- lib/virtual-fs/Cargo.toml | 2 +- lib/virtual-io/Cargo.toml | 2 +- lib/virtual-net/Cargo.toml | 4 ++-- lib/wai-bindgen-wasmer/Cargo.toml | 2 +- lib/wasi-types/Cargo.toml | 2 +- lib/wasix/Cargo.toml | 12 ++++++------ tests/lib/wast/Cargo.toml | 4 ++-- 14 files changed, 37 insertions(+), 37 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 4e6e52dfa10..48d99d608ae 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -6503,7 +6503,7 @@ checksum = "0b928f33d975fc6ad9f86c8f283853ad26bdd5b10b7f1542aa2fa15e2289105a" [[package]] name = "virtual-fs" -version = "0.17.0" +version = "0.18.0" dependencies = [ "anyhow", "async-trait", @@ -6535,7 +6535,7 @@ dependencies = [ [[package]] name = "virtual-mio" -version = "0.4.0" +version = "0.5.0" dependencies = [ "async-trait", "bytes 1.7.2", @@ -6550,7 +6550,7 @@ dependencies = [ [[package]] name = "virtual-net" -version = "0.9.0" +version = "0.10.0" dependencies = [ "anyhow", "async-trait", @@ -6653,7 +6653,7 @@ dependencies = [ [[package]] name = "wai-bindgen-wasmer" -version = "0.28.0" +version = "0.29.0" dependencies = [ "anyhow", "async-trait", @@ -7451,7 +7451,7 @@ version = "5.0.0-rc.1" [[package]] name = "wasmer-journal" -version = "0.10.0" +version = "0.11.0" dependencies = [ "anyhow", "async-trait", @@ -7507,7 +7507,7 @@ dependencies = [ [[package]] name = "wasmer-registry" -version = "5.20.0" +version = "5.21.0" dependencies = [ "anyhow", "async-tungstenite", @@ -7569,7 +7569,7 @@ dependencies = [ [[package]] name = "wasmer-sys-utils" -version = "0.28.0" +version = "0.29.0" dependencies = [ "libc", "region", @@ -7634,7 +7634,7 @@ dependencies = [ [[package]] name = "wasmer-wasix" -version = "0.28.0" +version = "0.29.0" dependencies = [ "ahash 0.8.11", "anyhow", @@ -7720,7 +7720,7 @@ dependencies = [ [[package]] name = "wasmer-wasix-types" -version = "0.28.0" +version = "0.29.0" dependencies = [ "anyhow", "bitflags 1.3.2", diff --git a/lib/c-api/Cargo.toml b/lib/c-api/Cargo.toml index a2e18914eac..45632c7556d 100644 --- a/lib/c-api/Cargo.toml +++ b/lib/c-api/Cargo.toml @@ -32,9 +32,9 @@ wasmer-compiler-singlepass = { version = "=5.0.0-rc.1", path = "../compiler-sing wasmer-emscripten = { version = "=5.0.0-rc.1", path = "../emscripten", optional = true } wasmer-middlewares = { version = "=5.0.0-rc.1", path = "../middlewares", optional = true } wasmer-types = { version = "=5.0.0-rc.1", path = "../types" } -wasmer-wasix = { path = "../wasix", version="=0.28.0", features = ["host-fs", "host-vnet"], optional = true } +wasmer-wasix = { path = "../wasix", version="=0.29.0", features = ["host-fs", "host-vnet"], optional = true } webc = { workspace = true, optional = true } -virtual-fs = { version = "0.17.0", path = "../virtual-fs", optional = true, default-features = false, features = ["static-fs"] } +virtual-fs = { version = "0.18.0", path = "../virtual-fs", optional = true, default-features = false, features = ["static-fs"] } enumset.workspace = true cfg-if = "1.0" lazy_static = "1.4" diff --git a/lib/cli/Cargo.toml b/lib/cli/Cargo.toml index 4f2901e6359..6736634fea8 100644 --- a/lib/cli/Cargo.toml +++ b/lib/cli/Cargo.toml @@ -122,7 +122,7 @@ wasmer-emscripten = { version = "=5.0.0-rc.1", path = "../emscripten" } wasmer-package = { version = "=0.1.0", path = "../package" } wasmer-vm = { version = "=5.0.0-rc.1", path = "../vm", optional = true } -wasmer-wasix = { path = "../wasix", version = "=0.28.0", features = [ +wasmer-wasix = { path = "../wasix", version = "=0.29.0", features = [ "logging", "webc_runner_rt_wcgi", "webc_runner_rt_dcgi", @@ -135,16 +135,16 @@ wasmer-wast = { version = "=5.0.0-rc.1", path = "../../tests/lib/wast", optional wasmer-types = { version = "=5.0.0-rc.1", path = "../types", features = [ "enable-serde", ] } -wasmer-registry = { version = "=5.20.0", path = "../registry", features = [ +wasmer-registry = { version = "=5.21.0", path = "../registry", features = [ "build-package", "clap", ] } wasmer-object = { version = "=5.0.0-rc.1", path = "../object", optional = true } -virtual-fs = { version = "0.17.0", path = "../virtual-fs", default-features = false, features = [ +virtual-fs = { version = "0.18.0", path = "../virtual-fs", default-features = false, features = [ "host-fs", ] } -virtual-net = { version = "0.9.0", path = "../virtual-net" } -virtual-mio = { version = "0.4.0", path = "../virtual-io" } +virtual-net = { version = "0.10.0", path = "../virtual-net" } +virtual-mio = { version = "0.5.0", path = "../virtual-io" } # Wasmer-owned dependencies. diff --git a/lib/journal/Cargo.toml b/lib/journal/Cargo.toml index 802241b14b3..7dcfc81a2ab 100644 --- a/lib/journal/Cargo.toml +++ b/lib/journal/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "wasmer-journal" -version = "0.10.0" +version = "0.11.0" description = "Journaling functionality used by Wasmer to save and restore WASM state" authors.workspace = true edition.workspace = true @@ -15,13 +15,13 @@ log-file = ["shared-buffer"] [dependencies] wasmer = { default-features = false, path = "../api", version = "=5.0.0-rc.1" } -wasmer-wasix-types = { path = "../wasi-types", version = "0.28.0", features = [ +wasmer-wasix-types = { path = "../wasi-types", version = "0.29.0", features = [ "enable-serde", ] } -virtual-net = { path = "../virtual-net", version = "0.9.0", default-features = false, features = [ +virtual-net = { path = "../virtual-net", version = "0.10.0", default-features = false, features = [ "rkyv", ] } -virtual-fs = { path = "../virtual-fs", version = "0.17.0", default-features = false } +virtual-fs = { path = "../virtual-fs", version = "0.18.0", default-features = false } shared-buffer = { workspace = true, optional = true } base64.workspace = true rkyv = { workspace = true } diff --git a/lib/registry/Cargo.toml b/lib/registry/Cargo.toml index 190c76a505d..6c38ce52377 100644 --- a/lib/registry/Cargo.toml +++ b/lib/registry/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "wasmer-registry" -version = "5.20.0" +version = "5.21.0" description = "Crate to interact with the wasmer registry, download packages, etc." authors.workspace = true edition.workspace = true diff --git a/lib/swift/Cargo.toml b/lib/swift/Cargo.toml index 6870c1ae390..844ed275407 100644 --- a/lib/swift/Cargo.toml +++ b/lib/swift/Cargo.toml @@ -13,7 +13,7 @@ name = "wasmer_swift" thiserror = "1" tokio = { version = "1.28.1", features = [ "rt" ], default-features = false } uniffi = "0.27" -virtual-fs = { path = "../virtual-fs", version = "0.17.0", default-features = false, features = [ +virtual-fs = { path = "../virtual-fs", version = "0.18.0", default-features = false, features = [ "webc-fs", ] } wasmer = { version = "5.0.0-rc.1", path = "../api", default-features = false, features = [ diff --git a/lib/sys-utils/Cargo.toml b/lib/sys-utils/Cargo.toml index dc9099825db..fee84c1620d 100644 --- a/lib/sys-utils/Cargo.toml +++ b/lib/sys-utils/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "wasmer-sys-utils" -version = "0.28.0" +version = "0.29.0" description = "Wasmer utilities for a sys environment." categories = ["wasm"] keywords = ["wasm", "webassembly"] diff --git a/lib/virtual-fs/Cargo.toml b/lib/virtual-fs/Cargo.toml index 9799ecdcad0..9c49c4ccdd6 100644 --- a/lib/virtual-fs/Cargo.toml +++ b/lib/virtual-fs/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "virtual-fs" -version = "0.17.0" +version = "0.18.0" description = "Wasmer Virtual FileSystem" authors.workspace = true edition.workspace = true diff --git a/lib/virtual-io/Cargo.toml b/lib/virtual-io/Cargo.toml index 119fca4e4ce..b071a6277c4 100644 --- a/lib/virtual-io/Cargo.toml +++ b/lib/virtual-io/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "virtual-mio" -version = "0.4.0" +version = "0.5.0" description = "Wasmer Virtual IO Engine powered by mio" authors.workspace = true edition.workspace = true diff --git a/lib/virtual-net/Cargo.toml b/lib/virtual-net/Cargo.toml index e5deec6e66f..d4bdd69448e 100644 --- a/lib/virtual-net/Cargo.toml +++ b/lib/virtual-net/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "virtual-net" -version = "0.9.0" +version = "0.10.0" description = "Wasmer Virtual Networking" authors.workspace = true edition.workspace = true @@ -23,7 +23,7 @@ libc = { workspace = true, optional = true } mio = { workspace = true, optional = true } socket2 = { workspace = true, optional = true } derivative = { version = "^2" } -virtual-mio = { path = "../virtual-io", version = "0.4.0", default-features = false } +virtual-mio = { path = "../virtual-io", version = "0.5.0", default-features = false } bincode = { version = "1.3" } serde = { version = "1.0", default-features = false, features = ["derive"] } pin-project-lite = "0.2.9" diff --git a/lib/wai-bindgen-wasmer/Cargo.toml b/lib/wai-bindgen-wasmer/Cargo.toml index 1e63bb17962..f9e4f159e7a 100644 --- a/lib/wai-bindgen-wasmer/Cargo.toml +++ b/lib/wai-bindgen-wasmer/Cargo.toml @@ -1,7 +1,7 @@ [package] name = "wai-bindgen-wasmer" description = "Generate WAI glue for a Rust Wasmer host" -version = "0.28.0" +version = "0.29.0" categories = ["wasm", "os"] keywords = ["wasm", "webassembly", "wasi", "sandbox", "ABI"] readme = "README.md" diff --git a/lib/wasi-types/Cargo.toml b/lib/wasi-types/Cargo.toml index af11a41882e..99413a1c9db 100644 --- a/lib/wasi-types/Cargo.toml +++ b/lib/wasi-types/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "wasmer-wasix-types" -version = "0.28.0" +version = "0.29.0" description = "WASI and WASIX types for Wasmer WebAssembly runtime" categories = ["wasm", "os"] keywords = ["wasm", "webassembly", "wasi", "sandbox", "ABI"] diff --git a/lib/wasix/Cargo.toml b/lib/wasix/Cargo.toml index 8de25b0be7c..c673407c275 100644 --- a/lib/wasix/Cargo.toml +++ b/lib/wasix/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "wasmer-wasix" -version = "0.28.0" +version = "0.29.0" description = "WASI and WASIX implementation library for Wasmer WebAssembly runtime" categories = ["wasm", "os"] keywords = ["wasm", "webassembly", "wasi", "sandbox", "ABI"] @@ -13,13 +13,13 @@ repository.workspace = true rust-version.workspace = true [dependencies] -wasmer-wasix-types = { path = "../wasi-types", version = "0.28.0", features = [ "enable-serde" ] } +wasmer-wasix-types = { path = "../wasi-types", version = "0.29.0", features = [ "enable-serde" ] } wasmer-types = { path = "../types", version = "=5.0.0-rc.1", default-features = false } wasmer = { path = "../api", version = "=5.0.0-rc.1", default-features = false, features = ["wat", "js-serializable-module"] } -virtual-mio = { path = "../virtual-io", version = "0.4.0", default-features = false } -virtual-fs = { path = "../virtual-fs", version = "0.17.0", default-features = false, features = ["webc-fs"] } -virtual-net = { path = "../virtual-net", version = "0.9.0", default-features = false, features = ["rkyv"] } -wasmer-journal = { path = "../journal", version = "0.10.0", default-features = false } +virtual-mio = { path = "../virtual-io", version = "0.5.0", default-features = false } +virtual-fs = { path = "../virtual-fs", version = "0.18.0", default-features = false, features = ["webc-fs"] } +virtual-net = { path = "../virtual-net", version = "0.10.0", default-features = false, features = ["rkyv"] } +wasmer-journal = { path = "../journal", version = "0.11.0", default-features = false } wasmer-emscripten = { path = "../emscripten", version = "=5.0.0-rc.1", optional = true } wasmer-config = { version = "0.9.0", path = "../config" } diff --git a/tests/lib/wast/Cargo.toml b/tests/lib/wast/Cargo.toml index 1b9bb841608..39169305246 100644 --- a/tests/lib/wast/Cargo.toml +++ b/tests/lib/wast/Cargo.toml @@ -12,9 +12,9 @@ edition = "2018" [dependencies] wasmer-types = { path = "../../../lib/types", version="=5.0.0-rc.1" } -wasmer-wasix = { path = "../../../lib/wasix", version="=0.28.0" } +wasmer-wasix = { path = "../../../lib/wasix", version="=0.29.0" } wasmer = { path = "../../../lib/api", version = "=5.0.0-rc.1", default-features = false } -virtual-fs = { path = "../../../lib/virtual-fs", version = "0.17.0" } +virtual-fs = { path = "../../../lib/virtual-fs", version = "0.18.0" } anyhow = "1.0" wast = "216.0.0" From 8d7299f366cb5d055b754985c167ae0c3eb738bd Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Mon, 21 Oct 2024 14:37:58 +0330 Subject: [PATCH 58/59] update CHANGELOG --- CHANGELOG.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 846e850bcce..64328ada58b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -11,6 +11,9 @@ Looking for changes that affect our C API? See the [C API Changelog](lib/c-api/C ## 5.0.0-rc.1 - 21/10/2024 +This release adds experimental support for v8, wasmi, and wamr as interpreter backends to wasmer. Also, we updated the versions of +llvm, cranelift and rkyv gaining nice performance boosts. + ## Added - [#5154](https://github.com/wasmerio/wasmer/pull/5154) Add build steps for interpreter backends From 3dad0586dd555e65ab2c2a18a579775c917a7659 Mon Sep 17 00:00:00 2001 From: "M.Amin Rayej" Date: Mon, 21 Oct 2024 14:43:07 +0330 Subject: [PATCH 59/59] update CHANGELOG --- CHANGELOG.md | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 64328ada58b..2de2bc94fa2 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -11,8 +11,7 @@ Looking for changes that affect our C API? See the [C API Changelog](lib/c-api/C ## 5.0.0-rc.1 - 21/10/2024 -This release adds experimental support for v8, wasmi, and wamr as interpreter backends to wasmer. Also, we updated the versions of -llvm, cranelift and rkyv gaining nice performance boosts. +This is a release candidate as we are preparing for the final release of 5.0 ## Added