2025-11-11 02:07:12 +09:00
|
|
|
Smokes v2 — Minimal Runner and Policy
|
2025-11-10 19:42:42 +09:00
|
|
|
|
2025-11-11 02:07:12 +09:00
|
|
|
Policy
|
|
|
|
|
- Use [SKIP:<reason>] prefix for environment/host dependent skips.
|
|
|
|
|
- Examples: [SKIP] hakorune not built, [SKIP:env] plugin path missing
|
|
|
|
|
- Keep reasons short and stable to allow grep-based canaries.
|
|
|
|
|
- Prefer JSON-only output in CI: set `NYASH_JSON_ONLY=1` to avoid noisy logs.
|
|
|
|
|
- Diagnostics lines like `[provider/select:*]` are filtered by default in `lib/test_runner.sh`.
|
2025-11-13 16:40:58 +09:00
|
|
|
- Toggle: set `HAKO_SILENT_TAGS=0` to disable filtering and show raw logs. `HAKO_SHOW_CALL_LOGS=1` also bypasses filtering.
|
2025-11-10 19:42:42 +09:00
|
|
|
|
2025-11-11 02:07:12 +09:00
|
|
|
Helpers
|
|
|
|
|
- `tools/smokes/v2/lib/mir_canary.sh` provides:
|
|
|
|
|
- `extract_mir_from_output` — between [MIR_BEGIN]/[MIR_END]
|
|
|
|
|
- `assert_has_tokens`, `assert_skip_tag`, `assert_order`, `assert_token_count`
|
|
|
|
|
- `tools/lib/canary.sh` provides minimal, harness-agnostic aliases:
|
|
|
|
|
- `extract_mir_between_tags` — same as `extract_mir_from_output`
|
|
|
|
|
- `require_tokens token...` — fail if any token missing
|
2025-11-10 19:42:42 +09:00
|
|
|
|
2025-11-11 02:07:12 +09:00
|
|
|
Notes
|
|
|
|
|
- Avoid running heavy integration smokes in CI by default. Use `--profile quick`.
|
|
|
|
|
- When a test depends on external tools (e.g., LLVM), prefer `[SKIP:<reason>]` over failure.
|
2025-09-24 09:30:42 +09:00
|
|
|
|
2025-11-11 02:07:12 +09:00
|
|
|
Quick tips
|
|
|
|
|
- EXE-heavy cases (e.g., `phase2100/*`) may take longer. When running quick with these tests, pass a larger timeout like `--timeout 120`.
|
|
|
|
|
- Smokes v2 auto-cleans temporary crate EXE objects created under `/tmp` (pattern: `ny_crate_backend_exe_*.o`) after the run.
|