mirror of
https://github.com/rust-lang/rust.git
synced 2025-09-30 16:26:10 +00:00

And introduce two new directives for ui tests: * `run-crash` * `run-fail-or-crash` Normally a `run-fail` ui test like tests that panic shall not be terminated by a signal like `SIGABRT`. So begin having that as a hard requirement. Some of our current tests do terminate by a signal/crash however. Introduce and use `run-crash` for those tests. Note that Windows crashes are not handled by signals but by certain high bits set on the process exit code. Example exit code for crash on Windows: `0xc000001d`. Because of this, we define "crash" on all platforms as "not exit with success and not exit with a regular failure code in the range 1..=127". Some tests behave differently on different targets: * Targets without unwind support will abort (crash) instead of exit with failure code 101 after panicking. As a special case, allow crashes for `run-fail` tests for such targets. * Different sanitizer implementations handle detected memory problems differently. Some abort (crash) the process while others exit with failure code 1. Introduce and use `run-fail-or-crash` for such tests.
40 lines
1.2 KiB
Rust
40 lines
1.2 KiB
Rust
//@ revisions: unchk_pass unchk_fail_post chk_pass chk_fail_post
|
|
//
|
|
//@ [unchk_pass] run-pass
|
|
//@ [unchk_fail_post] run-pass
|
|
//@ [chk_pass] run-pass
|
|
//
|
|
//@ [chk_fail_post] run-crash
|
|
//
|
|
//@ [unchk_pass] compile-flags: -Zcontract-checks=no
|
|
//@ [unchk_fail_post] compile-flags: -Zcontract-checks=no
|
|
//
|
|
//@ [chk_pass] compile-flags: -Zcontract-checks=yes
|
|
//@ [chk_fail_post] compile-flags: -Zcontract-checks=yes
|
|
|
|
#![feature(contracts)] // to access core::contracts
|
|
//~^ WARN the feature `contracts` is incomplete and may not be safe to use and/or cause compiler crashes [incomplete_features]
|
|
#![feature(contracts_internals)] // to access check_requires lang item
|
|
#![feature(core_intrinsics)]
|
|
fn foo(x: Baz) -> i32 {
|
|
let injected_checker = {
|
|
core::contracts::build_check_ensures(|ret| *ret > 100)
|
|
};
|
|
|
|
let ret = x.baz + 50;
|
|
core::intrinsics::contract_check_ensures(injected_checker, ret)
|
|
}
|
|
|
|
struct Baz { baz: i32 }
|
|
|
|
|
|
const BAZ_PASS_PRE_POST: Baz = Baz { baz: 100 };
|
|
#[cfg(any(unchk_fail_post, chk_fail_post))]
|
|
const BAZ_FAIL_POST: Baz = Baz { baz: 10 };
|
|
|
|
fn main() {
|
|
assert_eq!(foo(BAZ_PASS_PRE_POST), 150);
|
|
#[cfg(any(unchk_fail_post, chk_fail_post))]
|
|
foo(BAZ_FAIL_POST);
|
|
}
|