#![feature(coverage_attribute)] //@ edition: 2021 //@ compile-flags: -Copt-level=0 -Zmir-opt-level=3 // Regression test for . // // 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()); }