wasi-common: deprecate fd_allocate (#6217)
* wasi-common: remove allocate from WasiFile trait, always fail with NOTSUP This operation from cloudabi is linux-specific, isn't even supported across all linux filesystems, and has no support on macos or windows. Rather than ship spotty support, it has been removed from preview 2, and we are no longer supporting it in preview 1 as well. The preview 1 implementation will still check if fd is a file, and has rights, just to reject those cases with the errors expected. * wasi-tests: expect fd_allocate to always fail now. rewrite the file_allocate test to just check for failure. remove use of fd_allocate from fd_advise test, and remove test configuration setting used for excluding use of fd_allocate on macos and windows.
This commit is contained in:
@@ -1,5 +1,5 @@
|
||||
use std::{env, process};
|
||||
use wasi_tests::{open_scratch_directory, TESTCONFIG};
|
||||
use wasi_tests::open_scratch_directory;
|
||||
|
||||
unsafe fn test_fd_advise(dir_fd: wasi::Fd) {
|
||||
// Create a file in the scratch directory.
|
||||
@@ -40,14 +40,6 @@ unsafe fn test_fd_advise(dir_fd: wasi::Fd) {
|
||||
let stat = wasi::fd_filestat_get(file_fd).expect("failed to fdstat 3");
|
||||
assert_eq!(stat.size, 100, "file size should be 100");
|
||||
|
||||
if TESTCONFIG.support_fd_allocate() {
|
||||
// Use fd_allocate to expand size to 200:
|
||||
wasi::fd_allocate(file_fd, 100, 100).expect("allocating size");
|
||||
|
||||
let stat = wasi::fd_filestat_get(file_fd).expect("failed to fdstat 3");
|
||||
assert_eq!(stat.size, 200, "file size should be 200");
|
||||
}
|
||||
|
||||
wasi::fd_close(file_fd).expect("failed to close");
|
||||
wasi::path_unlink_file(dir_fd, "file").expect("failed to unlink");
|
||||
}
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
use std::{env, process};
|
||||
use wasi_tests::{open_scratch_directory, TESTCONFIG};
|
||||
use wasi_tests::open_scratch_directory;
|
||||
|
||||
unsafe fn test_file_allocate(dir_fd: wasi::Fd) {
|
||||
// Create a file in the scratch directory.
|
||||
@@ -25,22 +25,18 @@ unsafe fn test_file_allocate(dir_fd: wasi::Fd) {
|
||||
let mut stat = wasi::fd_filestat_get(file_fd).expect("reading file stats");
|
||||
assert_eq!(stat.size, 0, "file size should be 0");
|
||||
|
||||
if TESTCONFIG.support_fd_allocate() {
|
||||
// Allocate some size
|
||||
wasi::fd_allocate(file_fd, 0, 100).expect("allocating size");
|
||||
stat = wasi::fd_filestat_get(file_fd).expect("reading file stats");
|
||||
assert_eq!(stat.size, 100, "file size should be 100");
|
||||
let err = wasi::fd_allocate(file_fd, 0, 100)
|
||||
.err()
|
||||
.expect("fd_allocate must fail");
|
||||
assert_eq!(
|
||||
err,
|
||||
wasi::ERRNO_NOTSUP,
|
||||
"fd_allocate should fail with NOTSUP"
|
||||
);
|
||||
|
||||
// Allocate should not modify if less than current size
|
||||
wasi::fd_allocate(file_fd, 10, 10).expect("allocating size less than current size");
|
||||
stat = wasi::fd_filestat_get(file_fd).expect("reading file stats");
|
||||
assert_eq!(stat.size, 100, "file size should remain unchanged at 100");
|
||||
stat = wasi::fd_filestat_get(file_fd).expect("reading file stats");
|
||||
assert_eq!(stat.size, 0, "file size should still be 0");
|
||||
|
||||
// Allocate should modify if offset+len > current_len
|
||||
wasi::fd_allocate(file_fd, 90, 20).expect("allocating size larger than current size");
|
||||
stat = wasi::fd_filestat_get(file_fd).expect("reading file stats");
|
||||
assert_eq!(stat.size, 110, "file size should increase from 100 to 110");
|
||||
}
|
||||
wasi::fd_close(file_fd).expect("closing a file");
|
||||
wasi::path_unlink_file(dir_fd, "file").expect("removing a file");
|
||||
}
|
||||
|
||||
@@ -1,7 +1,6 @@
|
||||
pub struct TestConfig {
|
||||
errno_mode: ErrnoMode,
|
||||
no_dangling_filesystem: bool,
|
||||
no_fd_allocate: bool,
|
||||
no_rename_dir_to_empty_dir: bool,
|
||||
no_fdflags_sync_support: bool,
|
||||
}
|
||||
@@ -25,13 +24,11 @@ impl TestConfig {
|
||||
ErrnoMode::Permissive
|
||||
};
|
||||
let no_dangling_filesystem = std::env::var("NO_DANGLING_FILESYSTEM").is_ok();
|
||||
let no_fd_allocate = std::env::var("NO_FD_ALLOCATE").is_ok();
|
||||
let no_rename_dir_to_empty_dir = std::env::var("NO_RENAME_DIR_TO_EMPTY_DIR").is_ok();
|
||||
let no_fdflags_sync_support = std::env::var("NO_FDFLAGS_SYNC_SUPPORT").is_ok();
|
||||
TestConfig {
|
||||
errno_mode,
|
||||
no_dangling_filesystem,
|
||||
no_fd_allocate,
|
||||
no_rename_dir_to_empty_dir,
|
||||
no_fdflags_sync_support,
|
||||
}
|
||||
@@ -57,9 +54,6 @@ impl TestConfig {
|
||||
pub fn support_dangling_filesystem(&self) -> bool {
|
||||
!self.no_dangling_filesystem
|
||||
}
|
||||
pub fn support_fd_allocate(&self) -> bool {
|
||||
!self.no_fd_allocate
|
||||
}
|
||||
pub fn support_rename_dir_to_empty_dir(&self) -> bool {
|
||||
!self.no_rename_dir_to_empty_dir
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user