//! The logic that gets executed before building the binary and tests. //! We use it to auto-generate the Wasm spectests for each of the //! available compilers. //! //! Please try to keep this file as clean as possible. use std::env; use std::fs; use std::path::PathBuf; use std::process::Command; use test_generator::{ build_ignores_from_textfile, test_directory, test_directory_module, wasi_processor, wast_processor, with_features, with_test_module, Testsuite, }; fn main() -> anyhow::Result<()> { println!("cargo:rerun-if-changed=tests/ignores.txt"); // As rerun-if-changed doesn't support globs, we use another crate // to check changes in directories. build_deps::rerun_if_changed_paths("tests/wasi-wast/wasi/unstable/*") .expect("Can't get directory"); build_deps::rerun_if_changed_paths("tests/wasi-wast/wasi/snapshot1/*") .expect("Can't get directory"); let out_dir = PathBuf::from( env::var_os("OUT_DIR").expect("The OUT_DIR environment variable must be set"), ); let ignores = build_ignores_from_textfile("tests/ignores.txt".into())?; let compilers = ["singlepass", "cranelift", "llvm"]; // Spectests test generation { let mut spectests = Testsuite { buffer: String::new(), path: vec![], ignores: ignores.clone(), }; with_features(&mut spectests, &compilers, |mut spectests| { with_test_module(&mut spectests, "spec", |spectests| { let _spec_tests = test_directory(spectests, "tests/wast/spec", wast_processor)?; test_directory_module( spectests, "tests/wast/spec/proposals/multi-value", wast_processor, )?; test_directory_module(spectests, "tests/wast/spec/proposals/simd", wast_processor)?; // test_directory_module(spectests, "tests/wast/spec/proposals/bulk-memory-operations", wast_processor)?; Ok(()) })?; with_test_module(&mut spectests, "wasmer", |spectests| { let _spec_tests = test_directory(spectests, "tests/wast/wasmer", wast_processor)?; Ok(()) })?; Ok(()) })?; let spectests_output = out_dir.join("generated_spectests.rs"); fs::write(&spectests_output, spectests.buffer)?; // Write out our auto-generated tests and opportunistically format them with // `rustfmt` if it's installed. // Note: We need drop because we don't want to run `unwrap` or `expect` as // the command might fail, but we don't care about it's result. drop(Command::new("rustfmt").arg(&spectests_output).status()); } // Wasitest test generation { let mut wasitests = Testsuite { buffer: String::new(), path: vec![], ignores, }; let wasi_versions = ["unstable", "snapshot1"]; with_features(&mut wasitests, &compilers, |mut wasitests| { with_test_module(&mut wasitests, "wasitests", |wasitests| { for wasi_version in &wasi_versions { with_test_module(wasitests, wasi_version, |wasitests| { let _wasi_tests = test_directory( wasitests, format!("tests/wasi-wast/wasi/{}", wasi_version), wasi_processor, )?; Ok(()) })?; } Ok(()) })?; Ok(()) })?; let wasitests_output = out_dir.join("generated_wasitests.rs"); fs::write(&wasitests_output, wasitests.buffer)?; drop(Command::new("rustfmt").arg(&wasitests_output).status()); } Ok(()) }