diff options
| author | Zalathar <Zalathar@users.noreply.github.com> | 2024-04-17 11:41:40 +1000 |
|---|---|---|
| committer | Zalathar <Zalathar@users.noreply.github.com> | 2024-04-22 21:55:33 +1000 |
| commit | 4f7a47798eb3455aed74fde5cd8e81927d2db07a (patch) | |
| tree | 31dd57475aea7e63bde9ce2ff5caa3219e1d78c8 /tests/coverage/branch/let-else.rs | |
| parent | b3e117044c7f707293edc040edb93e7ec5f7040a (diff) | |
| download | rust-4f7a47798eb3455aed74fde5cd8e81927d2db07a.tar.gz rust-4f7a47798eb3455aed74fde5cd8e81927d2db07a.zip | |
coverage: Branch coverage test for let-else
Diffstat (limited to 'tests/coverage/branch/let-else.rs')
| -rw-r--r-- | tests/coverage/branch/let-else.rs | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/tests/coverage/branch/let-else.rs b/tests/coverage/branch/let-else.rs new file mode 100644 index 00000000000..af0665d8241 --- /dev/null +++ b/tests/coverage/branch/let-else.rs @@ -0,0 +1,35 @@ +#![feature(coverage_attribute)] +//@ edition: 2021 +//@ compile-flags: -Zcoverage-options=branch +//@ llvm-cov-flags: --show-branches=count + +macro_rules! no_merge { + () => { + for _ in 0..1 {} + }; +} + +fn let_else(value: Option<&str>) { + no_merge!(); + + let Some(x) = value else { + say("none"); + return; + }; + + say(x); +} + +#[coverage(off)] +fn say(message: &str) { + core::hint::black_box(message); +} + +#[coverage(off)] +fn main() { + let_else(Some("x")); + let_else(Some("x")); + let_else(None); +} + +// FIXME(#124118) Actually instrument let-else for branch coverage. |
