rust/tests/ui/same_name_method.rs

133 lines
2.1 KiB
Rust
Raw Normal View History

2022-06-06 12:36:57 +02:00
#![feature(lint_reasons)]
2021-09-08 10:36:51 +08:00
#![warn(clippy::same_name_method)]
#![allow(dead_code, non_camel_case_types)]
trait T1 {
fn foo() {}
}
trait T2 {
fn foo() {}
}
mod should_lint {
mod test_basic_case {
use crate::T1;
struct S;
impl S {
fn foo() {}
//~^ ERROR: method's name is the same as an existing method in a trait
2021-09-08 10:36:51 +08:00
}
impl T1 for S {
fn foo() {}
}
}
mod test_derive {
#[derive(Clone)]
struct S;
impl S {
fn clone() {}
//~^ ERROR: method's name is the same as an existing method in a trait
2021-09-08 10:36:51 +08:00
}
}
mod with_generic {
use crate::T1;
struct S<U>(U);
impl<U> S<U> {
fn foo() {}
//~^ ERROR: method's name is the same as an existing method in a trait
2021-09-08 10:36:51 +08:00
}
impl<U: Copy> T1 for S<U> {
fn foo() {}
}
}
mod default_method {
use crate::T1;
struct S;
impl S {
fn foo() {}
//~^ ERROR: method's name is the same as an existing method in a trait
2021-09-08 10:36:51 +08:00
}
impl T1 for S {}
}
mod multiple_conflicting_traits {
2021-09-08 10:36:51 +08:00
use crate::{T1, T2};
struct S;
impl S {
fn foo() {}
//~^ ERROR: method's name is the same as an existing method in a trait
2021-09-08 10:36:51 +08:00
}
impl T1 for S {}
impl T2 for S {}
}
}
mod should_not_lint {
mod not_lint_two_trait_method {
use crate::{T1, T2};
struct S;
impl T1 for S {
fn foo() {}
}
impl T2 for S {
fn foo() {}
}
}
mod only_lint_on_method {
trait T3 {
type foo;
}
struct S;
impl S {
fn foo() {}
}
impl T3 for S {
type foo = usize;
}
}
}
2022-06-06 12:36:57 +02:00
mod check_expect_suppression {
use crate::T1;
struct S;
impl S {
#[expect(clippy::same_name_method)]
fn foo() {}
}
impl T1 for S {
fn foo() {}
}
}
2021-09-08 10:36:51 +08:00
fn main() {}