diff options
| author | zhuyunxing <zhuyunxing.zyx@alibaba-inc.com> | 2024-07-02 18:34:26 +0800 |
|---|---|---|
| committer | zhuyunxing <zhuyunxing.zyx@alibaba-inc.com> | 2024-07-09 14:28:40 +0800 |
| commit | 83fa6b726ad04d5b4e9769c39eae544131fee46c (patch) | |
| tree | 7079f66fd437cb0784c445426f0610fa337e0c1a /tests/coverage/mcdc/inlined_expressions.coverage | |
| parent | c77788f011ee04cfc825926d89647af5ac3f6aa5 (diff) | |
| download | rust-83fa6b726ad04d5b4e9769c39eae544131fee46c.tar.gz rust-83fa6b726ad04d5b4e9769c39eae544131fee46c.zip | |
coverage. Fix panic when generating mcdc code for inlined functions
Diffstat (limited to 'tests/coverage/mcdc/inlined_expressions.coverage')
| -rw-r--r-- | tests/coverage/mcdc/inlined_expressions.coverage | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/tests/coverage/mcdc/inlined_expressions.coverage b/tests/coverage/mcdc/inlined_expressions.coverage new file mode 100644 index 00000000000..5b083d62186 --- /dev/null +++ b/tests/coverage/mcdc/inlined_expressions.coverage @@ -0,0 +1,41 @@ + LL| |#![feature(coverage_attribute)] + LL| |//@ edition: 2021 + LL| |//@ min-llvm-version: 18 + LL| |//@ compile-flags: -Zcoverage-options=mcdc -Copt-level=z -Cllvm-args=--inline-threshold=0 + LL| |//@ llvm-cov-flags: --show-branches=count --show-mcdc + LL| | + LL| |#[inline(always)] + LL| 3|fn inlined_instance(a: bool, b: bool) -> bool { + LL| 3| a && b + ^2 + ------------------ + | Branch (LL:5): [True: 2, False: 1] + | Branch (LL:10): [True: 1, False: 1] + ------------------ + |---> MC/DC Decision Region (LL:5) to (LL:11) + | + | Number of Conditions: 2 + | Condition C1 --> (LL:5) + | Condition C2 --> (LL:10) + | + | Executed MC/DC Test Vectors: + | + | C1, C2 Result + | 1 { F, - = F } + | 2 { T, F = F } + | 3 { T, T = T } + | + | C1-Pair: covered: (1,3) + | C2-Pair: covered: (2,3) + | MC/DC Coverage for Decision: 100.00% + | + ------------------ + LL| 3|} + LL| | + LL| |#[coverage(off)] + LL| |fn main() { + LL| | let _ = inlined_instance(true, false); + LL| | let _ = inlined_instance(false, true); + LL| | let _ = inlined_instance(true, true); + LL| |} + |
