cf6d6050f7
* The WASI targets deal with the `main` symbol a bit differently than native so some `codegen` and `assembly` tests have been ignored. * All `ignore-emscripten` directives have been updated to `ignore-wasm32` to be more clear that all wasm targets are ignored and it's not just Emscripten. * Most `ignore-wasm32-bare` directives are now gone. * Some ignore directives for wasm were switched to `needs-unwind` instead. * Many `ignore-wasm32*` directives are removed as the tests work with WASI as opposed to `wasm32-unknown-unknown`.
45 lines
1.3 KiB
Rust
45 lines
1.3 KiB
Rust
//@ run-pass
|
|
//@ check-run-results
|
|
//@ ignore-windows
|
|
//@ ignore-wasm32
|
|
//@ ignore-fuchsia
|
|
//@ ignore-horizon
|
|
//@ ignore-android
|
|
//@ normalize-stderr-test ".rs:\d+:\d+" -> ".rs:LL:CC"
|
|
|
|
// Test what the error message looks like when `println!()` panics because of
|
|
// `std::io::ErrorKind::BrokenPipe`
|
|
|
|
#![feature(unix_sigpipe)]
|
|
|
|
use std::env;
|
|
use std::process::{Command, Stdio};
|
|
|
|
#[unix_sigpipe = "sig_ign"]
|
|
fn main() {
|
|
let mut args = env::args();
|
|
let me = args.next().unwrap();
|
|
|
|
if let Some(arg) = args.next() {
|
|
// More than enough iterations to fill any pipe buffer. Normally this
|
|
// loop will end with a panic more or less immediately.
|
|
for _ in 0..65536 * 64 {
|
|
println!("{arg}");
|
|
}
|
|
unreachable!("should have panicked because of BrokenPipe");
|
|
}
|
|
|
|
// Set up a pipeline with a short-lived consumer and wait for it to finish.
|
|
// This will produce the `println!()` panic message on stderr.
|
|
let mut producer = Command::new(&me)
|
|
.arg("this line shall appear exactly once on stdout")
|
|
.env("RUST_BACKTRACE", "0")
|
|
.stdout(Stdio::piped())
|
|
.spawn()
|
|
.unwrap();
|
|
let mut consumer =
|
|
Command::new("head").arg("-n1").stdin(producer.stdout.take().unwrap()).spawn().unwrap();
|
|
consumer.wait().unwrap();
|
|
producer.wait().unwrap();
|
|
}
|