diff --git a/integration-tests/injectmock/src/main/java/io/quarkus/it/mockbean/CapitalizerService.java b/integration-tests/injectmock/src/main/java/io/quarkus/it/mockbean/CapitalizerService.java index 850e7f7df1722..70fbe8edf55b9 100644 --- a/integration-tests/injectmock/src/main/java/io/quarkus/it/mockbean/CapitalizerService.java +++ b/integration-tests/injectmock/src/main/java/io/quarkus/it/mockbean/CapitalizerService.java @@ -1,8 +1,8 @@ package io.quarkus.it.mockbean; -import javax.enterprise.context.ApplicationScoped; +import javax.inject.Singleton; -@ApplicationScoped +@Singleton public class CapitalizerService { public String capitalize(String input) { diff --git a/integration-tests/injectmock/src/test/java/io/quarkus/it/mockbean/WithSpiesTest.java b/integration-tests/injectmock/src/test/java/io/quarkus/it/mockbean/WithSpiesTest.java index 0fde29c32f6dd..135213378ab4f 100644 --- a/integration-tests/injectmock/src/test/java/io/quarkus/it/mockbean/WithSpiesTest.java +++ b/integration-tests/injectmock/src/test/java/io/quarkus/it/mockbean/WithSpiesTest.java @@ -15,7 +15,7 @@ @QuarkusTest class WithSpiesTest { - @InjectSpy + @InjectSpy(convertScopes = true) CapitalizerService capitalizerService; @InjectSpy diff --git a/test-framework/junit5-mockito/src/main/java/io/quarkus/test/junit/mockito/InjectMock.java b/test-framework/junit5-mockito/src/main/java/io/quarkus/test/junit/mockito/InjectMock.java index 82aad0650c8bc..d5d71839015cd 100644 --- a/test-framework/junit5-mockito/src/main/java/io/quarkus/test/junit/mockito/InjectMock.java +++ b/test-framework/junit5-mockito/src/main/java/io/quarkus/test/junit/mockito/InjectMock.java @@ -15,7 +15,7 @@ /** * If true, then Quarkus will change the scope of the target {@code Singleton} bean to {@code ApplicationScoped} - * to make the mockable. + * to make it mockable. * This is an advanced setting and should only be used if you don't rely on the differences between {@code Singleton} * and {@code ApplicationScoped} beans (for example it is invalid to read fields of {@code ApplicationScoped} beans * as a proxy stands in place of the actual implementation) diff --git a/test-framework/junit5-mockito/src/main/java/io/quarkus/test/junit/mockito/InjectSpy.java b/test-framework/junit5-mockito/src/main/java/io/quarkus/test/junit/mockito/InjectSpy.java index 0bad87a8a2666..1f1f9a6673688 100644 --- a/test-framework/junit5-mockito/src/main/java/io/quarkus/test/junit/mockito/InjectSpy.java +++ b/test-framework/junit5-mockito/src/main/java/io/quarkus/test/junit/mockito/InjectSpy.java @@ -23,4 +23,12 @@ * @see org.mockito.AdditionalAnswers#delegatesTo(Object) */ boolean delegate() default false; + + /** + * If true, then Quarkus will change the scope of the target {@code Singleton} bean to {@code ApplicationScoped}. + * This is an advanced setting and should only be used if you don't rely on the differences between {@code Singleton} + * and {@code ApplicationScoped} beans (for example it is invalid to read fields of {@code ApplicationScoped} beans + * as a proxy stands in place of the actual implementation) + */ + boolean convertScopes() default false; } diff --git a/test-framework/junit5-mockito/src/main/java/io/quarkus/test/junit/mockito/internal/SingletonToApplicationScopedTestBuildChainCustomizerProducer.java b/test-framework/junit5-mockito/src/main/java/io/quarkus/test/junit/mockito/internal/SingletonToApplicationScopedTestBuildChainCustomizerProducer.java index a6f35bf089977..9906fc368dec3 100644 --- a/test-framework/junit5-mockito/src/main/java/io/quarkus/test/junit/mockito/internal/SingletonToApplicationScopedTestBuildChainCustomizerProducer.java +++ b/test-framework/junit5-mockito/src/main/java/io/quarkus/test/junit/mockito/internal/SingletonToApplicationScopedTestBuildChainCustomizerProducer.java @@ -1,5 +1,6 @@ package io.quarkus.test.junit.mockito.internal; +import java.util.ArrayList; import java.util.HashSet; import java.util.List; import java.util.Set; @@ -25,14 +26,16 @@ import io.quarkus.builder.BuildStep; import io.quarkus.test.junit.buildchain.TestBuildChainCustomizerProducer; import io.quarkus.test.junit.mockito.InjectMock; +import io.quarkus.test.junit.mockito.InjectSpy; public class SingletonToApplicationScopedTestBuildChainCustomizerProducer implements TestBuildChainCustomizerProducer { private static final DotName INJECT_MOCK = DotName.createSimple(InjectMock.class.getName()); + private static final DotName INJECT_SPY = DotName.createSimple(InjectSpy.class.getName()); @Override public Consumer produce(Index testClassesIndex) { - return new Consumer() { + return new Consumer<>() { @Override public void accept(BuildChainBuilder buildChainBuilder) { @@ -40,7 +43,9 @@ public void accept(BuildChainBuilder buildChainBuilder) { @Override public void execute(BuildContext context) { Set mockTypes = new HashSet<>(); - List instances = testClassesIndex.getAnnotations(INJECT_MOCK); + List instances = new ArrayList<>(); + instances.addAll(testClassesIndex.getAnnotations(INJECT_MOCK)); + instances.addAll(testClassesIndex.getAnnotations(INJECT_SPY)); for (AnnotationInstance instance : instances) { if (instance.target().kind() != AnnotationTarget.Kind.FIELD) { continue;