Skip to content

Commit

Permalink
Auto merge of #12210 - GuillaumeGomez:add-regression-test-2371, r=bly…
Browse files Browse the repository at this point in the history
…xyas

Add regression ui test for #2371

Fixes #2371.

#2371 seems to already be handled correctly in the lint. This PR adds a ui regression test so we can close it.

r? `@blyxyas`

changelog: Add regression ui test for #2371
  • Loading branch information
bors committed Jan 29, 2024
2 parents 3cd713a + ce8b4b6 commit c148bce
Show file tree
Hide file tree
Showing 4 changed files with 37 additions and 17 deletions.
1 change: 0 additions & 1 deletion clippy_lints/src/methods/unnecessary_fold.rs
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,6 @@ fn check_fold_with_op(
cx,
UNNECESSARY_FOLD,
fold_span.with_hi(expr.span.hi()),
// TODO #2371 don't suggest e.g., .any(|x| f(x)) if we can suggest .any(f)
"this `.fold` can be written more succinctly using another method",
"try",
sugg,
Expand Down
6 changes: 6 additions & 0 deletions tests/ui/unnecessary_fold.fixed
Original file line number Diff line number Diff line change
@@ -1,9 +1,15 @@
#![allow(dead_code)]

fn is_any(acc: bool, x: usize) -> bool {
acc || x > 2
}

/// Calls which should trigger the `UNNECESSARY_FOLD` lint
fn unnecessary_fold() {
// Can be replaced by .any
let _ = (0..3).any(|x| x > 2);
// Can be replaced by .any (checking suggestion)
let _ = (0..3).fold(false, is_any);
// Can be replaced by .all
let _ = (0..3).all(|x| x > 2);
// Can be replaced by .sum
Expand Down
6 changes: 6 additions & 0 deletions tests/ui/unnecessary_fold.rs
Original file line number Diff line number Diff line change
@@ -1,9 +1,15 @@
#![allow(dead_code)]

fn is_any(acc: bool, x: usize) -> bool {
acc || x > 2
}

/// Calls which should trigger the `UNNECESSARY_FOLD` lint
fn unnecessary_fold() {
// Can be replaced by .any
let _ = (0..3).fold(false, |acc, x| acc || x > 2);
// Can be replaced by .any (checking suggestion)
let _ = (0..3).fold(false, |acc, x| is_any(acc, x));
// Can be replaced by .all
let _ = (0..3).fold(true, |acc, x| acc && x > 2);
// Can be replaced by .sum
Expand Down
41 changes: 25 additions & 16 deletions tests/ui/unnecessary_fold.stderr
Original file line number Diff line number Diff line change
@@ -1,95 +1,104 @@
error: this `.fold` can be written more succinctly using another method
--> $DIR/unnecessary_fold.rs:6:20
--> $DIR/unnecessary_fold.rs:10:20
|
LL | let _ = (0..3).fold(false, |acc, x| acc || x > 2);
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `any(|x| x > 2)`
|
= note: `-D clippy::unnecessary-fold` implied by `-D warnings`
= help: to override `-D warnings` add `#[allow(clippy::unnecessary_fold)]`

error: redundant closure
--> $DIR/unnecessary_fold.rs:12:32
|
LL | let _ = (0..3).fold(false, |acc, x| is_any(acc, x));
| ^^^^^^^^^^^^^^^^^^^^^^^ help: replace the closure with the function itself: `is_any`
|
= note: `-D clippy::redundant-closure` implied by `-D warnings`
= help: to override `-D warnings` add `#[allow(clippy::redundant_closure)]`

error: this `.fold` can be written more succinctly using another method
--> $DIR/unnecessary_fold.rs:8:20
--> $DIR/unnecessary_fold.rs:14:20
|
LL | let _ = (0..3).fold(true, |acc, x| acc && x > 2);
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `all(|x| x > 2)`

error: this `.fold` can be written more succinctly using another method
--> $DIR/unnecessary_fold.rs:10:25
--> $DIR/unnecessary_fold.rs:16:25
|
LL | let _: i32 = (0..3).fold(0, |acc, x| acc + x);
| ^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `sum()`

error: this `.fold` can be written more succinctly using another method
--> $DIR/unnecessary_fold.rs:12:25
--> $DIR/unnecessary_fold.rs:18:25
|
LL | let _: i32 = (0..3).fold(1, |acc, x| acc * x);
| ^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `product()`

error: this `.fold` can be written more succinctly using another method
--> $DIR/unnecessary_fold.rs:17:41
--> $DIR/unnecessary_fold.rs:23:41
|
LL | let _: bool = (0..3).map(|x| 2 * x).fold(false, |acc, x| acc || x > 2);
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `any(|x| x > 2)`

error: this `.fold` can be written more succinctly using another method
--> $DIR/unnecessary_fold.rs:47:10
--> $DIR/unnecessary_fold.rs:53:10
|
LL | .fold(false, |acc, x| acc || x > 2);
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `any(|x| x > 2)`

error: this `.fold` can be written more succinctly using another method
--> $DIR/unnecessary_fold.rs:58:33
--> $DIR/unnecessary_fold.rs:64:33
|
LL | assert_eq!(map.values().fold(0, |x, y| x + y), 0);
| ^^^^^^^^^^^^^^^^^^^^^ help: try: `sum::<i32>()`

error: this `.fold` can be written more succinctly using another method
--> $DIR/unnecessary_fold.rs:61:30
--> $DIR/unnecessary_fold.rs:67:30
|
LL | let _ = map.values().fold(0, |x, y| x + y);
| ^^^^^^^^^^^^^^^^^^^^^ help: try: `sum::<i32>()`

error: this `.fold` can be written more succinctly using another method
--> $DIR/unnecessary_fold.rs:62:30
--> $DIR/unnecessary_fold.rs:68:30
|
LL | let _ = map.values().fold(1, |x, y| x * y);
| ^^^^^^^^^^^^^^^^^^^^^ help: try: `product::<i32>()`

error: this `.fold` can be written more succinctly using another method
--> $DIR/unnecessary_fold.rs:63:35
--> $DIR/unnecessary_fold.rs:69:35
|
LL | let _: i32 = map.values().fold(0, |x, y| x + y);
| ^^^^^^^^^^^^^^^^^^^^^ help: try: `sum()`

error: this `.fold` can be written more succinctly using another method
--> $DIR/unnecessary_fold.rs:64:35
--> $DIR/unnecessary_fold.rs:70:35
|
LL | let _: i32 = map.values().fold(1, |x, y| x * y);
| ^^^^^^^^^^^^^^^^^^^^^ help: try: `product()`

error: this `.fold` can be written more succinctly using another method
--> $DIR/unnecessary_fold.rs:65:31
--> $DIR/unnecessary_fold.rs:71:31
|
LL | anything(map.values().fold(0, |x, y| x + y));
| ^^^^^^^^^^^^^^^^^^^^^ help: try: `sum::<i32>()`

error: this `.fold` can be written more succinctly using another method
--> $DIR/unnecessary_fold.rs:66:31
--> $DIR/unnecessary_fold.rs:72:31
|
LL | anything(map.values().fold(1, |x, y| x * y));
| ^^^^^^^^^^^^^^^^^^^^^ help: try: `product::<i32>()`

error: this `.fold` can be written more succinctly using another method
--> $DIR/unnecessary_fold.rs:67:26
--> $DIR/unnecessary_fold.rs:73:26
|
LL | num(map.values().fold(0, |x, y| x + y));
| ^^^^^^^^^^^^^^^^^^^^^ help: try: `sum()`

error: this `.fold` can be written more succinctly using another method
--> $DIR/unnecessary_fold.rs:68:26
--> $DIR/unnecessary_fold.rs:74:26
|
LL | num(map.values().fold(1, |x, y| x * y));
| ^^^^^^^^^^^^^^^^^^^^^ help: try: `product()`

error: aborting due to 15 previous errors
error: aborting due to 16 previous errors

0 comments on commit c148bce

Please sign in to comment.