Update type UI tests to use private items

This commit is contained in:
xFrednet 2021-08-12 13:15:15 +02:00
parent 206741bf57
commit c02dcd5405
6 changed files with 79 additions and 60 deletions

View File

@ -1,6 +1,10 @@
#![warn(clippy::all)] #![warn(clippy::all)]
#![allow(clippy::boxed_local, clippy::needless_pass_by_value)] #![allow(
#![allow(clippy::blacklisted_name)] clippy::boxed_local,
clippy::needless_pass_by_value,
clippy::blacklisted_name,
unused
)]
macro_rules! boxit { macro_rules! boxit {
($init:expr, $x:ty) => { ($init:expr, $x:ty) => {
@ -11,22 +15,22 @@ macro_rules! boxit {
fn test_macro() { fn test_macro() {
boxit!(Vec::new(), Vec<u8>); boxit!(Vec::new(), Vec<u8>);
} }
pub fn test(foo: Box<Vec<bool>>) { fn test(foo: Box<Vec<bool>>) {}
println!("{:?}", foo.get(0))
}
pub fn test2(foo: Box<dyn Fn(Vec<u32>)>) { fn test2(foo: Box<dyn Fn(Vec<u32>)>) {
// pass if #31 is fixed // pass if #31 is fixed
foo(vec![1, 2, 3]) foo(vec![1, 2, 3])
} }
pub fn test_local_not_linted() { fn test_local_not_linted() {
let _: Box<Vec<bool>>; let _: Box<Vec<bool>>;
} }
fn main() { // All of these test should be allowed because they are part of the
test(Box::new(Vec::new())); // public api and `avoid_breaking_exported_api` is `false` by default.
test2(Box::new(|v| println!("{:?}", v))); pub fn pub_test(foo: Box<Vec<bool>>) {}
test_macro(); pub fn pub_test_ret() -> Box<Vec<bool>> {
test_local_not_linted(); Box::new(Vec::new())
} }
fn main() {}

View File

@ -1,8 +1,8 @@
error: you seem to be trying to use `Box<Vec<T>>`. Consider using just `Vec<T>` error: you seem to be trying to use `Box<Vec<T>>`. Consider using just `Vec<T>`
--> $DIR/box_vec.rs:14:18 --> $DIR/box_vec.rs:18:14
| |
LL | pub fn test(foo: Box<Vec<bool>>) { LL | fn test(foo: Box<Vec<bool>>) {}
| ^^^^^^^^^^^^^^ | ^^^^^^^^^^^^^^
| |
= note: `-D clippy::box-vec` implied by `-D warnings` = note: `-D clippy::box-vec` implied by `-D warnings`
= help: `Vec<T>` is already on the heap, `Box<Vec<T>>` makes an extra allocation = help: `Vec<T>` is already on the heap, `Box<Vec<T>>` makes an extra allocation

View File

@ -1,6 +1,6 @@
#![feature(associated_type_defaults)] #![feature(associated_type_defaults)]
#![warn(clippy::linkedlist)] #![warn(clippy::linkedlist)]
#![allow(dead_code, clippy::needless_pass_by_value)] #![allow(unused, dead_code, clippy::needless_pass_by_value)]
extern crate alloc; extern crate alloc;
use alloc::collections::linked_list::LinkedList; use alloc::collections::linked_list::LinkedList;
@ -20,24 +20,29 @@ fn foo(_: LinkedList<u8>) {}
const BAR: Option<LinkedList<u8>> = None; const BAR: Option<LinkedList<u8>> = None;
} }
struct Bar; pub struct Bar {
priv_linked_list_field: LinkedList<u8>,
pub pub_linked_list_field: LinkedList<u8>,
}
impl Bar { impl Bar {
fn foo(_: LinkedList<u8>) {} fn foo(_: LinkedList<u8>) {}
} }
pub fn test(my_favourite_linked_list: LinkedList<u8>) { // All of these test should be trigger the lint because they are not
println!("{:?}", my_favourite_linked_list) // part of the public api
fn test(my_favorite_linked_list: LinkedList<u8>) {}
fn test_ret() -> Option<LinkedList<u8>> {
None
} }
fn test_local_not_linted() {
pub fn test_ret() -> Option<LinkedList<u8>> {
unimplemented!();
}
pub fn test_local_not_linted() {
let _: LinkedList<u8>; let _: LinkedList<u8>;
} }
fn main() { // All of these test should be allowed because they are part of the
test(LinkedList::new()); // public api and `avoid_breaking_exported_api` is `false` by default.
test_local_not_linted(); pub fn pub_test(the_most_awesome_linked_list: LinkedList<u8>) {}
pub fn pub_test_ret() -> Option<LinkedList<u8>> {
None
} }
fn main() {}

View File

@ -40,7 +40,15 @@ LL | const BAR: Option<LinkedList<u8>>;
= help: a `VecDeque` might work = help: a `VecDeque` might work
error: you seem to be using a `LinkedList`! Perhaps you meant some other data structure? error: you seem to be using a `LinkedList`! Perhaps you meant some other data structure?
--> $DIR/linkedlist.rs:25:15 --> $DIR/linkedlist.rs:24:29
|
LL | priv_linked_list_field: LinkedList<u8>,
| ^^^^^^^^^^^^^^
|
= help: a `VecDeque` might work
error: you seem to be using a `LinkedList`! Perhaps you meant some other data structure?
--> $DIR/linkedlist.rs:28:15
| |
LL | fn foo(_: LinkedList<u8>) {} LL | fn foo(_: LinkedList<u8>) {}
| ^^^^^^^^^^^^^^ | ^^^^^^^^^^^^^^
@ -48,20 +56,20 @@ LL | fn foo(_: LinkedList<u8>) {}
= help: a `VecDeque` might work = help: a `VecDeque` might work
error: you seem to be using a `LinkedList`! Perhaps you meant some other data structure? error: you seem to be using a `LinkedList`! Perhaps you meant some other data structure?
--> $DIR/linkedlist.rs:28:39 --> $DIR/linkedlist.rs:33:34
| |
LL | pub fn test(my_favourite_linked_list: LinkedList<u8>) { LL | fn test(my_favorite_linked_list: LinkedList<u8>) {}
| ^^^^^^^^^^^^^^ | ^^^^^^^^^^^^^^
| |
= help: a `VecDeque` might work = help: a `VecDeque` might work
error: you seem to be using a `LinkedList`! Perhaps you meant some other data structure? error: you seem to be using a `LinkedList`! Perhaps you meant some other data structure?
--> $DIR/linkedlist.rs:32:29 --> $DIR/linkedlist.rs:34:25
| |
LL | pub fn test_ret() -> Option<LinkedList<u8>> { LL | fn test_ret() -> Option<LinkedList<u8>> {
| ^^^^^^^^^^^^^^ | ^^^^^^^^^^^^^^
| |
= help: a `VecDeque` might work = help: a `VecDeque` might work
error: aborting due to 8 previous errors error: aborting due to 9 previous errors

View File

@ -1,13 +1,17 @@
#![warn(clippy::rc_mutex)] #![warn(clippy::rc_mutex)]
#![allow(clippy::blacklisted_name)] #![allow(unused, clippy::blacklisted_name)]
use std::rc::Rc; use std::rc::Rc;
use std::sync::Mutex; use std::sync::Mutex;
pub struct MyStruct { pub struct MyStructWithPrivItem {
foo: Rc<Mutex<i32>>, foo: Rc<Mutex<i32>>,
} }
pub struct MyStructWithPubItem {
pub foo: Rc<Mutex<i32>>,
}
pub struct SubT<T> { pub struct SubT<T> {
foo: T, foo: T,
} }
@ -17,18 +21,16 @@ pub enum MyEnum {
Two, Two,
} }
pub fn test1<T>(foo: Rc<Mutex<T>>) {} // All of these test should be trigger the lint because they are not
// part of the public api
fn test1<T>(foo: Rc<Mutex<T>>) {}
fn test2(foo: Rc<Mutex<MyEnum>>) {}
fn test3(foo: Rc<Mutex<SubT<usize>>>) {}
pub fn test2(foo: Rc<Mutex<MyEnum>>) {} // All of these test should be allowed because they are part of the
// public api and `avoid_breaking_exported_api` is `false` by default.
pub fn pub_test1<T>(foo: Rc<Mutex<T>>) {}
pub fn pub_test2(foo: Rc<Mutex<MyEnum>>) {}
pub fn pub_test3(foo: Rc<Mutex<SubT<usize>>>) {}
pub fn test3(foo: Rc<Mutex<SubT<usize>>>) {} fn main() {}
fn main() {
test1(Rc::new(Mutex::new(1)));
test2(Rc::new(Mutex::new(MyEnum::One)));
test3(Rc::new(Mutex::new(SubT { foo: 1 })));
let _my_struct = MyStruct {
foo: Rc::new(Mutex::new(1)),
};
}

View File

@ -8,26 +8,26 @@ LL | foo: Rc<Mutex<i32>>,
= help: consider using `Rc<RefCell<_>>` or `Arc<Mutex<_>>` instead = help: consider using `Rc<RefCell<_>>` or `Arc<Mutex<_>>` instead
error: usage of `Rc<Mutex<_>>` error: usage of `Rc<Mutex<_>>`
--> $DIR/rc_mutex.rs:20:22 --> $DIR/rc_mutex.rs:26:18
| |
LL | pub fn test1<T>(foo: Rc<Mutex<T>>) {} LL | fn test1<T>(foo: Rc<Mutex<T>>) {}
| ^^^^^^^^^^^^ | ^^^^^^^^^^^^
| |
= help: consider using `Rc<RefCell<_>>` or `Arc<Mutex<_>>` instead = help: consider using `Rc<RefCell<_>>` or `Arc<Mutex<_>>` instead
error: usage of `Rc<Mutex<_>>` error: usage of `Rc<Mutex<_>>`
--> $DIR/rc_mutex.rs:22:19 --> $DIR/rc_mutex.rs:27:15
| |
LL | pub fn test2(foo: Rc<Mutex<MyEnum>>) {} LL | fn test2(foo: Rc<Mutex<MyEnum>>) {}
| ^^^^^^^^^^^^^^^^^ | ^^^^^^^^^^^^^^^^^
| |
= help: consider using `Rc<RefCell<_>>` or `Arc<Mutex<_>>` instead = help: consider using `Rc<RefCell<_>>` or `Arc<Mutex<_>>` instead
error: usage of `Rc<Mutex<_>>` error: usage of `Rc<Mutex<_>>`
--> $DIR/rc_mutex.rs:24:19 --> $DIR/rc_mutex.rs:28:15
| |
LL | pub fn test3(foo: Rc<Mutex<SubT<usize>>>) {} LL | fn test3(foo: Rc<Mutex<SubT<usize>>>) {}
| ^^^^^^^^^^^^^^^^^^^^^^ | ^^^^^^^^^^^^^^^^^^^^^^
| |
= help: consider using `Rc<RefCell<_>>` or `Arc<Mutex<_>>` instead = help: consider using `Rc<RefCell<_>>` or `Arc<Mutex<_>>` instead