From f54ac1e0f52d69dda98e0b2e08aefc83e0b67afe Mon Sep 17 00:00:00 2001 From: Tim te Beek Date: Tue, 12 Mar 2024 11:31:12 +0000 Subject: [PATCH 1/2] refactor: Common static analysis issues Use this link to re-run the recipe: https://app.moderne.io/recipes/builder/ggZMncs1O?organizationId=T3BlblJld3JpdGU%3D Co-authored-by: Moderne --- .../kotlin/KotlinIrTypeMappingTest.java | 4 +-- .../kotlin/KotlinTypeMappingTest.java | 33 +++++++++---------- .../format/MinimumViableSpacingTest.java | 14 ++++---- .../format/RemoveTrailingWhitespaceTest.java | 2 +- .../kotlin/style/AutodetectTest.java | 18 +++++----- 5 files changed, 34 insertions(+), 37 deletions(-) diff --git a/src/test/java/org/openrewrite/kotlin/KotlinIrTypeMappingTest.java b/src/test/java/org/openrewrite/kotlin/KotlinIrTypeMappingTest.java index 0137bfdf7..76e7b4692 100644 --- a/src/test/java/org/openrewrite/kotlin/KotlinIrTypeMappingTest.java +++ b/src/test/java/org/openrewrite/kotlin/KotlinIrTypeMappingTest.java @@ -172,7 +172,7 @@ public String methodType(String methodName) { void fileField() { IrProperty property = getCompiledSource().getDeclarations().stream() .filter(it -> it instanceof IrProperty && "field".equals(((IrProperty) it).getName().asString())) - .map(it -> (IrProperty) it).findFirst().orElseThrow(); + .map(IrProperty.class::cast).findFirst().orElseThrow(); assertThat(typeMapper().variableType(property).toString()) .isEqualTo("org.openrewrite.kotlin.KotlinTypeGoatKt{name=field,type=kotlin.Int}"); } @@ -181,7 +181,7 @@ void fileField() { void fileFunction() { IrFunction function = getCompiledSource().getDeclarations().stream() .filter(it -> it instanceof IrFunction && "function".equals(((IrFunction) it).getName().asString())) - .map(it -> (IrFunction) it).findFirst().orElseThrow(); + .map(IrFunction.class::cast).findFirst().orElseThrow(); assertThat(typeMapper().methodDeclarationType(function).toString()) .isEqualTo("org.openrewrite.kotlin.KotlinTypeGoatKt{name=function,return=kotlin.Unit,parameters=[org.openrewrite.kotlin.C]}"); } diff --git a/src/test/java/org/openrewrite/kotlin/KotlinTypeMappingTest.java b/src/test/java/org/openrewrite/kotlin/KotlinTypeMappingTest.java index e3d3a1ffd..c3edbe500 100644 --- a/src/test/java/org/openrewrite/kotlin/KotlinTypeMappingTest.java +++ b/src/test/java/org/openrewrite/kotlin/KotlinTypeMappingTest.java @@ -83,7 +83,7 @@ public JavaType.Method methodType(String methodName) { public K.Property getProperty(String fieldName) { return goatClassDeclaration.getClassDeclaration().getBody().getStatements().stream() - .filter(it -> it instanceof K.Property) + .filter(K.Property.class::isInstance) .map(K.Property.class::cast) .filter(mv -> mv.getVariableDeclarations().getVariables().stream().anyMatch(v -> v.getSimpleName().equals(fieldName))) .findFirst() @@ -110,7 +110,7 @@ void fieldType() { assertThat(id.getType()).isInstanceOf(JavaType.Class.class); assertThat(id.getType().toString()).isEqualTo("kotlin.Int"); - J.MethodDeclaration getter = property.getAccessors().getElements().stream().filter(x -> x.getName().getSimpleName().equals("get")).findFirst().orElse(null); + J.MethodDeclaration getter = property.getAccessors().getElements().stream().filter(x -> "get".equals(x.getName().getSimpleName())).findFirst().orElse(null); JavaType.FullyQualified declaringType = getter.getMethodType().getDeclaringType(); assertThat(declaringType.getFullyQualifiedName()).isEqualTo("org.openrewrite.kotlin.KotlinTypeGoat"); assertThat(getter.getMethodType().getName()).isEqualTo("get"); @@ -118,7 +118,7 @@ void fieldType() { assertThat(getter.getName().getType()).isEqualTo(getter.getMethodType()); assertThat(getter.getMethodType().toString().substring(declaringType.toString().length())).isEqualTo("{name=get,return=kotlin.Int,parameters=[]}"); - J.MethodDeclaration setter = property.getAccessors().getElements().stream().filter(x -> x.getName().getSimpleName().equals("set")).findFirst().orElse(null); + J.MethodDeclaration setter = property.getAccessors().getElements().stream().filter(x -> "set".equals(x.getName().getSimpleName())).findFirst().orElse(null); declaringType = setter.getMethodType().getDeclaringType(); assertThat(declaringType.getFullyQualifiedName()).isEqualTo("org.openrewrite.kotlin.KotlinTypeGoat"); assertThat(setter.getMethodType().getName()).isEqualTo("set"); @@ -129,7 +129,7 @@ void fieldType() { @Test void fileField() { J.VariableDeclarations.NamedVariable nv = cu.getStatements().stream() - .filter(it -> it instanceof J.VariableDeclarations) + .filter(J.VariableDeclarations.class::isInstance) .flatMap(it -> ((J.VariableDeclarations) it).getVariables().stream()) .filter(it -> "field".equals(it.getSimpleName())).findFirst().orElseThrow(); @@ -142,7 +142,7 @@ void fileField() { @Test void fileFunction() { J.MethodDeclaration md = cu.getStatements().stream() - .filter(it -> it instanceof J.MethodDeclaration) + .filter(J.MethodDeclaration.class::isInstance) .map(J.MethodDeclaration.class::cast) .filter(it -> "function".equals(it.getSimpleName())).findFirst().orElseThrow(); @@ -199,7 +199,7 @@ void parameterized() { .map(J.MethodDeclaration.class::cast).findFirst().orElseThrow(); assertThat(md.getMethodType().toString()) .isEqualTo("org.openrewrite.kotlin.KotlinTypeGoat{name=parameterized,return=org.openrewrite.kotlin.PT,parameters=[org.openrewrite.kotlin.PT]}"); - J.VariableDeclarations vd = ((J.VariableDeclarations) md.getParameters().get(0)); + J.VariableDeclarations vd = (J.VariableDeclarations) md.getParameters().get(0); assertThat(vd.getTypeExpression().getType().toString()) .isEqualTo("org.openrewrite.kotlin.PT"); assertThat(((J.ParameterizedType) vd.getTypeExpression()).getClazz().getType().toString()) @@ -1267,7 +1267,7 @@ void annotationOnKotlinConeType(String input, String type) { new KotlinIsoVisitor() { @Override public J.Annotation visitAnnotation(J.Annotation annotation, Integer integer) { - assertThat(String.valueOf(annotation.getType().toString())).isEqualTo(type); + assertThat(annotation.getType().toString()).isEqualTo(type); found.set(true); return super.visitAnnotation(annotation, integer); } @@ -1316,11 +1316,11 @@ class Test { new KotlinIsoVisitor() { @Override public J.Identifier visitIdentifier(J.Identifier identifier, Integer integer) { - if (identifier.getSimpleName().equals("lang")) { + if ("lang".equals(identifier.getSimpleName())) { assertThat(identifier.getType()).isNull(); isFieldTargetNull.set(true); } - if (identifier.getSimpleName().equals("StringBuilder")) { + if ("StringBuilder".equals(identifier.getSimpleName())) { assertThat(identifier.getType().toString()).isEqualTo("java.lang.StringBuilder"); isStringBuilderTyped.set(true); } @@ -1419,15 +1419,12 @@ fun bar(b: Array) {} new KotlinIsoVisitor() { @Override public J.Identifier visitIdentifier(J.Identifier identifier, Integer integer) { - switch (identifier.getSimpleName()) { - case "String" -> { - assertThat(identifier.getType().toString()).isEqualTo("kotlin.String"); - count.incrementAndGet(); - } - case "Number" -> { - assertThat(identifier.getType().toString()).isEqualTo("kotlin.Number"); - count.incrementAndGet(); - } + if ("String".equals(identifier.getSimpleName())) { + assertThat(identifier.getType().toString()).isEqualTo("kotlin.String"); + count.incrementAndGet(); + } else if ("Number".equals(identifier.getSimpleName())) { + assertThat(identifier.getType().toString()).isEqualTo("kotlin.Number"); + count.incrementAndGet(); } return super.visitIdentifier(identifier, integer); } diff --git a/src/test/java/org/openrewrite/kotlin/format/MinimumViableSpacingTest.java b/src/test/java/org/openrewrite/kotlin/format/MinimumViableSpacingTest.java index 2195b30ab..83796a669 100644 --- a/src/test/java/org/openrewrite/kotlin/format/MinimumViableSpacingTest.java +++ b/src/test/java/org/openrewrite/kotlin/format/MinimumViableSpacingTest.java @@ -211,7 +211,7 @@ class A{val zero:Int=0 void variableDeclarationsInClass2() { rewriteRun( spec -> spec.recipes( - toRecipe(() -> new MinimumViableSpacingVisitor<>()) + toRecipe(MinimumViableSpacingVisitor::new) ), kotlin( """ @@ -312,7 +312,7 @@ void noSpaceAferAnnotation() { rewriteRun( spec -> spec.parser(KotlinParser.builder().classpath("junit-jupiter-api")) .recipes( - toRecipe(() -> new MinimumViableSpacingVisitor<>()) + toRecipe(MinimumViableSpacingVisitor::new) ), kotlin( """ @@ -332,7 +332,7 @@ fun testA() { void classConstructor() { rewriteRun( spec -> spec.recipes( - toRecipe(() -> new MinimumViableSpacingVisitor<>()) + toRecipe(MinimumViableSpacingVisitor::new) ), kotlin( """ @@ -351,7 +351,7 @@ class BaseProjectionNode ( void spaceAfterPublic() { rewriteRun( spec -> spec.recipes( - toRecipe(() -> new MinimumViableSpacingVisitor<>()) + toRecipe(MinimumViableSpacingVisitor::new) ), kotlin( """ @@ -369,7 +369,7 @@ public fun me() { void statementWithCommentInPrefix() { rewriteRun( spec -> spec.recipes( - toRecipe(() -> new MinimumViableSpacingVisitor<>()) + toRecipe(MinimumViableSpacingVisitor::new) ), kotlin( """ @@ -387,7 +387,7 @@ fun x() { void compilationUnitDeclarations() { rewriteRun( spec -> spec.recipes( - toRecipe(() -> new MinimumViableSpacingVisitor<>()) + toRecipe(MinimumViableSpacingVisitor::new) ), kotlin( """ @@ -404,7 +404,7 @@ class Test void blockWithImplicitReturn() { rewriteRun( spec -> spec.recipes( - toRecipe(() -> new MinimumViableSpacingVisitor<>()) + toRecipe(MinimumViableSpacingVisitor::new) ), kotlin( """ diff --git a/src/test/java/org/openrewrite/kotlin/format/RemoveTrailingWhitespaceTest.java b/src/test/java/org/openrewrite/kotlin/format/RemoveTrailingWhitespaceTest.java index 24b4de577..579db2d69 100644 --- a/src/test/java/org/openrewrite/kotlin/format/RemoveTrailingWhitespaceTest.java +++ b/src/test/java/org/openrewrite/kotlin/format/RemoveTrailingWhitespaceTest.java @@ -29,7 +29,7 @@ class RemoveTrailingWhitespaceTest implements RewriteTest { @Override public void defaults(RecipeSpec spec) { - spec.recipe(toRecipe(() -> new RemoveTrailingWhitespaceVisitor<>())); + spec.recipe(toRecipe(RemoveTrailingWhitespaceVisitor::new)); } @DocumentExample diff --git a/src/test/java/org/openrewrite/kotlin/style/AutodetectTest.java b/src/test/java/org/openrewrite/kotlin/style/AutodetectTest.java index 228dbd9bb..eebb608e3 100644 --- a/src/test/java/org/openrewrite/kotlin/style/AutodetectTest.java +++ b/src/test/java/org/openrewrite/kotlin/style/AutodetectTest.java @@ -493,15 +493,15 @@ class Test { assertThat(importLayout.getLayout().get(1)) .isInstanceOf(ImportLayoutStyle.Block.ImportPackage.class) - .matches(b -> ((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString().equals("java\\..+")); + .matches(b -> "java\\..+".equals(((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString())); assertThat(importLayout.getLayout().get(2)) .isInstanceOf(ImportLayoutStyle.Block.ImportPackage.class) - .matches(b -> ((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString().equals("javax\\..+")); + .matches(b -> "javax\\..+".equals(((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString())); assertThat(importLayout.getLayout().get(3)) .isInstanceOf(ImportLayoutStyle.Block.ImportPackage.class) - .matches(b -> ((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString().equals("kotlin\\..+")); + .matches(b -> "kotlin\\..+".equals(((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString())); assertThat(importLayout.getLayout().get(4)).isInstanceOf(ImportLayoutStyle.Block.AllAliases.class); } @@ -551,15 +551,15 @@ class Test { assertThat(importLayout.getLayout().get(1)) .isInstanceOf(ImportLayoutStyle.Block.ImportPackage.class) - .matches(b -> ((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString().equals("kotlin\\..+")); + .matches(b -> "kotlin\\..+".equals(((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString())); assertThat(importLayout.getLayout().get(2)) .isInstanceOf(ImportLayoutStyle.Block.ImportPackage.class) - .matches(b -> ((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString().equals("javax\\..+")); + .matches(b -> "javax\\..+".equals(((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString())); assertThat(importLayout.getLayout().get(3)) .isInstanceOf(ImportLayoutStyle.Block.ImportPackage.class) - .matches(b -> ((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString().equals("java\\..+")); + .matches(b -> "java\\..+".equals(((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString())); assertThat(importLayout.getLayout().get(4)).isInstanceOf(ImportLayoutStyle.Block.AllOthers.class); } @@ -594,17 +594,17 @@ class Test { assertThat(importLayout.getLayout().get(0)) .isInstanceOf(ImportLayoutStyle.Block.ImportPackage.class) - .matches(b -> ((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString().equals("java\\..+")); + .matches(b -> "java\\..+".equals(((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString())); assertThat(importLayout.getLayout().get(1)) .isInstanceOf(ImportLayoutStyle.Block.ImportPackage.class) - .matches(b -> ((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString().equals("kotlin\\..+")); + .matches(b -> "kotlin\\..+".equals(((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString())); assertThat(importLayout.getLayout().get(2)).isInstanceOf(ImportLayoutStyle.Block.AllOthers.class); assertThat(importLayout.getLayout().get(3)) .isInstanceOf(ImportLayoutStyle.Block.ImportPackage.class) - .matches(b -> ((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString().equals("javax\\..+")); + .matches(b -> "javax\\..+".equals(((ImportLayoutStyle.Block.ImportPackage) b).getPackageWildcard().toString())); assertThat(importLayout.getLayout().get(4)).isInstanceOf(ImportLayoutStyle.Block.AllAliases.class); } From 21967f170f81feb3e9288144d44ac1dca11ed692 Mon Sep 17 00:00:00 2001 From: Tim te Beek Date: Tue, 12 Mar 2024 18:59:19 +0100 Subject: [PATCH 2/2] Restore constructors in supplier --- .../kotlin/format/MinimumViableSpacingTest.java | 14 +++++++------- .../format/RemoveTrailingWhitespaceTest.java | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/src/test/java/org/openrewrite/kotlin/format/MinimumViableSpacingTest.java b/src/test/java/org/openrewrite/kotlin/format/MinimumViableSpacingTest.java index 83796a669..2195b30ab 100644 --- a/src/test/java/org/openrewrite/kotlin/format/MinimumViableSpacingTest.java +++ b/src/test/java/org/openrewrite/kotlin/format/MinimumViableSpacingTest.java @@ -211,7 +211,7 @@ class A{val zero:Int=0 void variableDeclarationsInClass2() { rewriteRun( spec -> spec.recipes( - toRecipe(MinimumViableSpacingVisitor::new) + toRecipe(() -> new MinimumViableSpacingVisitor<>()) ), kotlin( """ @@ -312,7 +312,7 @@ void noSpaceAferAnnotation() { rewriteRun( spec -> spec.parser(KotlinParser.builder().classpath("junit-jupiter-api")) .recipes( - toRecipe(MinimumViableSpacingVisitor::new) + toRecipe(() -> new MinimumViableSpacingVisitor<>()) ), kotlin( """ @@ -332,7 +332,7 @@ fun testA() { void classConstructor() { rewriteRun( spec -> spec.recipes( - toRecipe(MinimumViableSpacingVisitor::new) + toRecipe(() -> new MinimumViableSpacingVisitor<>()) ), kotlin( """ @@ -351,7 +351,7 @@ class BaseProjectionNode ( void spaceAfterPublic() { rewriteRun( spec -> spec.recipes( - toRecipe(MinimumViableSpacingVisitor::new) + toRecipe(() -> new MinimumViableSpacingVisitor<>()) ), kotlin( """ @@ -369,7 +369,7 @@ public fun me() { void statementWithCommentInPrefix() { rewriteRun( spec -> spec.recipes( - toRecipe(MinimumViableSpacingVisitor::new) + toRecipe(() -> new MinimumViableSpacingVisitor<>()) ), kotlin( """ @@ -387,7 +387,7 @@ fun x() { void compilationUnitDeclarations() { rewriteRun( spec -> spec.recipes( - toRecipe(MinimumViableSpacingVisitor::new) + toRecipe(() -> new MinimumViableSpacingVisitor<>()) ), kotlin( """ @@ -404,7 +404,7 @@ class Test void blockWithImplicitReturn() { rewriteRun( spec -> spec.recipes( - toRecipe(MinimumViableSpacingVisitor::new) + toRecipe(() -> new MinimumViableSpacingVisitor<>()) ), kotlin( """ diff --git a/src/test/java/org/openrewrite/kotlin/format/RemoveTrailingWhitespaceTest.java b/src/test/java/org/openrewrite/kotlin/format/RemoveTrailingWhitespaceTest.java index 579db2d69..24b4de577 100644 --- a/src/test/java/org/openrewrite/kotlin/format/RemoveTrailingWhitespaceTest.java +++ b/src/test/java/org/openrewrite/kotlin/format/RemoveTrailingWhitespaceTest.java @@ -29,7 +29,7 @@ class RemoveTrailingWhitespaceTest implements RewriteTest { @Override public void defaults(RecipeSpec spec) { - spec.recipe(toRecipe(RemoveTrailingWhitespaceVisitor::new)); + spec.recipe(toRecipe(() -> new RemoveTrailingWhitespaceVisitor<>())); } @DocumentExample