fix: return proper nil on runtime.InstantiateModule errors (#2353) #10017
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Test | |
on: | |
pull_request: | |
branches: [main] | |
paths-ignore: # ignore docs as they are built with Netlify. | |
- '**/*.md' | |
- 'site/**' | |
- 'netlify.toml' | |
push: | |
branches: [main] | |
paths-ignore: # ignore docs as they are built with Netlify. | |
- '**/*.md' | |
- 'site/**' | |
- 'netlify.toml' | |
env: # Update this prior to requiring a higher minor version in go.mod | |
GO_VERSION: "1.23" | |
defaults: | |
run: # use bash for all operating systems unless overridden | |
shell: bash | |
concurrency: | |
# https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#example-using-concurrency-to-cancel-any-in-progress-job-or-run | |
group: ${{ github.ref }}-${{ github.workflow }}-${{ github.actor }} | |
cancel-in-progress: true | |
jobs: | |
check: | |
name: Pre-commit check | |
# wabt requires a later version of libc than what's installed on ubuntu-22.04. | |
runs-on: ubuntu-latest | |
steps: | |
- name: Install latest wast2json | |
run: | # Needed for build.spectest. wabt includes wast2json. | |
wabt_version=1.0.34 | |
wabt_url=https://github.com/WebAssembly/wabt/releases/download/${wabt_version}/wabt-${wabt_version}-ubuntu.tar.gz | |
curl -sSL ${wabt_url} | tar --strip-components 2 -C /usr/local/bin -xzf - wabt-${wabt_version}/bin/wast2json | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-go@v5 | |
with: # not cache: true as we also need to cache golint | |
cache: false | |
go-version: ${{ env.GO_VERSION }} | |
- uses: actions/cache@v4 | |
with: | |
path: | | |
~/.cache/go-build | |
~/.cache/golangci-lint | |
~/go/pkg/mod | |
~/go/bin | |
key: check-${{ runner.os }}-go-${{ env.GO_VERSION }}-${{ hashFiles('**/go.sum', 'Makefile') }} | |
- run: make build.spectest | |
- run: make check | |
test: | |
name: ${{ matrix.platform.arch }}, ${{ matrix.platform.os }}, Go-${{ matrix.go-version }} | |
runs-on: ${{ matrix.platform.os }} | |
strategy: | |
fail-fast: false # don't fail fast as sometimes failures are arch/OS specific | |
matrix: # Use versions consistent with wazero's Go support policy. | |
platform: | |
- os: ubuntu-22.04 | |
arch: amd64 | |
- os: windows-2022 | |
arch: amd64 | |
- os: macos-14 | |
arch: arm64 | |
go-version: | |
- "1.23" # Current Go version | |
- "1.21" # Floor Go version of wazero (current - 2) | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-go@v5 | |
with: | |
go-version: ${{ matrix.go-version }} | |
# Ensure the pagefile is large enough to execute tests like TestStore_hammer_close on Windows. | |
- name: configure Pagefile | |
uses: al-cheb/[email protected] | |
if: runner.os == 'Windows' | |
with: | |
minimum-size: 8GB | |
maximum-size: 16GB | |
disk-root: "D:" | |
# Run -race could be really slow without -short, so run them together on this workflow. | |
# Since -short is not added in the scratch tests, all the tests are run in CI in practice. | |
- run: make test go_test_options='-timeout 20m -race -short' | |
- name: "Generate coverage report" # only once (not per OS) | |
if: runner.os == 'Linux' | |
run: make coverage | |
- name: "Upload coverage report" # only on main push and only once (not per OS) | |
if: github.event_name == 'push' && github.ref == 'refs/heads/main' && runner.os == 'Linux' | |
env: | |
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }} | |
run: bash <(curl -s https://codecov.io/bash) | |
test_scratch: | |
name: ${{ matrix.arch }}, Linux (scratch), Go-${{ matrix.go-version }} | |
runs-on: ubuntu-22.04 | |
strategy: | |
fail-fast: false # don't fail fast as sometimes failures are arch/OS specific | |
matrix: # Use versions consistent with wazero's Go support policy. | |
go-version: | |
- "1.23" # Current Go version | |
- "1.21" # Floor Go version of wazero (current - 2) | |
arch: | |
- "amd64" | |
- "arm64" | |
- "riscv64" | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-go@v5 | |
with: | |
go-version: ${{ matrix.go-version }} | |
- name: Build test binaries | |
run: | | |
go list -f '{{.Dir}}' ./... | egrep -v 'spectest' | xargs -Ipkg go test pkg -c -o pkg.test | |
go build -o wazerocli ./cmd/wazero | |
env: | |
GOARCH: ${{ matrix.arch }} | |
CGO_ENABLED: 0 | |
- name: Set up QEMU | |
if: ${{ matrix.arch != 'amd64' }} | |
uses: docker/setup-qemu-action@v3 | |
with: # Avoid docker.io rate-limits; built with internal-images.yml | |
image: ghcr.io/tetratelabs/wazero/internal-binfmt | |
platforms: ${{ matrix.arch }} | |
- name: Build scratch container | |
run: | | |
echo 'FROM scratch' >> Dockerfile | |
echo 'CMD ["/test"]' >> Dockerfile | |
docker buildx build -t wazero:test --platform linux/${{ matrix.arch }} . | |
- name: Run built test binaries | |
# This runs all tests compiled above in sequence. Note: This mounts /tmp to allow t.TempDir() in tests. | |
run: find . -name "*.test" | xargs -Itestbin docker run --platform linux/${{ matrix.arch }} -v $(pwd)/testbin:/test -v $(pwd)/wazerocli:/wazero -e WAZEROCLI=/wazero --tmpfs /tmp --rm -t wazero:test | |
test_bsd: | |
name: amd64, ${{ matrix.os.name }} | |
runs-on: ubuntu-22.04 | |
strategy: | |
fail-fast: false # don't fail fast as sometimes failures are OS specific | |
matrix: | |
os: | |
- name: freebsd | |
version: "14.1" | |
- name: openbsd | |
version: "7.5" | |
- name: netbsd | |
version: "10.0" | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Build test binaries | |
run: | | |
go list -f '{{.Dir}}' ./... | egrep -v 'imports|sysfs' | xargs -Ipkg go test pkg -c -o pkg.test | |
go build -o wazerocli ./cmd/wazero | |
env: | |
GOOS: ${{ matrix.os.name }} | |
- name: Run built test binaries | |
uses: cross-platform-actions/[email protected] | |
env: | |
WAZEROCLI: ./wazerocli | |
with: | |
operating_system: ${{ matrix.os.name }} | |
version: ${{ matrix.os.version }} | |
shell: bash | |
sync_files: runner-to-vm | |
environment_variables: WAZEROCLI | |
# This runs all tests compiled above in sequence. | |
run: find . -name "*.test" | xargs -Itestbin nice testbin -test.short | |
test_vm: | |
name: amd64, ${{ matrix.os.name }} | |
runs-on: ubuntu-22.04 | |
strategy: | |
fail-fast: false # don't fail fast as sometimes failures are OS specific | |
matrix: | |
os: | |
- name: dragonfly | |
version: "6.4.0" | |
action: 'vmactions/dragonflybsd-vm@v1' | |
- name: illumos | |
version: "r151052" | |
action: 'vmactions/omnios-vm@v1' | |
- name: solaris | |
version: "11.4" | |
action: 'vmactions/solaris-vm@v1' | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Build test binaries | |
run: | | |
go list -f '{{.Dir}}' ./... | egrep -v 'imports|sysfs' | xargs -Ipkg go test pkg -c -o pkg.test | |
go build -o wazerocli ./cmd/wazero | |
envsubst < ./.github/actions/vmactions/template.yml > ./.github/actions/vmactions/action.yml | |
env: | |
GOOS: ${{ matrix.os.name }} | |
VMACTIONS: ${{ matrix.os.action }} | |
- name: Run built test binaries | |
uses: ./.github/actions/vmactions | |
env: | |
WAZEROCLI: ./wazerocli | |
with: | |
envs: WAZEROCLI | |
# This runs all tests compiled above in sequence. | |
run: find . -name "*.test" | xargs -Itestbin nice testbin -test.short | |
# This ensures that internal/integration_test/fuzz is runnable, and is not intended to | |
# run full-length fuzzing while trying to find low-hanging frontend bugs. | |
fuzz: | |
name: Minimal Fuzzing (${{ matrix.platform.os }}, ${{ matrix.platform.arch }}) | |
runs-on: ${{ matrix.platform.os }} | |
strategy: | |
fail-fast: false # don't fail fast as sometimes failures are arch/OS specific | |
matrix: # Use versions consistent with wazero's Go support policy. | |
platform: | |
- os: ubuntu-22.04 | |
arch: amd64 | |
- os: macos-14 | |
arch: arm64 | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-go@v5 | |
with: | |
go-version: ${{ env.GO_VERSION }} | |
- uses: actions/cache@v4 | |
id: cache | |
with: | |
# Cache corpus and artifacts so that we don't start from scratch but rather with a meaningful corpus | |
# in the subsequent CI jobs. | |
path: | | |
~/.cargo | |
~/.cache/go-build | |
~/go/pkg/mod | |
~/.rustup/toolchains/ | |
internal/integration_test/fuzz/target | |
internal/integration_test/fuzz/fuzz/artifacts | |
internal/integration_test/fuzz/fuzz/corpus | |
key: build-fuzz-${{ matrix.platform.os }}-${{ matrix.platform.arch }}-go-${{ env.GO_VERSION }}-${{ hashFiles('**/go.sum', 'Makefile', '**/Cargo.lock', '**/Cargo.toml', '**/*.rs') }} | |
- run: cargo install cargo-fuzz | |
if: steps.cache.outputs.cache-hit != 'true' | |
# Run fuzzing only for a minute, not a full-length intensive one, but 60 seconds seems enough to find minor "front-end" | |
# bugs which might exist in binary parser, validation, or instantiation phase while not pressuring CI jobs. | |
- run: make fuzz fuzz_timeout_seconds=60 | |
if: ${{ github.event_name == 'pull_request' }} | |
# Run a bit longer on main branch push! | |
- run: make fuzz fuzz_timeout_seconds=180 | |
if: ${{ github.event_name == 'push' }} |