aboutsummaryrefslogtreecommitdiffstats
path: root/bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis
diff options
context:
space:
mode:
authorJon Bratseth <bratseth@oath.com>2021-12-19 19:46:50 +0100
committerGitHub <noreply@github.com>2021-12-19 19:46:50 +0100
commit6df122c97a324461194e0ca7d9e71fd1f77f325d (patch)
tree2c4df71208be6b8615961a025e699b8e1734401e /bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis
parent3662fb1b96d325fe7ff07a6eb031d7d58b5cc9e2 (diff)
parent4c56b0aedb0284140ef94aa3db0531da7342c628 (diff)
Merge pull request #20581 from vespa-engine/balder/reduce-usage-of-hamcrest-2
Simplify testing by sticking to assertEquals/True/False
Diffstat (limited to 'bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis')
-rw-r--r--bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/AnalyzeClassTest.java93
-rw-r--r--bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/AnalyzeMethodBodyTest.java26
-rw-r--r--bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/PackageTallyTest.java9
-rw-r--r--bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/TestUtilities.java18
4 files changed, 59 insertions, 87 deletions
diff --git a/bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/AnalyzeClassTest.java b/bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/AnalyzeClassTest.java
index 44ef26646f0..518f65ded17 100644
--- a/bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/AnalyzeClassTest.java
+++ b/bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/AnalyzeClassTest.java
@@ -12,28 +12,22 @@ import com.yahoo.container.plugin.classanalysis.sampleclasses.MethodAnnotation;
import com.yahoo.container.plugin.classanalysis.sampleclasses.MethodInvocation;
import com.yahoo.osgi.annotation.ExportPackage;
import com.yahoo.osgi.annotation.Version;
-import org.hamcrest.Matcher;
-import org.hamcrest.Matchers;
-import org.junit.Rule;
import org.junit.Test;
-import org.junit.rules.ExpectedException;
import javax.security.auth.login.LoginException;
import java.awt.Image;
import java.awt.image.ImagingOpException;
import java.awt.image.Kernel;
+import java.util.List;
import java.util.Optional;
import static com.yahoo.container.plugin.classanalysis.TestUtilities.analyzeClass;
import static com.yahoo.container.plugin.classanalysis.TestUtilities.classFile;
import static com.yahoo.container.plugin.classanalysis.TestUtilities.name;
-import static com.yahoo.container.plugin.classanalysis.TestUtilities.throwableMessage;
-import static org.hamcrest.Matchers.allOf;
-import static org.hamcrest.Matchers.containsString;
-import static org.hamcrest.Matchers.hasItem;
-import static org.hamcrest.Matchers.is;
-import static org.hamcrest.Matchers.not;
-import static org.junit.Assert.assertThat;
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertFalse;
+import static org.junit.Assert.assertTrue;
+import static org.junit.Assert.fail;
/**
* Tests that analysis of class files works.
@@ -45,128 +39,127 @@ public class AnalyzeClassTest {
@Test
public void require_that_full_class_name_is_returned() {
- assertThat(analyzeClass(Base.class).getName(), is(name(Base.class)));
+ assertEquals(name(Base.class), analyzeClass(Base.class).getName());
}
@Test
public void require_that_base_class_is_included() {
- assertThat(analyzeClass(Derived.class).getReferencedClasses(), hasItem(name(Base.class)));
+ assertTrue(analyzeClass(Derived.class).getReferencedClasses().contains(name(Base.class)));
}
@Test
public void require_that_implemented_interfaces_are_included() {
- assertThat(analyzeClass(Base.class).getReferencedClasses(),
- allOf(hasItem(name(Interface1.class)), hasItem(name(Interface2.class))));
+ assertTrue(analyzeClass(Base.class).getReferencedClasses().containsAll(
+ List.of(name(Interface1.class), name(Interface2.class))));
}
@Test
public void require_that_interface_can_be_analyzed() {
ClassFileMetaData classMetaData = analyzeClass(Interface1.class);
- assertThat(classMetaData.getName(), is(name(Interface1.class)));
- assertThat(classMetaData.getReferencedClasses(), hasItem(name(Interface2.class)));
+ assertEquals(name(Interface1.class), classMetaData.getName());
+ assertTrue(classMetaData.getReferencedClasses().contains(name(Interface2.class)));
}
@Test
public void require_that_return_type_is_included() {
- assertThat(analyzeClass(Interface1.class).getReferencedClasses(), hasItem(name(Image.class)));
+ assertTrue(analyzeClass(Interface1.class).getReferencedClasses().contains(name(Image.class)));
}
@Test
public void require_that_parameters_are_included() {
- assertThat(analyzeClass(Interface1.class).getReferencedClasses(), hasItem(name(Kernel.class)));
+ assertTrue(analyzeClass(Interface1.class).getReferencedClasses().contains(name(Kernel.class)));
}
@Test
public void require_that_exceptions_are_included() {
- assertThat(analyzeClass(Interface1.class).getReferencedClasses(), hasItem(name(ImagingOpException.class)));
+ assertTrue(analyzeClass(Interface1.class).getReferencedClasses().contains(name(ImagingOpException.class)));
}
@Test
public void require_that_basic_types_ignored() {
- assertThat(analyzeClass(Interface1.class).getReferencedClasses(),
- not(Matchers.<Iterable<? super String>>anyOf(hasItem("int"), hasItem("float"))));
+ List.of("int", "float").forEach(type ->
+ assertFalse(analyzeClass(Interface1.class).getReferencedClasses().contains(type)));
}
@Test
public void require_that_arrays_of_basic_types_ignored() {
- assertThat(analyzeClass(Interface1.class).getReferencedClasses(),
- not(Matchers.<Iterable<? super String>>anyOf(hasItem("int[]"), hasItem("int[][]"))));
+ List.of("int[]", "int[][]").forEach(type ->
+ assertFalse(analyzeClass(Interface1.class).getReferencedClasses().contains(type)));
}
@Test
public void require_that_instance_field_types_are_included() {
- assertThat(analyzeClass(Fields.class).getReferencedClasses(), hasItem(name(String.class)));
+ assertTrue(analyzeClass(Fields.class).getReferencedClasses().contains(name(String.class)));
}
@Test
public void require_that_static_field_types_are_included() {
- assertThat(analyzeClass(Fields.class).getReferencedClasses(), hasItem(name(java.util.List.class)));
+ assertTrue(analyzeClass(Fields.class).getReferencedClasses().contains(name(java.util.List.class)));
}
@Test
public void require_that_field_annotation_is_included() {
- assertThat(analyzeClass(Fields.class).getReferencedClasses(), hasItem(name(DummyAnnotation.class)));
+ assertTrue(analyzeClass(Fields.class).getReferencedClasses().contains(name(DummyAnnotation.class)));
}
@Test
public void require_that_class_annotation_is_included() {
- assertThat(analyzeClass(ClassAnnotation.class).getReferencedClasses(), hasItem(name(DummyAnnotation.class)));
+ assertTrue(analyzeClass(ClassAnnotation.class).getReferencedClasses().contains(name(DummyAnnotation.class)));
}
@Test
public void require_that_method_annotation_is_included() {
- assertThat(analyzeClass(MethodAnnotation.class).getReferencedClasses(), hasItem(name(DummyAnnotation.class)));
+ assertTrue(analyzeClass(MethodAnnotation.class).getReferencedClasses().contains(name(DummyAnnotation.class)));
}
@Test
public void require_that_export_package_annotations_are_ignored() {
- assertThat(Analyze.analyzeClass(classFile("com.yahoo.container.plugin.classanalysis.sampleclasses.package-info"))
- .getReferencedClasses(), not(Matchers.<Iterable<? super String>>anyOf(
- hasItem(name(ExportPackage.class)), hasItem(name(Version.class)))));
+ List.of(ExportPackage.class, Version.class).forEach(type ->
+ assertFalse(Analyze.analyzeClass(classFile("com.yahoo.container.plugin.classanalysis.sampleclasses.package-info"))
+ .getReferencedClasses().contains(type)));
}
@Test
public void require_that_export_annotations_are_processed() {
- assertThat(
- Analyze.analyzeClass(classFile("com.yahoo.container.plugin.classanalysis.sampleclasses.package-info")).getExportPackage(),
- is(Optional.of(new ExportPackageAnnotation(3, 1, 4, "TEST_QUALIFIER-2"))));
+ assertEquals(Optional.of(new ExportPackageAnnotation(3, 1, 4, "TEST_QUALIFIER-2")),
+ Analyze.analyzeClass(classFile("com.yahoo.container.plugin.classanalysis.sampleclasses.package-info")).getExportPackage());
}
- @Rule
- public ExpectedException expectedException = ExpectedException.none();
-
@Test
public void require_that_export_annotations_are_validated() {
- expectedException.expect(RuntimeException.class);
- expectedException.expectMessage(containsString("invalid/package-info"));
- expectedException.expectCause(throwableMessage(containsString("qualifier must follow the format")));
- expectedException.expectCause(throwableMessage(containsString("'EXAMPLE INVALID QUALIFIER'")));
- Analyze.analyzeClass(classFile("com.yahoo.container.plugin.classanalysis.sampleclasses.invalid.package-info"));
+ try {
+ Analyze.analyzeClass(classFile("com.yahoo.container.plugin.classanalysis.sampleclasses.invalid.package-info"));
+ fail();
+ } catch (RuntimeException e) {
+ assertTrue(e.getMessage().contains("invalid/package-info"));
+ assertTrue(e.getCause().getMessage().contains("qualifier must follow the format"));
+ assertTrue(e.getCause().getMessage().contains("'EXAMPLE INVALID QUALIFIER'"));
+ }
}
@Test
public void require_that_catch_clauses_are_included() {
- assertThat(Analyze.analyzeClass(classFile("com.yahoo.container.plugin.classanalysis.sampleclasses.CatchException"))
- .getReferencedClasses(), hasItem(name(LoginException.class)));
+ assertTrue(Analyze.analyzeClass(classFile("com.yahoo.container.plugin.classanalysis.sampleclasses.CatchException"))
+ .getReferencedClasses().contains(name(LoginException.class)));
}
@Test
public void require_that_class_references_are_included() {
- assertThat(Analyze.analyzeClass(classFile("com.yahoo.container.plugin.classanalysis.sampleclasses.ClassReference"))
- .getReferencedClasses(), hasItem(name(Interface1.class)));
+ assertTrue(Analyze.analyzeClass(classFile("com.yahoo.container.plugin.classanalysis.sampleclasses.ClassReference"))
+ .getReferencedClasses().contains(name(Interface1.class)));
}
@Test
public void require_that_return_type_of_method_invocations_are_included() {
- assertThat(analyzeClass(MethodInvocation.class).getReferencedClasses(), hasItem(name(Image.class)));
+ assertTrue(analyzeClass(MethodInvocation.class).getReferencedClasses().contains(name(Image.class)));
}
@Test
public void require_that_attributes_are_included() {
//Uses com/coremedia/iso/Utf8.class from com.googlecode.mp4parser:isoparser:1.0-RC-1
- assertThat(Analyze.analyzeClass(classFile("class/Utf8")).getReferencedClasses(),
- hasItem("org.aspectj.weaver.MethodDeclarationLineNumber"));
+ assertTrue(Analyze.analyzeClass(classFile("class/Utf8")).getReferencedClasses()
+ .contains("org.aspectj.weaver.MethodDeclarationLineNumber"));
}
}
diff --git a/bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/AnalyzeMethodBodyTest.java b/bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/AnalyzeMethodBodyTest.java
index b7565a4dad8..4502f88d158 100644
--- a/bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/AnalyzeMethodBodyTest.java
+++ b/bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/AnalyzeMethodBodyTest.java
@@ -11,13 +11,12 @@ import com.yahoo.container.plugin.classanalysis.sampleclasses.Methods;
import org.junit.Test;
import java.io.PrintStream;
+import java.util.List;
import static com.yahoo.container.plugin.classanalysis.TestUtilities.analyzeClass;
import static com.yahoo.container.plugin.classanalysis.TestUtilities.name;
-import static org.hamcrest.Matchers.allOf;
-import static org.hamcrest.Matchers.hasItem;
-import static org.hamcrest.Matchers.not;
-import static org.junit.Assert.assertThat;
+import static org.junit.Assert.assertFalse;
+import static org.junit.Assert.assertTrue;
/**
* Tests that classes used in method bodies are included in the imports list.
@@ -27,47 +26,46 @@ import static org.junit.Assert.assertThat;
public class AnalyzeMethodBodyTest {
@Test
public void require_that_class_of_locals_are_included() {
- assertThat(analyzeClass(Methods.class).getReferencedClasses(), hasItem(name(Base.class)));
+ assertTrue(analyzeClass(Methods.class).getReferencedClasses().contains(name(Base.class)));
}
@Test
public void require_that_class_of_locals_in_static_method_are_included() {
- assertThat(analyzeClass(Methods.class).getReferencedClasses(), hasItem(name(Derived.class)));
+ assertTrue(analyzeClass(Methods.class).getReferencedClasses().contains(name(Derived.class)));
}
@Test
public void require_that_field_references_are_included() {
- assertThat(analyzeClass(Methods.class).getReferencedClasses(),
- allOf(hasItem(name(java.util.List.class)), hasItem(name(Fields.class))));
+ assertTrue(analyzeClass(Methods.class).getReferencedClasses().containsAll(List.of(name(java.util.List.class), name(Fields.class))));
}
@Test
public void require_that_class_owning_field_is_included() {
- assertThat(analyzeClass(Methods.class).getReferencedClasses(), hasItem(name(System.class)));
+ assertTrue(analyzeClass(Methods.class).getReferencedClasses().contains(name(System.class)));
}
@Test
public void require_that_class_containing_method_is_included() {
- assertThat(analyzeClass(Methods.class).getReferencedClasses(), hasItem(name(PrintStream.class)));
+ assertTrue(analyzeClass(Methods.class).getReferencedClasses().contains(name(PrintStream.class)));
}
@Test
public void require_that_element_of_new_multidimensional_array_is_included() {
- assertThat(analyzeClass(Methods.class).getReferencedClasses(), hasItem(name(Interface1.class)));
+ assertTrue(analyzeClass(Methods.class).getReferencedClasses().contains(name(Interface1.class)));
}
@Test
public void require_that_basic_arrays_are_not_included() {
- assertThat(analyzeClass(Methods.class).getReferencedClasses(), not(hasItem("int[]")));
+ assertFalse(analyzeClass(Methods.class).getReferencedClasses().contains("int[]"));
}
@Test
public void require_that_container_generic_parameters_are_included() {
- assertThat(analyzeClass(Methods.class).getReferencedClasses(), hasItem(name(Dummy.class)));
+ assertTrue(analyzeClass(Methods.class).getReferencedClasses().contains(name(Dummy.class)));
}
@Test
public void require_that_class_owning_method_handler_is_included() {
- assertThat(analyzeClass(Methods.class).getReferencedClasses(), hasItem(name(ClassWithMethod.class)));
+ assertTrue(analyzeClass(Methods.class).getReferencedClasses().contains(name(ClassWithMethod.class)));
}
}
diff --git a/bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/PackageTallyTest.java b/bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/PackageTallyTest.java
index cfee980cb91..5bef1457c5f 100644
--- a/bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/PackageTallyTest.java
+++ b/bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/PackageTallyTest.java
@@ -3,11 +3,10 @@ package com.yahoo.container.plugin.classanalysis;
import org.junit.Test;
+import java.util.Map;
import java.util.Set;
-import static java.util.Collections.emptyMap;
-import static org.hamcrest.Matchers.is;
-import static org.junit.Assert.assertThat;
+import static org.junit.Assert.assertEquals;
/**
* @author gjoranv
@@ -16,9 +15,9 @@ public class PackageTallyTest {
@Test
public void referenced_packages_missing_from_are_detected() {
- PackageTally tally = new PackageTally(emptyMap(), Set.of("p1", "java.util", "com.yahoo.api.annotations", "missing"));
+ PackageTally tally = new PackageTally(Map.of(), Set.of("p1", "java.util", "com.yahoo.api.annotations", "missing"));
Set<String> missingPackages = tally.referencedPackagesMissingFrom(Set.of("p1"));
- assertThat(missingPackages, is(Set.of("missing")));
+ assertEquals(Set.of("missing"), missingPackages);
}
}
diff --git a/bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/TestUtilities.java b/bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/TestUtilities.java
index f0784cf80bc..9eacc0625b5 100644
--- a/bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/TestUtilities.java
+++ b/bundle-plugin/src/test/java/com/yahoo/container/plugin/classanalysis/TestUtilities.java
@@ -1,10 +1,6 @@
// Copyright Yahoo. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
package com.yahoo.container.plugin.classanalysis;
-import org.hamcrest.Description;
-import org.hamcrest.Matcher;
-import org.hamcrest.TypeSafeMatcher;
-
import java.io.File;
/**
@@ -23,18 +19,4 @@ public class TestUtilities {
public static String name(Class<?> clazz) {
return clazz.getName();
}
-
- public static TypeSafeMatcher<Throwable> throwableMessage(final Matcher<String> matcher) {
- return new TypeSafeMatcher<Throwable>() {
- @Override
- protected boolean matchesSafely(Throwable throwable) {
- return matcher.matches(throwable.getMessage());
- }
-
- @Override
- public void describeTo(Description description) {
- description.appendText("expects Throwable and a message matching ").appendDescriptionOf(matcher);
- }
- };
- }
}