Skip to content

Smoke-test the libFuzzer harness on pull requests#4981

Open
matthargett wants to merge 1 commit into
bytecodealliance:mainfrom
rebeckerspecialties:ci/fuzz-smoke-on-prs
Open

Smoke-test the libFuzzer harness on pull requests#4981
matthargett wants to merge 1 commit into
bytecodealliance:mainfrom
rebeckerspecialties:ci/fuzz-smoke-on-prs

Conversation

@matthargett

Copy link
Copy Markdown
Contributor

What

Add a pull_request-triggered smoke test for the existing libFuzzer harness in tests/fuzz/wasm-mutator-fuzz/.

The full harness already runs continuously on OSS-Fuzz (google/oss-fuzz/projects/wamr), but nothing in-tree builds or exercises it on a pull request. So a change that breaks the harness build, or reintroduces a previously fixed loader/validator crash, is only caught out-of-band — an OSS-Fuzz report hours to days after merge. This moves that class of memory-safety regression to a check before review.

How

For each of fast-interp (default) and classic-interp, the job:

  1. Installs the same toolchain OSS-Fuzz uses for this harness — LLVM 18.1.8 and wasm-tools 1.243.0.
  2. Generates the wasm-smith seed corpus via the existing smith_wasm.sh.
  3. Builds the wasm_mutator_fuzz target (ASan + UBSan + libFuzzer, from the harness's own sanitizer_flags.cmake).
  4. Replays the committed tests/malformed/fuzz/*.wasm regression corpus (deterministic), then runs a short seeded bounded fuzz. Any crash / sanitizer error fails the job.

Fork / upstream safety

The job needs no secrets and no write permissions (permissions: contents: read); it builds and runs only, so it behaves identically for pull requests opened within a repository and from forks.

Notes

  • Scoped to the two interpreter targets (the interpreter-only, most-exercised loader path); the llvm-jit / aot-compiler targets OSS-Fuzz also builds could be added.
  • paths: limits the job to code / build / fuzz changes. If this is later made a required check, drop the filter or pair it with an always-pass companion job to avoid the required-check-plus-path-filter deadlock.
  • libtinfo5 (needed by the prebuilt LLVM's clang at runtime) is resolved at the runner's actual ncurses version with a pool-scrape fallback, rather than a hard-coded security-pocket .deb URL, so the install survives ncurses point-release bumps. The same hard-coded-URL pattern in .github/scripts/codeql_buildscript.sh is currently broken; fixed separately in Fix the currently-failing CodeQL workflow and run it on pull requests #4980.

Verification

Verified end-to-end on a pull request in a fork: both matrix legs build and run green in ~3.5 min each.

The libFuzzer harness in tests/fuzz/wasm-mutator-fuzz already runs
continuously on OSS-Fuzz, but nothing in-tree builds or exercises it on a
pull request, so a change that breaks the harness build or reintroduces a
fixed loader/validator crash is only caught out-of-band, hours to days
later via an OSS-Fuzz report.

Add a pull_request workflow that builds the same fast-interp and
classic-interp targets OSS-Fuzz builds (matching LLVM 18.1.8 and
wasm-tools 1.243.0), replays the committed tests/malformed/fuzz
regression corpus, and runs a short bounded fuzz, failing on any crash.
It needs no secrets and no write permissions, so it behaves identically
for pull requests opened within a repository and from forks.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant