2024-01-16 04:03:29 -06:00
|
|
|
//! This test tests two things at once:
|
|
|
|
//! 1. we error if a const evaluation hits the deny-by-default lint limit
|
|
|
|
//! 2. we do not ICE on invalid follow-up code
|
2024-03-08 01:09:53 -06:00
|
|
|
//! 3. no ICE when run with `-Z unstable-options` (issue 122177)
|
2024-01-16 04:03:29 -06:00
|
|
|
|
2024-03-08 01:09:53 -06:00
|
|
|
//@revisions: eval_limit no_ice
|
|
|
|
//@[no_ice] compile-flags: -Z tiny-const-eval-limit -Z unstable-options
|
|
|
|
//@[eval_limit] compile-flags: -Z tiny-const-eval-limit
|
2024-01-16 04:03:29 -06:00
|
|
|
|
2018-06-24 15:53:27 -05:00
|
|
|
fn main() {
|
|
|
|
// Tests the Collatz conjecture with an incorrect base case (0 instead of 1).
|
|
|
|
// The value of `n` will loop indefinitely (4 - 2 - 1 - 4).
|
2024-01-16 04:03:29 -06:00
|
|
|
let s = [(); {
|
2018-06-29 15:32:54 -05:00
|
|
|
let mut n = 113383; // #20 in https://oeis.org/A006884
|
2019-07-01 11:26:36 -05:00
|
|
|
while n != 0 {
|
2022-11-02 06:57:40 -05:00
|
|
|
//~^ ERROR is taking a long time
|
|
|
|
n = if n % 2 == 0 { n / 2 } else { 3 * n + 1 };
|
2018-06-24 15:53:27 -05:00
|
|
|
}
|
|
|
|
n
|
|
|
|
}];
|
2024-01-16 04:03:29 -06:00
|
|
|
|
|
|
|
s.nonexistent_method();
|
2018-06-24 15:53:27 -05:00
|
|
|
}
|