Auto merge of #51450 - estebank:inner-fn-test, r=@pnkfelix
Add lint warning for inner function marked as `#[test]` Fix #36629.
This commit is contained in:
commit
739320a601
src
@ -1709,7 +1709,6 @@ impl LintPass for SoftLints {
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
declare_lint! {
|
||||
pub ELLIPSIS_INCLUSIVE_RANGE_PATTERNS,
|
||||
Allow,
|
||||
@ -1744,3 +1743,44 @@ impl EarlyLintPass for EllipsisInclusiveRangePatterns {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
declare_lint! {
|
||||
UNNAMEABLE_TEST_FUNCTIONS,
|
||||
Warn,
|
||||
"detects an function that cannot be named being marked as #[test]"
|
||||
}
|
||||
|
||||
pub struct UnnameableTestFunctions;
|
||||
|
||||
impl LintPass for UnnameableTestFunctions {
|
||||
fn get_lints(&self) -> LintArray {
|
||||
lint_array!(UNNAMEABLE_TEST_FUNCTIONS)
|
||||
}
|
||||
}
|
||||
|
||||
impl<'a, 'tcx> LateLintPass<'a, 'tcx> for UnnameableTestFunctions {
|
||||
fn check_item(&mut self, cx: &LateContext, it: &hir::Item) {
|
||||
match it.node {
|
||||
hir::ItemFn(..) => {
|
||||
for attr in &it.attrs {
|
||||
if attr.name() == "test" {
|
||||
let parent = cx.tcx.hir.get_parent(it.id);
|
||||
match cx.tcx.hir.find(parent) {
|
||||
Some(hir_map::NodeItem(hir::Item {node: hir::ItemMod(_), ..})) |
|
||||
None => {}
|
||||
_ => {
|
||||
cx.struct_span_lint(
|
||||
UNNAMEABLE_TEST_FUNCTIONS,
|
||||
attr.span,
|
||||
"cannot test inner function",
|
||||
).emit();
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
_ => return,
|
||||
};
|
||||
}
|
||||
}
|
||||
|
@ -130,6 +130,7 @@ pub fn register_builtins(store: &mut lint::LintStore, sess: Option<&Session>) {
|
||||
MutableTransmutes: MutableTransmutes,
|
||||
UnionsWithDropFields: UnionsWithDropFields,
|
||||
UnreachablePub: UnreachablePub,
|
||||
UnnameableTestFunctions: UnnameableTestFunctions,
|
||||
TypeAliasBounds: TypeAliasBounds,
|
||||
UnusedBrokenConst: UnusedBrokenConst,
|
||||
TrivialConstraints: TrivialConstraints,
|
||||
|
29
src/test/ui/lint/test-inner-fn.rs
Normal file
29
src/test/ui/lint/test-inner-fn.rs
Normal file
@ -0,0 +1,29 @@
|
||||
// Copyright 2018 The Rust Project Developers. See the COPYRIGHT
|
||||
// file at the top-level directory of this distribution and at
|
||||
// http://rust-lang.org/COPYRIGHT.
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||
// option. This file may not be copied, modified, or distributed
|
||||
// except according to those terms.
|
||||
|
||||
// compile-flags: --test -D unnameable_test_functions
|
||||
|
||||
#[test]
|
||||
fn foo() {
|
||||
#[test] //~ ERROR cannot test inner function [unnameable_test_functions]
|
||||
fn bar() {}
|
||||
bar();
|
||||
}
|
||||
|
||||
mod x {
|
||||
#[test]
|
||||
fn foo() {
|
||||
#[test] //~ ERROR cannot test inner function [unnameable_test_functions]
|
||||
fn bar() {}
|
||||
bar();
|
||||
}
|
||||
}
|
||||
|
||||
fn main() {}
|
16
src/test/ui/lint/test-inner-fn.stderr
Normal file
16
src/test/ui/lint/test-inner-fn.stderr
Normal file
@ -0,0 +1,16 @@
|
||||
error: cannot test inner function
|
||||
--> $DIR/test-inner-fn.rs:15:5
|
||||
|
|
||||
LL | #[test] //~ ERROR cannot test inner function [unnameable_test_functions]
|
||||
| ^^^^^^^
|
||||
|
|
||||
= note: requested on the command line with `-D unnameable-test-functions`
|
||||
|
||||
error: cannot test inner function
|
||||
--> $DIR/test-inner-fn.rs:23:9
|
||||
|
|
||||
LL | #[test] //~ ERROR cannot test inner function [unnameable_test_functions]
|
||||
| ^^^^^^^
|
||||
|
||||
error: aborting due to 2 previous errors
|
||||
|
Loading…
Reference in New Issue
Block a user