33 lines
1.2 KiB
Plaintext
33 lines
1.2 KiB
Plaintext
LL| |#![allow(unused_assignments)]
|
|
LL| |//@ failure-status: 101
|
|
LL| |
|
|
LL| 4|fn might_panic(should_panic: bool) {
|
|
LL| 4| if should_panic {
|
|
LL| 1| println!("panicking...");
|
|
LL| 1| panic!("panics");
|
|
LL| 3| } else {
|
|
LL| 3| println!("Don't Panic");
|
|
LL| 3| }
|
|
LL| 3|}
|
|
LL| |
|
|
LL| 1|fn main() -> Result<(), u8> {
|
|
LL| 1| let mut countdown = 10;
|
|
LL| 11| while countdown > 0 {
|
|
LL| 11| if countdown == 1 {
|
|
LL| 1| might_panic(true);
|
|
LL| 10| } else if countdown < 5 {
|
|
LL| 3| might_panic(false);
|
|
LL| 6| }
|
|
LL| 10| countdown -= 1;
|
|
LL| | }
|
|
LL| 0| Ok(())
|
|
LL| 0|}
|
|
LL| |
|
|
LL| |// Notes:
|
|
LL| |// 1. Compare this program and its coverage results to those of the similar tests `abort.rs` and
|
|
LL| |// `try_error_result.rs`.
|
|
LL| |// 2. Since the `panic_unwind.rs` test is allowed to unwind, it is also allowed to execute the
|
|
LL| |// normal program exit cleanup, including writing out the current values of the coverage
|
|
LL| |// counters.
|
|
|