Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix WASI rename issue: #2297 #2397

Merged
merged 10 commits into from
Jun 23, 2021
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,7 @@ Looking for changes that affect our C API? See the [C API Changelog](lib/c-api/C
- [#2157](https://github.com/wasmerio/wasmer/pull/2157) Simplify the code behind `WasmPtr`

### Fixed
- [#2397](https://github.com/wasmerio/wasmer/pull/2397) Fix WASI rename temporary file issue.
- [#2391](https://github.com/wasmerio/wasmer/pull/2391) Fix Singlepass emit bug, [#2347](https://github.com/wasmerio/wasmer/issues/2347) and [#2159](https://github.com/wasmerio/wasmer/issues/2159)
- [#2327](https://github.com/wasmerio/wasmer/pull/2327) Fix memory leak preventing internal instance memory from being freed when a WasmerEnv contained an exported extern (e.g. Memory, etc.).
- [#2247](https://github.com/wasmerio/wasmer/pull/2247) Internal WasiFS logic updated to be closer to what WASI libc does when finding a preopened fd for a path.
Expand Down
2 changes: 1 addition & 1 deletion lib/wasi/src/syscalls/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2068,7 +2068,7 @@ pub fn path_rename(
return __WASI_EEXIST;
}
let mut out_path = path.clone();
out_path.push(target_path);
out_path.push(std::path::Path::new(&target_entry_name));
out_path
}
Kind::Root { .. } => return __WASI_ENOTCAPABLE,
Expand Down
Binary file modified tests/wasi-wast/wasi/snapshot1/path_rename.wasm
Binary file not shown.
2 changes: 1 addition & 1 deletion tests/wasi-wast/wasi/snapshot1/path_rename.wast
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,5 @@
(wasi_test "path_rename.wasm"
(temp_dirs "temp")
(assert_return (i64.const 0))
(assert_stdout "The original file does not still exist!\nFound item: path_renamed_file.txt\n柴犬\n")
(assert_stdout "The original file does not still exist!\nFound item: path_renamed_file.txt\n柴犬\nrun_with_sub_dir: The original file does not still exist!\nrun_with_different_sub_dirs: The original file does not still exist!\n")
)
94 changes: 93 additions & 1 deletion tests/wasi-wast/wasi/tests/path_rename.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ use std::fs;
use std::io::{Read, Write};
use std::path::PathBuf;

fn main() {
fn run_with_toplevel_dir() {
#[cfg(not(target_os = "wasi"))]
let mut base = PathBuf::from("test_fs");
#[cfg(target_os = "wasi")]
Expand Down Expand Up @@ -73,3 +73,95 @@ fn main() {
println!("{}", test_str);
std::fs::remove_file(file_to_rename_to).unwrap();
}

fn run_with_sub_dir() {
chenyukang marked this conversation as resolved.
Show resolved Hide resolved
#[cfg(not(target_os = "wasi"))]
let base = PathBuf::from("test_fs");
#[cfg(target_os = "wasi")]
let mut base = PathBuf::from("temp");

//make a sub-directory
fs::create_dir(base.join("sub"));

let file_to_create = base.join("sub/path_rename_file.txt");
let file_to_rename_to = base.join("sub/path_renamed_file.txt");

{
let mut f = std::fs::OpenOptions::new()
.create_new(true)
.write(true)
.open(&file_to_create)
.unwrap();

let string = "Hello world";
let bytes: Vec<u8> = string.bytes().collect();
f.write_all(&bytes[..]).unwrap();
}

std::fs::rename(&file_to_create, &file_to_rename_to).unwrap();
let mut file = fs::File::open(&file_to_rename_to).expect("Could not open file");
if file_to_create.exists() {
println!("run_with_sub_dir: The original file still exists!");
return;
} else {
println!("run_with_sub_dir: The original file does not still exist!");
}

if !file_to_rename_to.exists() {
println!("run_with_sub_dir: The moved file does not exist!");
return;
}
fs::remove_dir_all(base.join("sub"));
}

fn run_with_different_sub_dirs() {
#[cfg(not(target_os = "wasi"))]
let base = PathBuf::from("test_fs");
#[cfg(target_os = "wasi")]
let mut base = PathBuf::from("temp");

//make sub-directories
fs::create_dir(base.join("a"));
fs::create_dir(base.join("a/b"));
fs::create_dir(base.join("c"));
fs::create_dir(base.join("c/d"));
fs::create_dir(base.join("c/d/e"));

let file_to_create = base.join("a/b/path_rename_file.txt");
let file_to_rename_to = base.join("c/d/e/path_renamed_file.txt");

{
let mut f = std::fs::OpenOptions::new()
.create_new(true)
.write(true)
.open(&file_to_create)
.unwrap();

let string = "Hello world";
let bytes: Vec<u8> = string.bytes().collect();
f.write_all(&bytes[..]).unwrap();
}

std::fs::rename(&file_to_create, &file_to_rename_to).unwrap();
let mut file = fs::File::open(&file_to_rename_to).expect("Could not open file");
if file_to_create.exists() {
println!("run_with_different_sub_dirs: The original file still exists!");
return;
} else {
println!("run_with_different_sub_dirs: The original file does not still exist!");
}

if !file_to_rename_to.exists() {
println!("run_with_different_sub_dirs: The moved file does not exist!");
return;
}

fs::remove_dir_all(base.join("a"));
fs::remove_dir_all(base.join("c"));
}

fn main() {
run_with_toplevel_dir();
run_with_sub_dir();
run_with_different_sub_dirs();
}
Binary file modified tests/wasi-wast/wasi/unstable/path_rename.wasm
Binary file not shown.
2 changes: 1 addition & 1 deletion tests/wasi-wast/wasi/unstable/path_rename.wast
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,5 @@
(wasi_test "path_rename.wasm"
(temp_dirs "temp")
(assert_return (i64.const 0))
(assert_stdout "The original file does not still exist!\nFound item: path_renamed_file.txt\n柴犬\n")
(assert_stdout "The original file does not still exist!\nFound item: path_renamed_file.txt\n柴犬\nrun_with_sub_dir: The original file does not still exist!\nrun_with_different_sub_dirs: The original file does not still exist!\n")
)