1
Fork 0
mirror of https://github.com/RGBCube/uutils-coreutils synced 2025-07-27 11:07:44 +00:00

Merge pull request #8219 from Maximkaaa/tee_no_more_writable

tests/tee: enable no_more_writable test
This commit is contained in:
Daniel Hofstetter 2025-06-18 18:51:33 +02:00 committed by GitHub
commit 2ba6c32687
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -134,32 +134,6 @@ fn test_readonly() {
assert_eq!(at.read(writable_file), content_tee); assert_eq!(at.read(writable_file), content_tee);
} }
#[test]
#[cfg(target_os = "linux")]
fn test_tee_no_more_writeable_2() {
// should be equals to 'tee out1 out2 >/dev/full <multi_read' call
// but currently there is no way to redirect stdout to /dev/full
// so this test is disabled
let (_at, mut ucmd) = at_and_ucmd!();
let _content = (1..=10).fold(String::new(), |mut output, x| {
let _ = writeln!(output, "{x}");
output
});
let file_out_a = "tee_file_out_a";
let file_out_b = "tee_file_out_b";
let _result = ucmd
.arg(file_out_a)
.arg(file_out_b)
.pipe_in("/dev/full")
.succeeds(); // TODO: expected to succeed currently; change to fails() when required
// TODO: comment in after https://github.com/uutils/coreutils/issues/1805 is fixed
// assert_eq!(at.read(file_out_a), content);
// assert_eq!(at.read(file_out_b), content);
// assert!(result.stderr.contains("No space left on device"));
}
#[cfg(target_os = "linux")] #[cfg(target_os = "linux")]
mod linux_only { mod linux_only {
use uutests::util::{AtPath, CmdResult, TestScenario, UCommand}; use uutests::util::{AtPath, CmdResult, TestScenario, UCommand};
@ -581,4 +555,28 @@ mod linux_only {
expect_success(&output); expect_success(&output);
expect_correct(file_out_a, &at, content.as_str()); expect_correct(file_out_a, &at, content.as_str());
} }
#[test]
fn test_tee_no_more_writeable_2() {
use std::fs::File;
let (at, mut ucmd) = at_and_ucmd!();
let content = (1..=10).fold(String::new(), |mut output, x| {
let _ = writeln!(output, "{x}");
output
});
let file_out_a = "tee_file_out_a";
let file_out_b = "tee_file_out_b";
let dev_full = File::options().append(true).open("/dev/full").unwrap();
let result = ucmd
.arg(file_out_a)
.arg(file_out_b)
.set_stdout(dev_full)
.pipe_in(content.as_bytes())
.fails();
assert_eq!(at.read(file_out_a), content);
assert_eq!(at.read(file_out_b), content);
assert!(result.stderr_str().contains("No space left on device"));
}
} }