summaryrefslogtreecommitdiffstats
path: root/tests/coverage/if_else.coverage
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-07 05:48:42 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-07 05:48:42 +0000
commitcec1877e180393eba0f6ddb0cf97bf3a791631c7 (patch)
tree47b4dac2a9dd9a40c30c251b4d4a72d7ccf77e9f /tests/coverage/if_else.coverage
parentAdding debian version 1.74.1+dfsg1-1. (diff)
downloadrustc-cec1877e180393eba0f6ddb0cf97bf3a791631c7.tar.xz
rustc-cec1877e180393eba0f6ddb0cf97bf3a791631c7.zip
Merging upstream version 1.75.0+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/coverage/if_else.coverage')
-rw-r--r--tests/coverage/if_else.coverage41
1 files changed, 41 insertions, 0 deletions
diff --git a/tests/coverage/if_else.coverage b/tests/coverage/if_else.coverage
new file mode 100644
index 000000000..0274401f0
--- /dev/null
+++ b/tests/coverage/if_else.coverage
@@ -0,0 +1,41 @@
+ LL| |#![allow(unused_assignments, unused_variables)]
+ LL| |
+ LL| 1|fn main() {
+ LL| 1| // Initialize test constants in a way that cannot be determined at compile time, to ensure
+ LL| 1| // rustc and LLVM cannot optimize out statements (or coverage counters) downstream from
+ LL| 1| // dependent conditions.
+ LL| 1| let is_true = std::env::args().len() == 1;
+ LL| 1|
+ LL| 1| let mut countdown = 0;
+ LL| 1| if
+ LL| 1| is_true
+ LL| 1| {
+ LL| 1| countdown
+ LL| 1| =
+ LL| 1| 10
+ LL| 1| ;
+ LL| 1| }
+ LL| | else // Note coverage region difference without semicolon
+ LL| | {
+ LL| 0| countdown
+ LL| 0| =
+ LL| 0| 100
+ LL| | }
+ LL| |
+ LL| | if
+ LL| 1| is_true
+ LL| 1| {
+ LL| 1| countdown
+ LL| 1| =
+ LL| 1| 10
+ LL| 1| ;
+ LL| 1| }
+ LL| | else
+ LL| 0| {
+ LL| 0| countdown
+ LL| 0| =
+ LL| 0| 100
+ LL| 0| ;
+ LL| 0| }
+ LL| 1|}
+