diff options
| author | Ben Kimock <kimockb@gmail.com> | 2023-03-28 21:37:15 -0400 |
|---|---|---|
| committer | Ben Kimock <kimockb@gmail.com> | 2023-03-28 21:37:15 -0400 |
| commit | 9f17ede4acd28df8c0468984d53b965bfbaea8dc (patch) | |
| tree | 1555185e06b42c0eee3804b6a5fcdbf22d1da867 /tests | |
| parent | 67540ec950b9bb5919c3c51dcf9fd6b3d380b7dc (diff) | |
| download | rust-9f17ede4acd28df8c0468984d53b965bfbaea8dc.tar.gz rust-9f17ede4acd28df8c0468984d53b965bfbaea8dc.zip | |
Raise an aborting signal without UB
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/ui/process/signal-exit-status.rs | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/tests/ui/process/signal-exit-status.rs b/tests/ui/process/signal-exit-status.rs index 9519ed7b4c7..0f05f916cb9 100644 --- a/tests/ui/process/signal-exit-status.rs +++ b/tests/ui/process/signal-exit-status.rs @@ -4,14 +4,16 @@ // ignore-windows // ignore-fuchsia code returned as ZX_TASK_RETCODE_EXCEPTION_KILL, FIXME (#58590) +#![feature(core_intrinsics)] + use std::env; use std::process::Command; pub fn main() { let args: Vec<String> = env::args().collect(); if args.len() >= 2 && args[1] == "signal" { - // Raise a segfault. - unsafe { *(1 as *mut isize) = 0; } + // Raise an aborting signal without UB + core::intrinsics::abort(); } else { let status = Command::new(&args[0]).arg("signal").status().unwrap(); assert!(status.code().is_none()); |
