about summary refs log tree commit diff
path: root/tests/ui/process/process-sigpipe.rs
blob: 3ecf271599d23b312be5b2da90ea9da693f22e6b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
//@ run-pass
#![allow(unused_imports)]
#![allow(deprecated)]

//@ ignore-android since the dynamic linker sets a SIGPIPE handler (to do
// a crash report) so inheritance is moot on the entire platform

// libstd ignores SIGPIPE, and other libraries may set signal masks.
// Make sure that these behaviors don't get inherited to children
// spawned via std::process, since they're needed for traditional UNIX
// filter behavior.
// This test checks that `yes` or `while echo y ; do : ; done | head`
// terminates (instead of running forever), and that it does not print an
// error message about a broken pipe.

//@ ignore-vxworks no 'sh'
//@ ignore-fuchsia no 'sh'
//@ needs-threads
//@ only-unix SIGPIPE is a unix feature

use std::process;
use std::thread;

fn main() {
    // Just in case `yes` or `while-echo` doesn't check for EPIPE...
    thread::spawn(|| {
        thread::sleep_ms(5000);
        process::exit(1);
    });
    // QNX Neutrino does not have `yes`. Therefore, use `while-echo` for `nto`
    // and `yes` for other platforms.
    let command = if cfg!(target_os = "nto") {
        "while echo y ; do : ; done | head"
    } else {
        "yes | head"
    };
    let output = process::Command::new("sh")
        .arg("-c")
        .arg(command)
        .output()
        .unwrap();
    assert!(output.status.success());
    assert!(output.stderr.len() == 0);
}