mirror of
https://github.com/rust-lang/rust.git
synced 2024-12-11 16:15:03 +00:00
Use is_in_test
in more places.
This commit is contained in:
parent
4c44b4e3c8
commit
6d61bdabea
@ -1,5 +1,5 @@
|
|||||||
use clippy_utils::diagnostics::span_lint_and_then;
|
use clippy_utils::diagnostics::span_lint_and_then;
|
||||||
use clippy_utils::is_in_test_function;
|
use clippy_utils::is_in_test;
|
||||||
|
|
||||||
use rustc_hir as hir;
|
use rustc_hir as hir;
|
||||||
use rustc_hir::intravisit::FnKind;
|
use rustc_hir::intravisit::FnKind;
|
||||||
@ -41,7 +41,7 @@ fn report(cx: &LateContext<'_>, param: &GenericParam<'_>, generics: &Generics<'_
|
|||||||
pub(super) fn check_fn<'tcx>(cx: &LateContext<'_>, kind: &'tcx FnKind<'_>, body: &'tcx Body<'_>, hir_id: HirId) {
|
pub(super) fn check_fn<'tcx>(cx: &LateContext<'_>, kind: &'tcx FnKind<'_>, body: &'tcx Body<'_>, hir_id: HirId) {
|
||||||
if let FnKind::ItemFn(_, generics, _) = kind
|
if let FnKind::ItemFn(_, generics, _) = kind
|
||||||
&& cx.tcx.visibility(cx.tcx.hir().body_owner_def_id(body.id())).is_public()
|
&& cx.tcx.visibility(cx.tcx.hir().body_owner_def_id(body.id())).is_public()
|
||||||
&& !is_in_test_function(cx.tcx, hir_id)
|
&& !is_in_test(cx.tcx, hir_id)
|
||||||
{
|
{
|
||||||
for param in generics.params {
|
for param in generics.params {
|
||||||
if param.is_impl_trait() {
|
if param.is_impl_trait() {
|
||||||
@ -59,7 +59,7 @@ pub(super) fn check_impl_item(cx: &LateContext<'_>, impl_item: &ImplItem<'_>) {
|
|||||||
&& of_trait.is_none()
|
&& of_trait.is_none()
|
||||||
&& let body = cx.tcx.hir().body(body_id)
|
&& let body = cx.tcx.hir().body(body_id)
|
||||||
&& cx.tcx.visibility(cx.tcx.hir().body_owner_def_id(body.id())).is_public()
|
&& cx.tcx.visibility(cx.tcx.hir().body_owner_def_id(body.id())).is_public()
|
||||||
&& !is_in_test_function(cx.tcx, impl_item.hir_id())
|
&& !is_in_test(cx.tcx, impl_item.hir_id())
|
||||||
{
|
{
|
||||||
for param in impl_item.generics.params {
|
for param in impl_item.generics.params {
|
||||||
if param.is_impl_trait() {
|
if param.is_impl_trait() {
|
||||||
@ -75,7 +75,7 @@ pub(super) fn check_trait_item(cx: &LateContext<'_>, trait_item: &TraitItem<'_>,
|
|||||||
&& let hir::Node::Item(item) = cx.tcx.parent_hir_node(trait_item.hir_id())
|
&& let hir::Node::Item(item) = cx.tcx.parent_hir_node(trait_item.hir_id())
|
||||||
// ^^ (Will always be a trait)
|
// ^^ (Will always be a trait)
|
||||||
&& !item.vis_span.is_empty() // Is public
|
&& !item.vis_span.is_empty() // Is public
|
||||||
&& !is_in_test_function(cx.tcx, trait_item.hir_id())
|
&& !is_in_test(cx.tcx, trait_item.hir_id())
|
||||||
{
|
{
|
||||||
for param in trait_item.generics.params {
|
for param in trait_item.generics.params {
|
||||||
if param.is_impl_trait() {
|
if param.is_impl_trait() {
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
use clippy_config::msrvs::Msrv;
|
use clippy_config::msrvs::Msrv;
|
||||||
use clippy_utils::diagnostics::span_lint;
|
use clippy_utils::diagnostics::span_lint;
|
||||||
use clippy_utils::is_in_test_function;
|
use clippy_utils::is_in_test;
|
||||||
use rustc_attr::{StabilityLevel, StableSince};
|
use rustc_attr::{StabilityLevel, StableSince};
|
||||||
use rustc_data_structures::fx::FxHashMap;
|
use rustc_data_structures::fx::FxHashMap;
|
||||||
use rustc_hir::{Expr, ExprKind, HirId};
|
use rustc_hir::{Expr, ExprKind, HirId};
|
||||||
@ -88,7 +88,7 @@ impl IncompatibleMsrv {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
let version = self.get_def_id_version(cx.tcx, def_id);
|
let version = self.get_def_id_version(cx.tcx, def_id);
|
||||||
if self.msrv.meets(version) || is_in_test_function(cx.tcx, node) {
|
if self.msrv.meets(version) || is_in_test(cx.tcx, node) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if let ExpnKind::AstPass(_) | ExpnKind::Desugaring(_) = span.ctxt().outer_expn_data().kind {
|
if let ExpnKind::AstPass(_) | ExpnKind::Desugaring(_) = span.ctxt().outer_expn_data().kind {
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
use clippy_utils::diagnostics::span_lint_and_then;
|
use clippy_utils::diagnostics::span_lint_and_then;
|
||||||
use clippy_utils::ty::{is_never_like, is_type_diagnostic_item};
|
use clippy_utils::ty::{is_never_like, is_type_diagnostic_item};
|
||||||
use clippy_utils::{is_in_cfg_test, is_in_test_function, is_lint_allowed};
|
use clippy_utils::{is_in_test, is_lint_allowed};
|
||||||
use rustc_hir::Expr;
|
use rustc_hir::Expr;
|
||||||
use rustc_lint::{LateContext, Lint};
|
use rustc_lint::{LateContext, Lint};
|
||||||
use rustc_middle::ty;
|
use rustc_middle::ty;
|
||||||
@ -61,7 +61,7 @@ pub(super) fn check(
|
|||||||
|
|
||||||
let method_suffix = if is_err { "_err" } else { "" };
|
let method_suffix = if is_err { "_err" } else { "" };
|
||||||
|
|
||||||
if allow_unwrap_in_tests && (is_in_test_function(cx.tcx, expr.hir_id) || is_in_cfg_test(cx.tcx, expr.hir_id)) {
|
if allow_unwrap_in_tests && is_in_test(cx.tcx, expr.hir_id) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
use clippy_utils::diagnostics::span_lint_and_help;
|
use clippy_utils::diagnostics::span_lint_and_help;
|
||||||
|
use clippy_utils::is_in_test;
|
||||||
use clippy_utils::macros::{find_assert_args, find_assert_eq_args, root_macro_call_first_node, PanicExpn};
|
use clippy_utils::macros::{find_assert_args, find_assert_eq_args, root_macro_call_first_node, PanicExpn};
|
||||||
use clippy_utils::{is_in_cfg_test, is_in_test_function};
|
|
||||||
use rustc_hir::Expr;
|
use rustc_hir::Expr;
|
||||||
use rustc_lint::{LateContext, LateLintPass};
|
use rustc_lint::{LateContext, LateLintPass};
|
||||||
use rustc_session::declare_lint_pass;
|
use rustc_session::declare_lint_pass;
|
||||||
@ -62,7 +62,7 @@ impl<'tcx> LateLintPass<'tcx> for MissingAssertMessage {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// This lint would be very noisy in tests, so just ignore if we're in test context
|
// This lint would be very noisy in tests, so just ignore if we're in test context
|
||||||
if is_in_test_function(cx.tcx, expr.hir_id) || is_in_cfg_test(cx.tcx, expr.hir_id) {
|
if is_in_test(cx.tcx, expr.hir_id) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
use clippy_utils::diagnostics::{span_lint, span_lint_and_then};
|
use clippy_utils::diagnostics::{span_lint, span_lint_and_then};
|
||||||
|
use clippy_utils::is_in_test;
|
||||||
use clippy_utils::macros::{format_arg_removal_span, root_macro_call_first_node, FormatArgsStorage, MacroCall};
|
use clippy_utils::macros::{format_arg_removal_span, root_macro_call_first_node, FormatArgsStorage, MacroCall};
|
||||||
use clippy_utils::source::{expand_past_previous_comma, snippet_opt};
|
use clippy_utils::source::{expand_past_previous_comma, snippet_opt};
|
||||||
use clippy_utils::{is_in_cfg_test, is_in_test_function};
|
|
||||||
use rustc_ast::token::LitKind;
|
use rustc_ast::token::LitKind;
|
||||||
use rustc_ast::{
|
use rustc_ast::{
|
||||||
FormatArgPosition, FormatArgPositionKind, FormatArgs, FormatArgsPiece, FormatOptions, FormatPlaceholder,
|
FormatArgPosition, FormatArgPositionKind, FormatArgs, FormatArgsPiece, FormatOptions, FormatPlaceholder,
|
||||||
@ -297,8 +297,7 @@ impl<'tcx> LateLintPass<'tcx> for Write {
|
|||||||
.as_ref()
|
.as_ref()
|
||||||
.map_or(false, |crate_name| crate_name == "build_script_build");
|
.map_or(false, |crate_name| crate_name == "build_script_build");
|
||||||
|
|
||||||
let allowed_in_tests = self.allow_print_in_tests
|
let allowed_in_tests = self.allow_print_in_tests && is_in_test(cx.tcx, expr.hir_id);
|
||||||
&& (is_in_test_function(cx.tcx, expr.hir_id) || is_in_cfg_test(cx.tcx, expr.hir_id));
|
|
||||||
match diag_name {
|
match diag_name {
|
||||||
sym::print_macro | sym::println_macro if !allowed_in_tests => {
|
sym::print_macro | sym::println_macro if !allowed_in_tests => {
|
||||||
if !is_build_script {
|
if !is_build_script {
|
||||||
|
@ -2625,16 +2625,6 @@ pub fn inherits_cfg(tcx: TyCtxt<'_>, def_id: LocalDefId) -> bool {
|
|||||||
.any(|attr| attr.has_name(sym::cfg))
|
.any(|attr| attr.has_name(sym::cfg))
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Checks whether item either has `test` attribute applied, or
|
|
||||||
/// is a module with `test` in its name.
|
|
||||||
///
|
|
||||||
/// Note: Add `//@compile-flags: --test` to UI tests with a `#[test]` function
|
|
||||||
pub fn is_test_module_or_function(tcx: TyCtxt<'_>, item: &Item<'_>) -> bool {
|
|
||||||
is_in_test_function(tcx, item.hir_id())
|
|
||||||
|| matches!(item.kind, ItemKind::Mod(..))
|
|
||||||
&& item.ident.name.as_str().split('_').any(|a| a == "test" || a == "tests")
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Walks up the HIR tree from the given expression in an attempt to find where the value is
|
/// Walks up the HIR tree from the given expression in an attempt to find where the value is
|
||||||
/// consumed.
|
/// consumed.
|
||||||
///
|
///
|
||||||
|
Loading…
Reference in New Issue
Block a user