Deny non-lifetime generics for test functions.
Previously, these were allowed if the function returned `()`, but always led to an ambiguity error.
This commit is contained in:
parent
4bf00613ee
commit
774f7825cb
1 changed files with 15 additions and 18 deletions
|
@ -3,7 +3,7 @@ use crate::errors;
|
||||||
/// Ideally, this code would be in libtest but for efficiency and error messages it lives here.
|
/// Ideally, this code would be in libtest but for efficiency and error messages it lives here.
|
||||||
use crate::util::{check_builtin_macro_attribute, warn_on_duplicate_attribute};
|
use crate::util::{check_builtin_macro_attribute, warn_on_duplicate_attribute};
|
||||||
use rustc_ast::ptr::P;
|
use rustc_ast::ptr::P;
|
||||||
use rustc_ast::{self as ast, attr};
|
use rustc_ast::{self as ast, attr, GenericParamKind};
|
||||||
use rustc_ast_pretty::pprust;
|
use rustc_ast_pretty::pprust;
|
||||||
use rustc_errors::Applicability;
|
use rustc_errors::Applicability;
|
||||||
use rustc_expand::base::*;
|
use rustc_expand::base::*;
|
||||||
|
@ -550,24 +550,21 @@ fn has_test_signature(cx: &ExtCtxt<'_>, i: &ast::Item) -> bool {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
match (has_output, has_should_panic_attr) {
|
if has_should_panic_attr && has_output {
|
||||||
(true, true) => {
|
sd.span_err(i.span, "functions using `#[should_panic]` must return `()`");
|
||||||
sd.span_err(i.span, "functions using `#[should_panic]` must return `()`");
|
return false;
|
||||||
false
|
|
||||||
}
|
|
||||||
(true, false) => {
|
|
||||||
if !generics.params.is_empty() {
|
|
||||||
sd.span_err(
|
|
||||||
i.span,
|
|
||||||
"functions used as tests must have signature fn() -> ()",
|
|
||||||
);
|
|
||||||
false
|
|
||||||
} else {
|
|
||||||
true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
(false, _) => true,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if generics.params.iter().any(|param| !matches!(param.kind, GenericParamKind::Lifetime))
|
||||||
|
{
|
||||||
|
sd.span_err(
|
||||||
|
i.span,
|
||||||
|
"functions used as tests can not have any non-lifetime generic parameters",
|
||||||
|
);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
true
|
||||||
}
|
}
|
||||||
_ => {
|
_ => {
|
||||||
// should be unreachable because `is_test_fn_item` should catch all non-fn items
|
// should be unreachable because `is_test_fn_item` should catch all non-fn items
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue