| #![feature(coverage_attribute)] |
| //@ edition: 2021 |
| //@ compile-flags: -Copt-level=0 -Zmir-opt-level=3 |
| |
| // Regression test for <https://github.com/rust-lang/rust/issues/117012>. |
| // |
| // If some coverage counters were removed by MIR optimizations, we need to take |
| // care not to refer to those counter IDs in coverage mappings, and instead |
| // replace them with a constant zero value. If we don't, `llvm-cov` might see |
| // a too-large counter ID and silently discard the entire function from its |
| // coverage reports. |
| |
| #[derive(Debug, PartialEq, Eq)] |
| struct Foo(u32); |
| |
| fn eq_good() { |
| println!("a"); |
| assert_eq!(Foo(1), Foo(1)); |
| } |
| |
| fn eq_good_message() { |
| println!("b"); |
| assert_eq!(Foo(1), Foo(1), "message b"); |
| } |
| |
| fn ne_good() { |
| println!("c"); |
| assert_ne!(Foo(1), Foo(3)); |
| } |
| |
| fn ne_good_message() { |
| println!("d"); |
| assert_ne!(Foo(1), Foo(3), "message d"); |
| } |
| |
| fn eq_bad() { |
| println!("e"); |
| assert_eq!(Foo(1), Foo(3)); |
| } |
| |
| fn eq_bad_message() { |
| println!("f"); |
| assert_eq!(Foo(1), Foo(3), "message f"); |
| } |
| |
| fn ne_bad() { |
| println!("g"); |
| assert_ne!(Foo(1), Foo(1)); |
| } |
| |
| fn ne_bad_message() { |
| println!("h"); |
| assert_ne!(Foo(1), Foo(1), "message h"); |
| } |
| |
| #[coverage(off)] |
| fn main() { |
| eq_good(); |
| eq_good_message(); |
| ne_good(); |
| ne_good_message(); |
| |
| assert!(std::panic::catch_unwind(eq_bad).is_err()); |
| assert!(std::panic::catch_unwind(eq_bad_message).is_err()); |
| assert!(std::panic::catch_unwind(ne_bad).is_err()); |
| assert!(std::panic::catch_unwind(ne_bad_message).is_err()); |
| } |