From ebc00dc9c127ef429f71571c5c860093dfd03823 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Moritz=20Pfl=C3=BCgner?= Date: Wed, 18 Dec 2024 13:33:26 +0100 Subject: [PATCH] #739 junit<4/5>:AssertionMustProvideMessage returned false positives for assert methods with a non-void return type. --- .../META-INF/jqassistant-rules/junit4.xml | 6 +++--- .../META-INF/jqassistant-rules/junit5.xml | 4 ++-- .../plugin/junit/test/rule/Junit4IT.java | 16 ++++++++++------ .../plugin/junit/test/rule/Junit5IT.java | 10 ++++++---- .../junit/test/set/junit4/Assertions4Junit4.java | 6 ++++++ .../junit/test/set/junit5/Assertions4Junit5.java | 5 +++++ 6 files changed, 32 insertions(+), 15 deletions(-) diff --git a/plugin/junit/src/main/resources/META-INF/jqassistant-rules/junit4.xml b/plugin/junit/src/main/resources/META-INF/jqassistant-rules/junit4.xml index 2fa47f134e..e2b5154485 100644 --- a/plugin/junit/src/main/resources/META-INF/jqassistant-rules/junit4.xml +++ b/plugin/junit/src/main/resources/META-INF/jqassistant-rules/junit4.xml @@ -139,8 +139,8 @@ WHERE assertType.fqn = 'org.junit.Assert' and ( - assertMethod.signature =~ 'void assert.*' - or assertMethod.signature =~ 'void fail.*' + assertMethod.signature CONTAINS ' assert' + or assertMethod.signature CONTAINS ' fail' ) SET assertMethod:Junit4:Assert @@ -208,7 +208,7 @@ (testType:Type)-[:DECLARES]->(testMethod:Test:Method), (testMethod)-[invocation:INVOKES*]->(assertMethod:Junit4:Assert:Method) WHERE NOT ( - assertMethod.signature =~ 'void assert.*\\(java.lang.String,.*\\)' + assertMethod.signature =~ '.*assert.*\\(java.lang.String,.*\\)' or assertMethod.signature = 'void fail(java.lang.String)' ) RETURN diff --git a/plugin/junit/src/main/resources/META-INF/jqassistant-rules/junit5.xml b/plugin/junit/src/main/resources/META-INF/jqassistant-rules/junit5.xml index d1782d401c..7b81ea1e36 100644 --- a/plugin/junit/src/main/resources/META-INF/jqassistant-rules/junit5.xml +++ b/plugin/junit/src/main/resources/META-INF/jqassistant-rules/junit5.xml @@ -451,8 +451,8 @@ (testType:Type)-[:DECLARES]->(testMethod:Test:Method), (testMethod)-[invocation:INVOKES]->(assertMethod:Junit5:Assert:Method) WHERE NOT ( - assertMethod.signature =~ 'void assert.*\\(.*java.lang.String\\)' - or assertMethod.signature =~ 'void assert.*\\(.*java.util.function.Supplier\\)' + assertMethod.signature =~ '.*assert.*\\(.*java.lang.String\\)' + or assertMethod.signature =~ '.*assert.*\\(.*java.util.function.Supplier\\)' or assertMethod.signature = 'java.lang.Object fail(java.lang.String)' ) RETURN diff --git a/plugin/junit/src/test/java/com/buschmais/jqassistant/plugin/junit/test/rule/Junit4IT.java b/plugin/junit/src/test/java/com/buschmais/jqassistant/plugin/junit/test/rule/Junit4IT.java index 9164aaef1b..733f61e55c 100644 --- a/plugin/junit/src/test/java/com/buschmais/jqassistant/plugin/junit/test/rule/Junit4IT.java +++ b/plugin/junit/src/test/java/com/buschmais/jqassistant/plugin/junit/test/rule/Junit4IT.java @@ -21,6 +21,7 @@ import com.buschmais.jqassistant.plugin.junit.test.set.junit5.Assertions4Junit5; import org.junit.Assert; +import org.junit.function.ThrowingRunnable; import org.junit.jupiter.api.Test; import static com.buschmais.jqassistant.core.report.api.model.Result.Status.FAILURE; @@ -173,8 +174,9 @@ public void assertMethod() throws Exception { assertThat(applyConcept("java:AssertMethod").getStatus(), equalTo(SUCCESS)); store.beginTransaction(); List methods = query("match (m:Assert:Junit4:Method) return m").getColumn("m"); - assertThat(methods, containsInAnyOrder(methodDescriptor(Assert.class, "assertTrue", boolean.class), - methodDescriptor(Assert.class, "assertTrue", String.class, boolean.class), methodDescriptor(Assert.class, "fail", String.class))); + assertThat(methods, containsInAnyOrder(methodDescriptor(Assert.class, "assertThrows", String.class, Class.class, ThrowingRunnable.class), + methodDescriptor(Assert.class, "assertTrue", boolean.class), methodDescriptor(Assert.class, "assertTrue", String.class, boolean.class), + methodDescriptor(Assert.class, "fail", String.class))); store.commitTransaction(); } @@ -344,7 +346,7 @@ public void nonJUnit4TestMethod() throws Exception { .get("TestMethod") .getValue()) .collect(Collectors.toList()); - assertThat(rows.size(), equalTo(12)); + assertThat(rows.size(), equalTo(13)); assertThat(rows, containsInAnyOrder(is(methodDescriptor(Assertions4Junit5.class, "assertWithoutMessage")), is(methodDescriptor(Assertions4Junit5.class, "assertWithMessageSupplier")), is(methodDescriptor(Assertions4Junit5.class, "assertWithMessage")), is(methodDescriptor(Assertions4Junit5.class, "repeatedTestWithoutAssertion")), @@ -354,7 +356,8 @@ public void nonJUnit4TestMethod() throws Exception { is(methodDescriptor(Assertions4Junit5.class, "testWithDeepNestedAssertion")), is(methodDescriptor(Assertions4Junit5.class, "testWithDeepAndShallowAssertion")), is(methodDescriptor(Assertions4Junit5.class, "assertWithNonVoidReturn")), - is(methodDescriptor(Assertions4Junit5.class, "assertInSuperClass")))); + is(methodDescriptor(Assertions4Junit5.class, "assertInSuperClass")), + is(methodDescriptor(Assertions4Junit5.class, "assertWithMessageButNonVoidReturnType")))); store.commitTransaction(); } @@ -378,11 +381,12 @@ public void usageOfJUnit5TestApi() throws Exception { .get("TestMethod") .getValue()) .collect(Collectors.toList()); - assertThat(rows.size(), equalTo(7)); + assertThat(rows.size(), equalTo(8)); assertThat(rows, containsInAnyOrder(is(methodDescriptor(Assertions4Junit5.class, "assertWithoutMessage")), is(methodDescriptor(Assertions4Junit5.class, "assertWithMessageSupplier")), is(methodDescriptor(Assertions4Junit5.class, "assertWithMessage")), is(methodDescriptor(Assertions4Junit5.class, "testWithAssertion")), is(methodDescriptor(Assertions4Junit5.class, "testWithNestedAssertion")), - is(methodDescriptor(Assertions4Junit5.class, "assertWithNonVoidReturn")), is(methodDescriptor(Assertions4Junit5.class, "testWithDeepAndShallowAssertion")))); + is(methodDescriptor(Assertions4Junit5.class, "assertWithNonVoidReturn")), is(methodDescriptor(Assertions4Junit5.class, "testWithDeepAndShallowAssertion")), + is(methodDescriptor(Assertions4Junit5.class, "assertWithMessageButNonVoidReturnType")))); store.commitTransaction(); } diff --git a/plugin/junit/src/test/java/com/buschmais/jqassistant/plugin/junit/test/rule/Junit5IT.java b/plugin/junit/src/test/java/com/buschmais/jqassistant/plugin/junit/test/rule/Junit5IT.java index 6b30c73f6c..6feb18a7cc 100644 --- a/plugin/junit/src/test/java/com/buschmais/jqassistant/plugin/junit/test/rule/Junit5IT.java +++ b/plugin/junit/src/test/java/com/buschmais/jqassistant/plugin/junit/test/rule/Junit5IT.java @@ -464,11 +464,12 @@ public void nonJUnit5TestMethod() throws Exception { .get("TestMethod") .getValue()) .collect(Collectors.toList()); - assertThat(rows.size(), equalTo(6)); + assertThat(rows.size(), equalTo(7)); assertThat(rows, containsInAnyOrder(is(methodDescriptor(Assertions4Junit4.class, "assertWithoutMessage")), is(methodDescriptor(Assertions4Junit4.class, "assertWithMessage")), is(methodDescriptor(Assertions4Junit4.class, "testWithoutAssertion")), is(methodDescriptor(Assertions4Junit4.class, "testWithAssertion")), is(methodDescriptor(Assertions4Junit4.class, "testWithNestedAssertion")), - is(methodDescriptor(Assertions4Junit4.class, "testWithExpectedRuntimeException")))); + is(methodDescriptor(Assertions4Junit4.class, "testWithExpectedRuntimeException")), + is(methodDescriptor(Assertions4Junit4.class, "assertWithMessageButNonVoidReturnType")))); store.commitTransaction(); } @@ -492,10 +493,11 @@ public void usageOfJUnit4TestApi() throws Exception { .get("TestMethod") .getValue()) .collect(Collectors.toList()); - assertThat(rows.size(), equalTo(4)); + assertThat(rows.size(), equalTo(5)); assertThat(rows, containsInAnyOrder(is(methodDescriptor(Assertions4Junit4.class, "assertWithoutMessage")), is(methodDescriptor(Assertions4Junit4.class, "assertWithMessage")), is(methodDescriptor(Assertions4Junit4.class, "testWithAssertion")), - is(methodDescriptor(Assertions4Junit4.class, "testWithNestedAssertion")))); + is(methodDescriptor(Assertions4Junit4.class, "testWithNestedAssertion")), + is(methodDescriptor(Assertions4Junit4.class, "assertWithMessageButNonVoidReturnType")))); store.commitTransaction(); } diff --git a/plugin/junit/src/test/java/com/buschmais/jqassistant/plugin/junit/test/set/junit4/Assertions4Junit4.java b/plugin/junit/src/test/java/com/buschmais/jqassistant/plugin/junit/test/set/junit4/Assertions4Junit4.java index e0918d5cdb..dfb95eb580 100644 --- a/plugin/junit/src/test/java/com/buschmais/jqassistant/plugin/junit/test/set/junit4/Assertions4Junit4.java +++ b/plugin/junit/src/test/java/com/buschmais/jqassistant/plugin/junit/test/set/junit4/Assertions4Junit4.java @@ -3,6 +3,7 @@ import org.junit.Ignore; import org.junit.Test; +import static org.junit.Assert.assertThrows; import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; @@ -14,6 +15,11 @@ public void assertWithoutMessage() { assertTrue(true); } + @Test + public void assertWithMessageButNonVoidReturnType() { + assertThrows("Condition must be true", NullPointerException.class, null); + } + @Test public void assertWithMessage() { assertTrue("Condition must be true", true); diff --git a/plugin/junit/src/test/java/com/buschmais/jqassistant/plugin/junit/test/set/junit5/Assertions4Junit5.java b/plugin/junit/src/test/java/com/buschmais/jqassistant/plugin/junit/test/set/junit5/Assertions4Junit5.java index d5c598cd0b..77100ec18d 100644 --- a/plugin/junit/src/test/java/com/buschmais/jqassistant/plugin/junit/test/set/junit5/Assertions4Junit5.java +++ b/plugin/junit/src/test/java/com/buschmais/jqassistant/plugin/junit/test/set/junit5/Assertions4Junit5.java @@ -16,6 +16,11 @@ public void assertWithoutMessage() { assertTrue(true); } + @Test + public void assertWithMessageButNonVoidReturnType() { + assertThrows(NullPointerException.class, null, "Condition must be true"); + } + @Test public void assertWithMessageSupplier() { assertTrue(() -> true, () -> "S");