From df11939589989fada7b131c4ee239dfea361612c Mon Sep 17 00:00:00 2001 From: chrisly42 Date: Sat, 3 Aug 2019 20:57:34 +0200 Subject: [PATCH] New JoinVarArgsContains inspection that will detect multiple .contains(), .doesNotContain(), and .containsOnlyOnce() calls within the same statement that could be joined together using variadic arguments. --- README.md | 27 ++++++++-- build.gradle | 4 +- .../intellij/plugins/cajon/CommonMatchers.kt | 8 ++- .../intellij/plugins/cajon/MethodNames.kt | 2 + .../ImplicitAssertionInspection.kt | 2 +- .../JoinVarArgsContainsInspection.kt | 53 +++++++++++++++++++ .../quickfixes/JoinVarArgsContainsQuickFix.kt | 38 +++++++++++++ src/main/resources/META-INF/plugin.xml | 2 + .../JoinVarArgsContains.html | 11 ++++ .../JoinVarArgsContainsInspectionTest.kt | 19 +++++++ .../GuavaOptional/GuavaOptionalAfter.java | 7 +++ .../GuavaOptional/GuavaOptionalBefore.java | 7 +++ .../Java8Optional/Java8OptionalAfter.java | 7 +++ .../Java8Optional/Java8OptionalBefore.java | 7 +++ .../JoinVarArgsContainsAfter.java | 22 ++++++++ .../JoinVarArgsContainsBefore.java | 28 ++++++++++ 16 files changed, 236 insertions(+), 8 deletions(-) create mode 100644 src/main/java/de/platon42/intellij/plugins/cajon/inspections/JoinVarArgsContainsInspection.kt create mode 100644 src/main/java/de/platon42/intellij/plugins/cajon/quickfixes/JoinVarArgsContainsQuickFix.kt create mode 100644 src/main/resources/inspectionDescriptions/JoinVarArgsContains.html create mode 100644 src/test/java/de/platon42/intellij/plugins/cajon/inspections/JoinVarArgsContainsInspectionTest.kt create mode 100644 src/test/resources/inspections/JoinVarArgsContains/JoinVarArgsContainsAfter.java create mode 100644 src/test/resources/inspections/JoinVarArgsContains/JoinVarArgsContainsBefore.java diff --git a/README.md b/README.md index 1c1c85d..520009f 100644 --- a/README.md +++ b/README.md @@ -92,6 +92,23 @@ You can toggle the various inspections in the Settings/Editor/Inspections in the The behavior regarding the insertion of line breaks between the expressions can be configured in the inspection settings. +- JoinVarArgsContains + + Looks for ```.contains()```, ```.doesNotContain()```, and .```containsOnlyOnce()``` calls for iterables + within the same statement. The available quickfix can join the arguments to variadic version of the call + and remove the surplus one. + + ``` + from: assertThat(expected).contains("foo").doesNotContain("bar").contains("etc").doesNotContain("huh"); + to: assertThat(expected).contains("foo", "etc").doesNotContain("bar", "huh"); + ``` + Will not be performed on more complex statements with ```.extracting()``` or ```.as()``` to avoid + changing semantics or losing descriptions. + + Note that the quickfix does not handle comments very well and might remove them during the operation. + + You may need to perform some manual reformatting, if the line gets too long after applying the fix. + - AssertThatObjectIsNullOrNotNull Uses ```isNull()``` and ```isNotNull()``` instead. @@ -343,7 +360,7 @@ You can toggle the various inspections in the Settings/Editor/Inspections in the to: assertThat(opt).isPresent(); from: assertThat(opt).isEqualTo(Optional.of("foo")); - from: assertThat(opt).isEqualTo(Optional.ofNullable("foo")); + from: assertThat(opt).isEqualTo(Optional.ofNullable("foo")); // only for constant "foo" to: assertThat(opt).contains("foo"); from: assertThat(opt).isEqualTo(Optional.empty()); @@ -380,7 +397,7 @@ You can toggle the various inspections in the Settings/Editor/Inspections in the to: assertThat(opt).isPresent(); from: assertThat(opt).isEqualTo(Optional.of("foo")); - from: assertThat(opt).isEqualTo(Optional.fromNullable("foo")); + from: assertThat(opt).isEqualTo(Optional.fromNullable("foo")); // only for constant "foo" to: assertThat(opt).contains("foo"); from: assertThat(opt).isEqualTo(Optional.absent()); @@ -509,7 +526,7 @@ The IntelliJ framework actually uses the JUnit 3 TestCase for plugin testing and Feel free to use the code (in package ```de.platon42.intellij.jupiter```) for your projects (with attribution). ## Planned features -- Joining ```.contains()``` expressions +- More Optional fixes such as opt1.get() == opt2.get() etc. - Converting ```foo.compareTo(bar) == 0``` to ```isEqualTo()``` (yes, I've *really* seen code like that) - Extraction with property names to lambda with Java 8 @@ -520,7 +537,9 @@ Feel free to use the code (in package ```de.platon42.intellij.jupiter```) for yo ## Changelog -#### V1.3 (02-Aug-19) +#### V1.3 (03-Aug-19) +- New JoinVarArgsContains inspection that will detect multiple ```.contains()```, ```.doesNotContain()```, + and ```.containsOnlyOnce()``` calls within the same statement that could be joined together using variadic arguments. - AssertJ 3.13.0 broke some inspections due to new ```AbstractStringAssert::isEqualTo()``` method. - AssertThatJava8Optional and AssertThatGuavaOptional inspections do not longer try to fix ```assertThat(optional).isEqualTo(Optional.fromNullable(expression))``` to ```contains()``` diff --git a/build.gradle b/build.gradle index 996987e..467fe8c 100644 --- a/build.gradle +++ b/build.gradle @@ -43,8 +43,10 @@ intellij { patchPluginXml { changeNotes """ -

V1.3 (02-Aug-19)

+

V1.3 (03-Aug-19)