1d6643c4f6
To fix the linker errors, we need to set the output extension to `.js` instead of `.wasm`. Setting the output to a `.wasm` file puts Emscripten into standalone mode which is effectively a distinct target. We need to set the runner to be `node` as well. This fixes most of the ui tests. I fixed a few more tests with simple problems: - `intrinsics/intrinsic-alignment.rs` and `structs-enums/rec-align-u64.rs` -- Two `#[cfg]` macros match for Emscripten so we got a duplicate definition of `mod m`. - `issues/issue-12699.rs` -- Seems to hang so I disabled it - `process/process-sigpipe.rs` -- Not expected to work on Emscripten so I disabled it
37 lines
1.1 KiB
Rust
37 lines
1.1 KiB
Rust
//@ 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 `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'
|
|
//@ ignore-emscripten No threads
|
|
//@ only-unix SIGPIPE is a unix feature
|
|
|
|
use std::process;
|
|
use std::thread;
|
|
|
|
fn main() {
|
|
// Just in case `yes` doesn't check for EPIPE...
|
|
thread::spawn(|| {
|
|
thread::sleep_ms(5000);
|
|
process::exit(1);
|
|
});
|
|
let output = process::Command::new("sh")
|
|
.arg("-c")
|
|
.arg("while echo y ; do : ; done | head")
|
|
.output()
|
|
.unwrap();
|
|
assert!(output.status.success());
|
|
assert!(output.stderr.len() == 0);
|
|
}
|