From 7133c55710e66cc27f2613bf4496e91155814658 Mon Sep 17 00:00:00 2001 From: chrisly42 Date: Wed, 15 May 2019 20:50:30 +0200 Subject: [PATCH] Added Guava Optional opt.orNull() == null case. Added Java 8 Optional opt.orElse(null) == null case, too. --- README.md | 21 ++++++++-- build.gradle | 4 +- .../intellij/plugins/cajon/Extensions.kt | 42 +++++++++++++++++++ .../inspections/AbstractAssertJInspection.kt | 9 ++++ .../AssertThatBinaryExpressionInspection.kt | 4 +- ...ThatCollectionOrMapExpressionInspection.kt | 4 +- .../AssertThatGuavaOptionalInspection.kt | 9 ++++ .../AssertThatJava8OptionalInspection.kt | 11 +++-- .../AssertThatStringExpressionInspection.kt | 4 +- .../MoveOutMethodCallExpressionQuickFix.kt | 12 ++++-- .../AssertThatGuavaOptionalInspectionTest.kt | 2 + .../AssertThatJava8OptionalInspectionTest.kt | 2 + .../GuavaOptional/GuavaOptionalAfter.java | 5 +++ .../GuavaOptional/GuavaOptionalBefore.java | 5 +++ .../Java8Optional/Java8OptionalAfter.java | 7 ++++ .../Java8Optional/Java8OptionalBefore.java | 7 ++++ 16 files changed, 134 insertions(+), 14 deletions(-) diff --git a/README.md b/README.md index 883b058..02a3903 100644 --- a/README.md +++ b/README.md @@ -265,7 +265,7 @@ You can toggle the various inspections in the Settings/Editor/Inspections in the to: assertThat(primActual).isEqualTo(primExpected); from: assertThat(10 < primActual).isNotEqualTo(false); - to: assertThat(primActual).isGreaterThan(primExpected); + to: assertThat(primActual).isGreaterThan(10); from: assertThat(objActual != objExpected).isEqualTo(true); to: assertThat(objActual).isNotSameAs(objExpected); @@ -301,6 +301,12 @@ You can toggle the various inspections in the Settings/Editor/Inspections in the from: assertThat(opt.get()).isSameAs("foo"); to: assertThat(opt).containsSame("foo"); + from: assertThat(opt.orElse(null)).isEqualTo(null); + to: assertThat(opt).isNotPresent(); + + from: assertThat(opt.orElse(null)).isNotEqualTo(null); + to: assertThat(opt).isPresent(); + from: assertThat(opt).isEqualTo(Optional.of("foo")); from: assertThat(opt).isEqualTo(Optional.ofNullable("foo")); to: assertThat(opt).contains("foo"); @@ -332,6 +338,12 @@ You can toggle the various inspections in the Settings/Editor/Inspections in the from: assertThat(opt.get()).isEqualTo("foo"); to: assertThat(opt).contains("foo"); + from: assertThat(opt.orNull()).isEqualTo(null); + to: assertThat(opt).isAbsent(); + + from: assertThat(opt.orNull()).isNotEqualTo(null); + to: assertThat(opt).isPresent(); + from: assertThat(opt).isEqualTo(Optional.of("foo")); from: assertThat(opt).isEqualTo(Optional.fromNullable("foo")); to: assertThat(opt).contains("foo"); @@ -436,8 +448,8 @@ You can toggle the various inspections in the Settings/Editor/Inspections in the .flatExtracting(Extractors.resultOf("bareMethod") ``` Works on both POJOs and ```Iterable```s/```Array```s. - Implementation is very basic though and does not work with fancy cascaded .extracting() sequences. - If there's demand, I will add it. + Implementation is very basic though and does not work with fancy cascaded ```.extracting()``` sequences. + If there's demand, I could add it. ## Development notice @@ -450,6 +462,7 @@ Feel free to use the code (in package ```de.platon42.intellij.jupiter```) for yo ## Planned features - Joining .contains() expressions - Removing .isPresent().contains() combinations for Optionals +- Converting ```foo.compareTo(bar) == 0``` to ```isEqualTo()``` (yes, I've *really* seen code like that) - Extraction with property names to lambda with Java 8 ``` from: assertThat(object).extracting("propOne", "propNoGetter", "propTwo.innerProp")... @@ -460,6 +473,8 @@ Feel free to use the code (in package ```de.platon42.intellij.jupiter```) for yo #### V1.1 (unreleased) - Improved JoinAssertThatStatements detection of expressions with side-effects and added pre/post-increment/decrement detection. +- Added Guava Optional ```opt.orNull() == null``` case. You know, I'm not making this stuff up, people actually write this kind of code. +- Added Java 8 Optional ```opt.orElse(null) == null``` case, too. #### V1.0 (06-May-19) - First release to be considered stable enough for production use. diff --git a/build.gradle b/build.gradle index fc506a3..d7631cb 100644 --- a/build.gradle +++ b/build.gradle @@ -35,7 +35,7 @@ compileTestKotlin { kotlinOptions.jvmTarget = "1.8" } intellij { - version '2019.1.1' + version '2019.1.2' // pluginName 'Concise AssertJ Optimizing Nitpicker (Cajon)' updateSinceUntilBuild false } @@ -45,6 +45,8 @@ patchPluginXml {

V1.1 (unreleased)

V1.0 (06-May-19)