36 lines
1.3 KiB
Markdown
36 lines
1.3 KiB
Markdown
|
|
# Smokes — How‑To(前提→手順→検証)
|
|||
|
|
|
|||
|
|
目的
|
|||
|
|
- 代表スモークを素早く回して、回帰を検知する。
|
|||
|
|
|
|||
|
|
前提
|
|||
|
|
- リリースビルド済み: `cargo build --release --features llvm`
|
|||
|
|
- LLVM 18 が導入済み(AOT 経路のとき)
|
|||
|
|
|
|||
|
|
手順(推奨ランナー)
|
|||
|
|
1) LLVM curated
|
|||
|
|
- 実行: `tools/smokes/curated_llvm.sh [--phi-off]`
|
|||
|
|
- `--phi-off`: `NYASH_MIR_NO_PHI=1` を有効化し、検証を緩和
|
|||
|
|
2) PHI 不変条件パリティ
|
|||
|
|
- 実行: `tools/smokes/curated_phi_invariants.sh`
|
|||
|
|
- PyVM と llvmlite の stdout/exit code を比較
|
|||
|
|
|
|||
|
|
手動スモーク(例)
|
|||
|
|
- Core (LLVM): `examples/llvm11_core_smoke.nyash`
|
|||
|
|
- Async (LLVM only):
|
|||
|
|
- `apps/tests/async-await-min/main.nyash`
|
|||
|
|
- `apps/tests/async-spawn-instance/main.nyash`
|
|||
|
|
- `apps/tests/async-await-timeout-fixed/main.nyash`(`NYASH_AWAIT_MAX_MS=100`)
|
|||
|
|
|
|||
|
|
アーカイブ(非推奨)
|
|||
|
|
- `tools/smokes/archive/` に旧ランナー(JIT/Cranelift 時代)が存在
|
|||
|
|
- `smoke_phase_10_10.sh`, `smoke_vm_jit.sh`, `smoke_async_spawn.sh`, `jit_smoke.sh`, `aot_smoke_cranelift.sh`
|
|||
|
|
- これらは基本使わず、curated 系を使用
|
|||
|
|
|
|||
|
|
便利フラグ
|
|||
|
|
- `NYASH_LLVM_USE_HARNESS=1`: llvmlite ハーネス経由
|
|||
|
|
- `NYASH_MIR_NO_PHI=1`, `NYASH_VERIFY_ALLOW_NO_PHI=1`: PHI 無しモード
|
|||
|
|
|
|||
|
|
検証
|
|||
|
|
- 0 で成功、非 0 で失敗(CI 連携可)
|