From 4dc76b5911e3309b42174f170039543b01574031 Mon Sep 17 00:00:00 2001 From: James Roper Date: Thu, 2 Aug 2018 15:20:58 +1000 Subject: [PATCH 1/2] Zerodep in container TCK Added tests for the zerodep implementation to use the Arquillian Reactive Streams TCK test to run the tests in a container (Thorntail, but should be straight forward to switch to anything else). --- bin/buildDeps.sh | 6 +- pom.xml | 6 ++ zerodep-cdi/pom.xml | 99 +++++++++++++++++++ .../cdi/ReactiveStreamsArquillianTckTest.java | 13 +++ .../zerodep/cdi/ZeroDepArchiveAppender.java | 29 ++++++ .../streams/zerodep/cdi/ZeroDepExtension.java | 17 ++++ ...boss.arquillian.core.spi.LoadableExtension | 4 + 7 files changed, 171 insertions(+), 3 deletions(-) create mode 100644 zerodep-cdi/pom.xml create mode 100644 zerodep-cdi/src/test/java/com/lightbend/microprofile/reactive/streams/zerodep/cdi/ReactiveStreamsArquillianTckTest.java create mode 100644 zerodep-cdi/src/test/java/com/lightbend/microprofile/reactive/streams/zerodep/cdi/ZeroDepArchiveAppender.java create mode 100644 zerodep-cdi/src/test/java/com/lightbend/microprofile/reactive/streams/zerodep/cdi/ZeroDepExtension.java create mode 100644 zerodep-cdi/src/test/resources/META-INF/services/org.jboss.arquillian.core.spi.LoadableExtension diff --git a/bin/buildDeps.sh b/bin/buildDeps.sh index 34f69ce..dee10af 100755 --- a/bin/buildDeps.sh +++ b/bin/buildDeps.sh @@ -1,9 +1,9 @@ #!/bin/bash # This should be set to the commit hash that is being tracked. Needed even if TRACKING_PR is set. -TRACKING_COMMIT="0d0c4f50" +TRACKING_COMMIT="4a1ee95" # To track a particular pull request, put it's number here, otherwise comment it out. -# TRACKING_PR="67" +TRACKING_PR="84" set -e @@ -25,4 +25,4 @@ fi git checkout "${TRACKING_COMMIT}" -mvn -am -pl streams/api,streams/tck clean install -Dmaven.test.skip -Drat.skip=true -Dcheckstyle.skip=true -Dmaven.javadoc.skip=true -Dasciidoctor.skip=true +mvn -am -pl streams/api,streams/tck,streams/tck-arquillian clean install -Dmaven.test.skip -Drat.skip=true -Dcheckstyle.skip=true -Dmaven.javadoc.skip=true -Dasciidoctor.skip=true diff --git a/pom.xml b/pom.xml index 5d4c06e..1ae0b31 100644 --- a/pom.xml +++ b/pom.xml @@ -62,6 +62,7 @@ akka zerodep + zerodep-cdi @@ -76,6 +77,11 @@ microprofile-reactive-streams-operators-tck ${microprofile.reactive.streams.version} + + org.eclipse.microprofile.reactive.streams + microprofile-reactive-streams-operators-tck-arquillian + ${microprofile.reactive.streams.version} + com.typesafe.akka akka-actor_2.12 diff --git a/zerodep-cdi/pom.xml b/zerodep-cdi/pom.xml new file mode 100644 index 0000000..23685ff --- /dev/null +++ b/zerodep-cdi/pom.xml @@ -0,0 +1,99 @@ + + + + + 4.0.0 + + + com.lightbend.microprofile.reactive.streams + lightbend-microprofile-reactive-streams-parent + 1.0-SNAPSHOT + + + lightbend-microprofile-reactive-streams-zerodep-cdi + Lightbend MicroProfile Reactive Streams Operators Zero Dependency CDI + Lightbend MicroProfile Reactive Streams Operators :: Zero Dependency CDI Integration + + + ${project.groupId} + lightbend-microprofile-reactive-streams-zerodep + ${project.version} + + + javax.enterprise + cdi-api + + + org.eclipse.microprofile.reactive.streams + microprofile-reactive-streams-operators-tck-arquillian + test + + + io.thorntail + arquillian + + + org.jboss.arquillian.junit + arquillian-junit-container + + + test + + + + + + + javax.enterprise + cdi-api + 2.0 + + + org.jboss.arquillian + arquillian-bom + 1.1.15.Final + import + pom + + + io.thorntail + bom + 2.0.0.Final + import + pom + + + + + + + + org.apache.maven.plugins + maven-javadoc-plugin + + + attach-javadocs + + jar + + + + + + org.apache.maven.plugins + maven-source-plugin + + + attach-sources + + jar + + + + + + + \ No newline at end of file diff --git a/zerodep-cdi/src/test/java/com/lightbend/microprofile/reactive/streams/zerodep/cdi/ReactiveStreamsArquillianTckTest.java b/zerodep-cdi/src/test/java/com/lightbend/microprofile/reactive/streams/zerodep/cdi/ReactiveStreamsArquillianTckTest.java new file mode 100644 index 0000000..9c1b487 --- /dev/null +++ b/zerodep-cdi/src/test/java/com/lightbend/microprofile/reactive/streams/zerodep/cdi/ReactiveStreamsArquillianTckTest.java @@ -0,0 +1,13 @@ +/* + * Copyright (C) 2018 Lightbend Inc. + */ +package com.lightbend.microprofile.reactive.streams.zerodep.cdi; + +import org.eclipse.microprofile.reactive.streams.tck.arquillian.ReactiveStreamsArquillianTck; + +/** + * This class exists purely to bring in the TCK so that it gets automatically picked up by surefire, and can be run by + * IntelliJ. + */ +public class ReactiveStreamsArquillianTckTest extends ReactiveStreamsArquillianTck { +} diff --git a/zerodep-cdi/src/test/java/com/lightbend/microprofile/reactive/streams/zerodep/cdi/ZeroDepArchiveAppender.java b/zerodep-cdi/src/test/java/com/lightbend/microprofile/reactive/streams/zerodep/cdi/ZeroDepArchiveAppender.java new file mode 100644 index 0000000..9b76e91 --- /dev/null +++ b/zerodep-cdi/src/test/java/com/lightbend/microprofile/reactive/streams/zerodep/cdi/ZeroDepArchiveAppender.java @@ -0,0 +1,29 @@ +/* + * Copyright (C) 2018 Lightbend Inc. + */ +package com.lightbend.microprofile.reactive.streams.zerodep.cdi; + +import com.lightbend.microprofile.reactive.streams.zerodep.ReactiveStreamsEngineImpl; +import org.eclipse.microprofile.reactive.streams.ReactiveStreams; +import org.jboss.arquillian.container.test.spi.client.deployment.AuxiliaryArchiveAppender; +import org.jboss.shrinkwrap.api.Archive; +import org.jboss.shrinkwrap.api.ShrinkWrap; +import org.jboss.shrinkwrap.api.spec.JavaArchive; +import org.reactivestreams.Publisher; + +/** + * Adds the Reactive Streams operators API as well as the zerodep implementation to Thorntail. + */ +public class ZeroDepArchiveAppender implements AuxiliaryArchiveAppender { + @Override + public Archive createAuxiliaryArchive() { + return ShrinkWrap.create(JavaArchive.class) + .addPackages(true, ReactiveStreams.class.getPackage()) + .addPackages(true, Publisher.class.getPackage()) + // For some reason, Thorntail automatically creates a bean for this, and I don't know why. + // When I tried to add another application scoped bean that @Produces this, it failed with + // an ambiguous dependency because both that, and the one that Thorntail automatically + // created, existed. I have no idea how that's happening. + .addPackages(true, ReactiveStreamsEngineImpl.class.getPackage()); + } +} diff --git a/zerodep-cdi/src/test/java/com/lightbend/microprofile/reactive/streams/zerodep/cdi/ZeroDepExtension.java b/zerodep-cdi/src/test/java/com/lightbend/microprofile/reactive/streams/zerodep/cdi/ZeroDepExtension.java new file mode 100644 index 0000000..4d44abe --- /dev/null +++ b/zerodep-cdi/src/test/java/com/lightbend/microprofile/reactive/streams/zerodep/cdi/ZeroDepExtension.java @@ -0,0 +1,17 @@ +/* + * Copyright (C) 2018 Lightbend Inc. + */ +package com.lightbend.microprofile.reactive.streams.zerodep.cdi; + +import org.jboss.arquillian.container.test.spi.client.deployment.AuxiliaryArchiveAppender; +import org.jboss.arquillian.core.spi.LoadableExtension; + +/** + * Arquillian extension to register the archive appender. + */ +public class ZeroDepExtension implements LoadableExtension { + @Override + public void register(ExtensionBuilder extensionBuilder) { + extensionBuilder.service(AuxiliaryArchiveAppender.class, ZeroDepArchiveAppender.class); + } +} diff --git a/zerodep-cdi/src/test/resources/META-INF/services/org.jboss.arquillian.core.spi.LoadableExtension b/zerodep-cdi/src/test/resources/META-INF/services/org.jboss.arquillian.core.spi.LoadableExtension new file mode 100644 index 0000000..5f347a4 --- /dev/null +++ b/zerodep-cdi/src/test/resources/META-INF/services/org.jboss.arquillian.core.spi.LoadableExtension @@ -0,0 +1,4 @@ +# +# Copyright (C) 2018 Lightbend Inc. +# +com.lightbend.microprofile.reactive.streams.zerodep.cdi.ZeroDepExtension \ No newline at end of file From 7e35a4d334300cf2d2b2cf471c254600f5a27346 Mon Sep 17 00:00:00 2001 From: James Roper Date: Thu, 9 Aug 2018 10:22:30 +1000 Subject: [PATCH 2/2] Add jcommander to arquillian deployment --- bin/buildDeps.sh | 4 ++-- .../reactive/streams/zerodep/cdi/ZeroDepArchiveAppender.java | 5 ++++- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/bin/buildDeps.sh b/bin/buildDeps.sh index dee10af..6ec959c 100755 --- a/bin/buildDeps.sh +++ b/bin/buildDeps.sh @@ -1,9 +1,9 @@ #!/bin/bash # This should be set to the commit hash that is being tracked. Needed even if TRACKING_PR is set. -TRACKING_COMMIT="4a1ee95" +TRACKING_COMMIT="6387275" # To track a particular pull request, put it's number here, otherwise comment it out. -TRACKING_PR="84" +# TRACKING_PR="84" set -e diff --git a/zerodep-cdi/src/test/java/com/lightbend/microprofile/reactive/streams/zerodep/cdi/ZeroDepArchiveAppender.java b/zerodep-cdi/src/test/java/com/lightbend/microprofile/reactive/streams/zerodep/cdi/ZeroDepArchiveAppender.java index 9b76e91..7e78027 100644 --- a/zerodep-cdi/src/test/java/com/lightbend/microprofile/reactive/streams/zerodep/cdi/ZeroDepArchiveAppender.java +++ b/zerodep-cdi/src/test/java/com/lightbend/microprofile/reactive/streams/zerodep/cdi/ZeroDepArchiveAppender.java @@ -3,6 +3,7 @@ */ package com.lightbend.microprofile.reactive.streams.zerodep.cdi; +import com.beust.jcommander.JCommander; import com.lightbend.microprofile.reactive.streams.zerodep.ReactiveStreamsEngineImpl; import org.eclipse.microprofile.reactive.streams.ReactiveStreams; import org.jboss.arquillian.container.test.spi.client.deployment.AuxiliaryArchiveAppender; @@ -24,6 +25,8 @@ public Archive createAuxiliaryArchive() { // When I tried to add another application scoped bean that @Produces this, it failed with // an ambiguous dependency because both that, and the one that Thorntail automatically // created, existed. I have no idea how that's happening. - .addPackages(true, ReactiveStreamsEngineImpl.class.getPackage()); + .addPackages(true, ReactiveStreamsEngineImpl.class.getPackage()) + // Because TestNG depends on it but this old verison of Arquillian doesn't bring it in. + .addPackages(true, JCommander.class.getPackage()); } }