coverage: Regression test for unwrapping prev
when there are no spans
This commit is contained in:
parent
cec814202a
commit
e01338aeb8
8
tests/coverage/no_spans.cov-map
Normal file
8
tests/coverage/no_spans.cov-map
Normal file
@ -0,0 +1,8 @@
|
||||
Function name: no_spans::affected_function::{closure#0}
|
||||
Raw bytes (9): 0x[01, 01, 00, 01, 01, 1b, 0c, 00, 0e]
|
||||
Number of files: 1
|
||||
- file 0 => global file 1
|
||||
Number of expressions: 0
|
||||
Number of file 0 mappings: 1
|
||||
- Code(Counter(0)) at (prev + 27, 12) to (start + 0, 14)
|
||||
|
30
tests/coverage/no_spans.coverage
Normal file
30
tests/coverage/no_spans.coverage
Normal file
@ -0,0 +1,30 @@
|
||||
LL| |#![feature(coverage_attribute)]
|
||||
LL| |// edition: 2021
|
||||
LL| |
|
||||
LL| |// If the span extractor can't find any relevant spans for a function, the
|
||||
LL| |// refinement loop will terminate with nothing in its `prev` slot. If the
|
||||
LL| |// subsequent code tries to unwrap `prev`, it will panic.
|
||||
LL| |//
|
||||
LL| |// This scenario became more likely after #118525 started discarding spans that
|
||||
LL| |// can't be un-expanded back to within the function body.
|
||||
LL| |//
|
||||
LL| |// Regression test for "invalid attempt to unwrap a None some_prev", as seen
|
||||
LL| |// in issues such as #118643 and #118662.
|
||||
LL| |
|
||||
LL| |#[coverage(off)]
|
||||
LL| |fn main() {
|
||||
LL| | affected_function()();
|
||||
LL| |}
|
||||
LL| |
|
||||
LL| |macro_rules! macro_that_defines_a_function {
|
||||
LL| | (fn $name:ident () $body:tt) => {
|
||||
LL| | fn $name () -> impl Fn() $body
|
||||
LL| | }
|
||||
LL| |}
|
||||
LL| |
|
||||
LL| |macro_that_defines_a_function! {
|
||||
LL| | fn affected_function() {
|
||||
LL| 1| || ()
|
||||
LL| | }
|
||||
LL| |}
|
||||
|
29
tests/coverage/no_spans.rs
Normal file
29
tests/coverage/no_spans.rs
Normal file
@ -0,0 +1,29 @@
|
||||
#![feature(coverage_attribute)]
|
||||
// edition: 2021
|
||||
|
||||
// If the span extractor can't find any relevant spans for a function, the
|
||||
// refinement loop will terminate with nothing in its `prev` slot. If the
|
||||
// subsequent code tries to unwrap `prev`, it will panic.
|
||||
//
|
||||
// This scenario became more likely after #118525 started discarding spans that
|
||||
// can't be un-expanded back to within the function body.
|
||||
//
|
||||
// Regression test for "invalid attempt to unwrap a None some_prev", as seen
|
||||
// in issues such as #118643 and #118662.
|
||||
|
||||
#[coverage(off)]
|
||||
fn main() {
|
||||
affected_function()();
|
||||
}
|
||||
|
||||
macro_rules! macro_that_defines_a_function {
|
||||
(fn $name:ident () $body:tt) => {
|
||||
fn $name () -> impl Fn() $body
|
||||
}
|
||||
}
|
||||
|
||||
macro_that_defines_a_function! {
|
||||
fn affected_function() {
|
||||
|| ()
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user