use super::*;
use test_programs_artifacts::*;
use wasi_common::sync::{WasiCtxBuilder, add_to_linker};
foreach_p1!(assert_test_exists);
fn run(path: &str, inherit_stdio: bool) -> Result<()> {
let path = Path::new(path);
let name = path.file_stem().unwrap().to_str().unwrap();
let workspace = prepare_workspace(name)?;
let stdout = WritePipe::new_in_memory();
let stderr = WritePipe::new_in_memory();
let r = {
let engine = test_programs_artifacts::engine(|_| {});
let mut linker = Linker::new(&engine);
add_to_linker(&mut linker, |cx| cx)?;
let mut builder = WasiCtxBuilder::new();
if inherit_stdio {
builder.inherit_stdio();
} else {
builder
.stdout(Box::new(stdout.clone()))
.stderr(Box::new(stderr.clone()));
}
builder.arg(name)?.arg(".")?;
println!("preopen: {workspace:?}");
let preopen_dir =
cap_std::fs::Dir::open_ambient_dir(workspace.path(), cap_std::ambient_authority())?;
builder.preopened_dir(preopen_dir, ".")?;
for (var, val) in test_programs_artifacts::wasi_tests_environment() {
builder.env(var, val)?;
}
let mut store = Store::new(&engine, builder.build());
let module = Module::from_file(&engine, path)?;
let instance = linker.instantiate(&mut store, &module)?;
let start = instance.get_typed_func::<(), ()>(&mut store, "_start")?;
start.call(&mut store, ())?;
Ok(())
};
r.map_err(move |trap: EnvError| {
let stdout = stdout
.try_into_inner()
.expect("sole ref to stdout")
.into_inner();
if !stdout.is_empty() {
println!("guest stdout:\n{}\n===", String::from_utf8_lossy(&stdout));
}
let stderr = stderr
.try_into_inner()
.expect("sole ref to stderr")
.into_inner();
if !stderr.is_empty() {
println!("guest stderr:\n{}\n===", String::from_utf8_lossy(&stderr));
}
trap.context(format!(
"error while testing wasi-tests {name} with cap-std-sync"
))
})?;
Ok(())
}
#[test_log::test]
fn p1_big_random_buf() {
run(P1_BIG_RANDOM_BUF, true).unwrap()
}
#[test_log::test]
fn p1_clock_time_get() {
run(P1_CLOCK_TIME_GET, true).unwrap()
}
#[test_log::test]
fn p1_close_preopen() {
run(P1_CLOSE_PREOPEN, true).unwrap()
}
#[test_log::test]
fn p1_dangling_fd() {
run(P1_DANGLING_FD, true).unwrap()
}
#[test_log::test]
fn p1_dangling_symlink() {
run(P1_DANGLING_SYMLINK, true).unwrap()
}
#[test_log::test]
fn p1_directory_seek() {
run(P1_DIRECTORY_SEEK, true).unwrap()
}
#[test_log::test]
fn p1_dir_fd_op_failures() {
run(P1_DIR_FD_OP_FAILURES, true).unwrap()
}
#[test_log::test]
fn p1_fd_advise() {
run(P1_FD_ADVISE, true).unwrap()
}
#[test_log::test]
fn p1_fd_filestat_get() {
run(P1_FD_FILESTAT_GET, true).unwrap()
}
#[test_log::test]
fn p1_fd_filestat_set() {
run(P1_FD_FILESTAT_SET, true).unwrap()
}
#[test_log::test]
fn p1_fd_flags_set() {
run(P1_FD_FLAGS_SET, true).unwrap()
}
#[test_log::test]
fn p1_fd_readdir() {
run(P1_FD_READDIR, true).unwrap()
}
#[test_log::test]
fn p1_file_allocate() {
run(P1_FILE_ALLOCATE, true).unwrap()
}
#[test_log::test]
#[cfg_attr(not(target_os = "linux"), ignore)]
fn p1_file_pread_pwrite() {
run(P1_FILE_PREAD_PWRITE, true).unwrap()
}
#[test_log::test]
fn p1_file_read_write() {
run(P1_FILE_READ_WRITE, true).unwrap()
}
#[test_log::test]
fn p1_file_seek_tell() {
run(P1_FILE_SEEK_TELL, true).unwrap()
}
#[test_log::test]
fn p1_file_truncation() {
run(P1_FILE_TRUNCATION, true).unwrap()
}
#[test_log::test]
fn p1_file_unbuffered_write() {
run(P1_FILE_UNBUFFERED_WRITE, true).unwrap()
}
#[test_log::test]
fn p1_interesting_paths() {
run(P1_INTERESTING_PATHS, true).unwrap()
}
#[test_log::test]
fn p1_regular_file_isatty() {
run(P1_REGULAR_FILE_ISATTY, true).unwrap()
}
#[test_log::test]
fn p1_nofollow_errors() {
run(P1_NOFOLLOW_ERRORS, true).unwrap()
}
#[test_log::test]
fn p1_overwrite_preopen() {
run(P1_OVERWRITE_PREOPEN, true).unwrap()
}
#[test_log::test]
fn p1_path_exists() {
run(P1_PATH_EXISTS, true).unwrap()
}
#[test_log::test]
fn p1_path_filestat() {
run(P1_PATH_FILESTAT, true).unwrap()
}
#[test_log::test]
fn p1_path_link() {
run(P1_PATH_LINK, true).unwrap()
}
#[test_log::test]
fn p1_path_open_create_existing() {
run(P1_PATH_OPEN_CREATE_EXISTING, true).unwrap()
}
#[test_log::test]
fn p1_path_open_read_write() {
run(P1_PATH_OPEN_READ_WRITE, true).unwrap()
}
#[test_log::test]
fn p1_path_open_dirfd_not_dir() {
run(P1_PATH_OPEN_DIRFD_NOT_DIR, true).unwrap()
}
#[test_log::test]
fn p1_path_open_missing() {
run(P1_PATH_OPEN_MISSING, true).unwrap()
}
#[test_log::test]
fn p1_path_open_nonblock() {
run(P1_PATH_OPEN_NONBLOCK, true).unwrap()
}
#[test_log::test]
fn p1_path_rename_dir_trailing_slashes() {
run(P1_PATH_RENAME_DIR_TRAILING_SLASHES, true).unwrap()
}
#[test_log::test]
fn p1_path_rename() {
run(P1_PATH_RENAME, true).unwrap()
}
#[test_log::test]
fn p1_path_symlink_trailing_slashes() {
run(P1_PATH_SYMLINK_TRAILING_SLASHES, true).unwrap()
}
#[test_log::test]
fn p1_poll_oneoff_files() {
run(P1_POLL_ONEOFF_FILES, false).unwrap()
}
#[test_log::test]
fn p1_poll_oneoff_stdio() {
run(P1_POLL_ONEOFF_STDIO, true).unwrap()
}
#[test_log::test]
fn p1_readlink() {
run(P1_READLINK, true).unwrap()
}
#[test_log::test]
fn p1_remove_directory() {
run(P1_REMOVE_DIRECTORY, true).unwrap()
}
#[test_log::test]
fn p1_remove_nonempty_directory() {
run(P1_REMOVE_NONEMPTY_DIRECTORY, true).unwrap()
}
#[test_log::test]
fn p1_renumber() {
run(P1_RENUMBER, true).unwrap()
}
#[test_log::test]
fn p1_sched_yield() {
run(P1_SCHED_YIELD, true).unwrap()
}
#[test_log::test]
fn p1_stdio() {
run(P1_STDIO, true).unwrap()
}
#[test_log::test]
fn p1_stdio_isatty() {
if test_programs_artifacts::stdio_is_terminal() {
run(P1_STDIO_ISATTY, true).unwrap()
}
}
#[test_log::test]
fn p1_stdio_not_isatty() {
run(P1_STDIO_NOT_ISATTY, false).unwrap()
}
#[test_log::test]
fn p1_symlink_create() {
run(P1_SYMLINK_CREATE, true).unwrap()
}
#[test_log::test]
fn p1_symlink_filestat() {
run(P1_SYMLINK_FILESTAT, true).unwrap()
}
#[test_log::test]
fn p1_symlink_loop() {
run(P1_SYMLINK_LOOP, true).unwrap()
}
#[test_log::test]
fn p1_unlink_file_trailing_slashes() {
run(P1_UNLINK_FILE_TRAILING_SLASHES, true).unwrap()
}
#[test_log::test]
fn p1_path_open_preopen() {
run(P1_PATH_OPEN_PREOPEN, true).unwrap()
}
#[test_log::test]
fn p1_unicode_output() {
run(P1_UNICODE_OUTPUT, true).unwrap()
}
#[test_log::test]
fn p1_file_write() {
run(P1_FILE_WRITE, true).unwrap()
}
#[test_log::test]
fn p1_path_open_lots() {
run(P1_PATH_OPEN_LOTS, true).unwrap()
}
#[test_log::test]
fn p1_sleep_quickly_but_lots() {
run(P1_SLEEP_QUICKLY_BUT_LOTS, true).unwrap()
}