blob: 14ba36238d62f522077aa97c7a03decbf3f6ec0d [file] [log] [blame]
#![allow(unused_assignments)]
// expect-exit-status-1
fn main() -> Result<(),u8> {
let mut countdown = 10;
while
countdown
>
0
{
if
countdown
<
5
{
return
if
countdown
>
8
{
Ok(())
}
else
{
Err(1)
}
;
}
countdown
-=
1
;
}
Ok(())
}
// ISSUE(77553): Originally, this test had `Err(1)` on line 22 (instead of `Ok(())`) and
// `std::process::exit(2)` on line 26 (instead of `Err(1)`); and this worked as expected on Linux
// and MacOS. But on Windows (MSVC, at least), the call to `std::process::exit()` exits the program
// without saving the InstrProf coverage counters. The use of `std::process:exit()` is not critical
// to the coverage test for early returns, but this is a limitation that should be fixed.
//
// FIXME(richkadel): Consider creating a new tests for coverage when calling `std::process::exit()`,
// move the `ISSUE` comment to that test, and implement a new test directive that supports skipping
// coverage tests when targeting specific platforms (at least skipping Windows, or MSVC if the
// problem exists on MSVC only).