1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-08 23:28:18 -05:00

fix(core): don't panic on stdout/stderr write failures in Deno.core.print (#11039)

This commit is contained in:
Charlie Moog 2021-06-21 21:39:59 -05:00 committed by GitHub
parent 188222b893
commit 580c9f9ef0
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 25 additions and 2 deletions

View file

@ -3230,6 +3230,29 @@ console.log("finish");
util::test_pty(args, output, input);
}
#[test]
fn broken_stdout() {
let (reader, writer) = os_pipe::pipe().unwrap();
// drop the reader to create a broken pipe
drop(reader);
let output = util::deno_cmd()
.current_dir(util::root_path())
.arg("eval")
.arg("console.log(3.14)")
.stdout(writer)
.stderr(std::process::Stdio::piped())
.spawn()
.unwrap()
.wait_with_output()
.unwrap();
assert!(!output.status.success());
let stderr = std::str::from_utf8(output.stderr.as_ref()).unwrap().trim();
assert!(stderr.contains("Uncaught BrokenPipe"));
assert!(!stderr.contains("panic"));
}
itest!(_091_use_define_for_class_fields {
args: "run 091_use_define_for_class_fields.ts",
output: "091_use_define_for_class_fields.ts.out",

View file

@ -61,10 +61,10 @@ pub fn op_print(
is_err: bool,
) -> Result<(), AnyError> {
if is_err {
eprint!("{}", msg);
stderr().write_all(msg.as_bytes())?;
stderr().flush().unwrap();
} else {
print!("{}", msg);
stdout().write_all(msg.as_bytes())?;
stdout().flush().unwrap();
}
Ok(())