We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Describe the bug Mockito is currently supported only for mocking interfaces. This is a fairly big caveat, sufficient I feel for it not to be included in https://www.graalvm.org/native-image/libraries-and-frameworks/ without a disclaimer.
To Reproduce Steps to reproduce the behavior:
Small diff from master to make it mock a class rather than an instance.
[dahoppe@dahoppelnx graalvm-reachability-metadata]$ git diff HEAD^ HEAD diff --git a/tests/src/org.mockito/mockito-core/4.8.1/src/test/java/org_mockito/mockito_core/MyService.java b/tests/src/org.mockito/mockito-core/4.8.1/src/test/java/org_mockito/mockito_core/MyService.java index 3ff1323..588e2f7 100644 --- a/tests/src/org.mockito/mockito-core/4.8.1/src/test/java/org_mockito/mockito_core/MyService.java +++ b/tests/src/org.mockito/mockito-core/4.8.1/src/test/java/org_mockito/mockito_core/MyService.java @@ -6,6 +6,8 @@ */ package org_mockito.mockito_core; -public interface MyService { - String getGreeting(); +public class MyService { + String getGreeting() { + return "Hello, world!"; + } } diff --git a/tests/src/org.mockito/mockito-core/4.8.1/src/test/resources/mockito-extensions/org.mockito.plugins.MockMaker b/tests/src/org.mockito/mockito-core/4.8.1/src/test/resources/mockito-extensions/org.mockito.plugins.MockMaker deleted file mode 100644 index 5494acd..0000000 --- a/tests/src/org.mockito/mockito-core/4.8.1/src/test/resources/mockito-extensions/org.mockito.plugins.MockMaker +++ /dev/null @@ -1 +0,0 @@ -org.mockito.internal.creation.proxy.ProxyMockMaker
Run tests:
./gradlew test -Pcoordinates=org.mockito:mockito-core:4.8.1
Expected behavior Test should still pass.
Logs Build fails like so:
``` [dahoppe@dahoppelnx graalvm-reachability-metadata]$ ./gradlew test -Pcoordinates=org.mockito:mockito-core:4.8.1 > Configure project : GraalVM Reachability Metadata TCK --------------------------------- > Task :test-org.mockito-mockito-core-4.8.1 ==================== Testing library: org.mockito:mockito-core:4.8.1 Command: `/home/dahoppe/Repos/graalvm-reachability-metadata/gradlew nativeTest` Executing test... ------- Command: [/home/dahoppe/Repos/graalvm-reachability-metadata/gradlew, nativeTest] Starting a Gradle Daemon, 1 busy and 1 incompatible and 6 stopped Daemons could not be reused, use --status for details > Task :tck-build-logic:extractPluginRequests UP-TO-DATE > Task :tck-build-logic:generatePluginAdapters UP-TO-DATE > Task :tck-build-logic:compileJava UP-TO-DATE > Task :tck-build-logic:compileGroovy UP-TO-DATE > Task :tck-build-logic:compileGroovyPlugins UP-TO-DATE > Task :tck-build-logic:pluginDescriptors UP-TO-DATE > Task :tck-build-logic:processResources UP-TO-DATE > Task :tck-build-logic:classes UP-TO-DATE > Task :tck-build-logic:jar UP-TO-DATE > Task :compileJava NO-SOURCE > Task :processResources NO-SOURCE > Task :classes UP-TO-DATE > Task :compileTestJava UP-TO-DATE > Task :jar UP-TO-DATE > Task :processTestResources UP-TO-DATE > Task :testClasses UP-TO-DATE > Task :test UP-TO-DATE > Task :generateTestResourcesConfigFile UP-TO-DATE > Task :nativeTestCompile [native-image-plugin] Args are: [-cp, /home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/libs/org.mockito.mockito-core_tests.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.graalvm.buildtools/junit-platform-native/0.9.28/8080b84eee8ed37d8a937d8a0f22184071b7867a/junit-platform-native-0.9.28.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.jupiter/junit-jupiter/5.10.0/8fea1d9c58b2156f1b998f2f18da04bc9e087f74/junit-jupiter-5.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.vintage/junit-vintage-engine/5.10.0/af4e0a3cb6901aa53d6401003fc10638014b39b1/junit-vintage-engine-5.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.platform/junit-platform-console/1.10.0/9901db09e60bf678e4a22fd4be564f10aa7c585/junit-platform-console-1.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.platform/junit-platform-reporting/1.10.0/d0bf1dc2f224e41439c65af66cd75dc13dec670e/junit-platform-reporting-1.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.platform/junit-platform-launcher/1.10.0/89a1922534ed102be1fb2a8c0b2c6151297a12bf/junit-platform-launcher-1.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.jupiter/junit-jupiter-params/5.10.0/9041c7365495a897a64782ea5a6fdb99dab1814e/junit-jupiter-params-5.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.jupiter/junit-jupiter-engine/5.10.0/90587932d718fc51a48112d33045a18476c542ad/junit-jupiter-engine-5.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.jupiter/junit-jupiter-api/5.10.0/2fe4ba3d31d5067878e468c96aa039005a9134d3/junit-jupiter-api-5.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.platform/junit-platform-engine/1.10.0/276c4edcf64fabb5a139fa7b4f99330d7a93b804/junit-platform-engine-1.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.platform/junit-platform-commons/1.10.0/d533ff2c286eaf963566f92baf5f8a06628d2609/junit-platform-commons-1.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.mockito/mockito-core/4.8.1/d8eb9dec8747d08645347bb8c69088ac83197975/mockito-core-4.8.1.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.assertj/assertj-core/3.22.0/c300c0c6a24559f35fa0bd3a5472dc1edcd0111e/assertj-core-3.22.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/net.bytebuddy/byte-buddy/1.12.16/7817a8128b38ff8cb8570c8f3c85c1a41002a09d/byte-buddy-1.12.16.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/net.bytebuddy/byte-buddy-agent/1.12.16/c2d5dd150c17028c494e7f02a17f4a995dcb4e9f/byte-buddy-agent-1.12.16.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.objenesis/objenesis/3.2/7fadf57620c8b8abdf7519533e5527367cb51f09/objenesis-3.2.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/junit/junit/4.13.2/8ac9e16d933b6fb43bc7f576336b8f4d7eb5ba12/junit-4.13.2.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.opentest4j/opentest4j/1.3.0/152ea56b3a72f655d4fd677fc0ef2596c3dd5e6e/opentest4j-1.3.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.hamcrest/hamcrest-core/1.3/42a25dc3219429f0e5d060061f71acb49bf010a0/hamcrest-core-1.3.jar:/home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/classes/java/test:/home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/resources/test:/home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/test-results/test/testlist, --no-fallback, --verbose, -Ob, -o, /home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/native/nativeTestCompile/org.mockito.mockito-core_tests-tests, -H:ConfigurationFileDirectories=/home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/native/generated/generateTestResourcesConfigFile,/home/dahoppe/Repos/graalvm-reachability-metadata/metadata/org.mockito/mockito-core/4.8.1, --features=org.graalvm.junit.platform.JUnitPlatformFeature, -H:+StrictConfiguration, org.graalvm.junit.platform.NativeImageJUnitLauncher] [native-image-plugin] GraalVM Toolchain detection is disabled [native-image-plugin] GraalVM location read from environment variable: JAVA_HOME [native-image-plugin] Native Image executable path: /home/dahoppe/javas/graalvm-ce-java17-22.3.2/lib/svm/bin/native-image Apply file:///home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/resources/test/META-INF/native-image/test/proxy-config.json Apply jar:file:///home/dahoppe/javas/graalvm-ce-java17-22.3.2/lib/svm/library-support.jar!/META-INF/native-image/com.oracle.svm/thirdparty/native-image.properties Apply jar:file:///home/dahoppe/javas/graalvm-ce-java17-22.3.2/lib/svm/library-support.jar!/META-INF/native-image/com.oracle.svm/polyglot/native-image.properties Executing [ /home/dahoppe/javas/graalvm-ce-java17-22.3.2/bin/java \ -XX:+UseParallelGC \ -XX:+UnlockExperimentalVMOptions \ -XX:+EnableJVMCI \ -Dtruffle.TrustAllTruffleRuntimeProviders=true \ -Dtruffle.TruffleRuntime=com.oracle.truffle.api.impl.DefaultTruffleRuntime \ -Dgraalvm.ForcePolyglotInvalid=true \ -Dgraalvm.locatorDisabled=true \ -Dsubstratevm.IgnoreGraalVersionCheck=true \ --add-exports=java.base/com.sun.crypto.provider=org.graalvm.nativeimage.builder \ --add-exports=java.base/jdk.internal.access.foreign=org.graalvm.nativeimage.builder \ --add-exports=java.base/jdk.internal.event=org.graalvm.nativeimage.builder \ --add-exports=java.base/jdk.internal.loader=org.graalvm.nativeimage.builder,org.graalvm.truffle \ --add-exports=java.base/jdk.internal.logger=org.graalvm.nativeimage.builder \ --add-exports=java.base/jdk.internal.misc=org.graalvm.nativeimage.builder,org.graalvm.nativeimage.objectfile,org.graalvm.nativeimage.pointsto \ --add-exports=java.base/jdk.internal.module=jdk.internal.vm.compiler,org.graalvm.nativeimage.base,org.graalvm.nativeimage.builder \ --add-exports=java.base/jdk.internal.org.objectweb.asm=org.graalvm.nativeimage.builder \ --add-exports=java.base/jdk.internal.perf=org.graalvm.nativeimage.builder \ --add-exports=java.base/jdk.internal.platform=org.graalvm.nativeimage.builder \ --add-exports=java.base/jdk.internal.ref=org.graalvm.nativeimage.builder,org.graalvm.nativeimage.objectfile \ --add-exports=java.base/jdk.internal.reflect=org.graalvm.nativeimage.builder \ --add-exports=java.base/jdk.internal.util=org.graalvm.nativeimage.builder \ --add-exports=java.base/jdk.internal.vm.annotation=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.invoke.util=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.net=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.nio.ch=org.graalvm.nativeimage.builder,org.graalvm.nativeimage.objectfile \ --add-exports=java.base/sun.reflect.annotation=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.reflect.generics.factory=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.reflect.generics.reflectiveObjects=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.reflect.generics.repository=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.reflect.generics.scope=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.reflect.generics.tree=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.security.jca=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.security.provider=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.security.ssl=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.security.util=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.security.x509=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.text.spi=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.util.calendar=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.util.cldr=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.util.locale.provider=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.util.locale=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.util.resources=org.graalvm.nativeimage.builder \ --add-exports=java.base/sun.util=org.graalvm.nativeimage.builder \ --add-exports=java.desktop/sun.java2d.pipe=org.graalvm.nativeimage.builder \ --add-exports=java.desktop/sun.java2d=org.graalvm.nativeimage.builder \ --add-exports=java.management/com.sun.jmx.mbeanserver=org.graalvm.nativeimage.builder \ --add-exports=java.management/sun.management=org.graalvm.nativeimage.builder,org.graalvm.nativeimage.pointsto \ --add-exports=java.xml.crypto/org.jcp.xml.dsig.internal.dom=org.graalvm.nativeimage.builder \ --add-exports=jdk.internal.vm.ci/jdk.vm.ci.aarch64=jdk.internal.vm.compiler,org.graalvm.nativeimage.builder,org.graalvm.nativeimage.objectfile \ --add-exports=jdk.internal.vm.ci/jdk.vm.ci.amd64=jdk.internal.vm.compiler,org.graalvm.nativeimage.builder,org.graalvm.nativeimage.objectfile \ --add-exports=jdk.internal.vm.ci/jdk.vm.ci.code.site=jdk.internal.vm.compiler,org.graalvm.nativeimage.builder \ --add-exports=jdk.internal.vm.ci/jdk.vm.ci.code.stack=jdk.internal.vm.compiler,org.graalvm.nativeimage.builder \ --add-exports=jdk.internal.vm.ci/jdk.vm.ci.code=jdk.internal.vm.compiler,org.graalvm.nativeimage.builder,org.graalvm.nativeimage.objectfile,org.graalvm.nativeimage.pointsto \ --add-exports=jdk.internal.vm.ci/jdk.vm.ci.common=jdk.internal.vm.compiler,org.graalvm.nativeimage.builder,org.graalvm.nativeimage.pointsto \ --add-exports=jdk.internal.vm.ci/jdk.vm.ci.hotspot.aarch64=jdk.internal.vm.compiler \ --add-exports=jdk.internal.vm.ci/jdk.vm.ci.hotspot.amd64=jdk.internal.vm.compiler \ --add-exports=jdk.internal.vm.ci/jdk.vm.ci.hotspot.riscv64=jdk.internal.vm.compiler \ --add-exports=jdk.internal.vm.ci/jdk.vm.ci.hotspot=jdk.internal.vm.compiler,org.graalvm.nativeimage.builder \ --add-exports=jdk.internal.vm.ci/jdk.vm.ci.meta=jdk.internal.vm.compiler,org.graalvm.nativeimage.builder,org.graalvm.nativeimage.objectfile,org.graalvm.nativeimage.pointsto \ --add-exports=jdk.internal.vm.ci/jdk.vm.ci.riscv64=jdk.internal.vm.compiler \ --add-exports=jdk.internal.vm.ci/jdk.vm.ci.runtime=jdk.internal.vm.compiler,org.graalvm.nativeimage.builder,org.graalvm.nativeimage.pointsto \ --add-exports=jdk.internal.vm.ci/jdk.vm.ci.services=jdk.internal.vm.compiler,org.graalvm.nativeimage.builder \ --add-exports=jdk.jfr/jdk.jfr.events=org.graalvm.nativeimage.builder \ --add-exports=jdk.jfr/jdk.jfr.internal.handlers=org.graalvm.nativeimage.builder \ --add-exports=jdk.jfr/jdk.jfr.internal.jfc=org.graalvm.nativeimage.builder \ --add-exports=jdk.jfr/jdk.jfr.internal=org.graalvm.nativeimage.builder \ --add-exports=jdk.management/com.sun.management.internal=org.graalvm.nativeimage.builder \ -XX:+UseJVMCINativeLibrary \ -Xss10m \ -Xms1g \ -Xmx12963908808 \ -Djava.awt.headless=true \ -Dorg.graalvm.version=22.3.2 \ -Dcom.oracle.graalvm.isaot=true \ -Djava.system.class.loader=com.oracle.svm.hosted.NativeImageSystemClassLoader \ -Xshare:off \ -Djdk.internal.lambda.disableEagerInitialization=true \ -Djdk.internal.lambda.eagerlyInitialize=false \ -Djava.lang.invoke.InnerClassLambdaMetafactory.initializeLambdas=false \ -Djunit.platform.listeners.uid.tracking.output.dir=/home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/test-results/test/testlist \ --add-modules=ALL-DEFAULT \ --module-path \ /home/dahoppe/javas/graalvm-ce-java17-22.3.2/lib/truffle/truffle-api.jar:/home/dahoppe/javas/graalvm-ce-java17-22.3.2/lib/svm/builder/svm.jar:/home/dahoppe/javas/graalvm-ce-java17-22.3.2/lib/svm/builder/objectfile.jar:/home/dahoppe/javas/graalvm-ce-java17-22.3.2/lib/svm/builder/pointsto.jar:/home/dahoppe/javas/graalvm-ce-java17-22.3.2/lib/svm/builder/native-image-base.jar \ --module \ org.graalvm.nativeimage.builder/com.oracle.svm.hosted.NativeImageGeneratorRunner \ -watchpid \ 952213 \ -imagecp \ /home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/libs/org.mockito.mockito-core_tests.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.graalvm.buildtools/junit-platform-native/0.9.28/8080b84eee8ed37d8a937d8a0f22184071b7867a/junit-platform-native-0.9.28.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.jupiter/junit-jupiter/5.10.0/8fea1d9c58b2156f1b998f2f18da04bc9e087f74/junit-jupiter-5.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.vintage/junit-vintage-engine/5.10.0/af4e0a3cb6901aa53d6401003fc10638014b39b1/junit-vintage-engine-5.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.platform/junit-platform-console/1.10.0/9901db09e60bf678e4a22fd4be564f10aa7c585/junit-platform-console-1.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.platform/junit-platform-reporting/1.10.0/d0bf1dc2f224e41439c65af66cd75dc13dec670e/junit-platform-reporting-1.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.platform/junit-platform-launcher/1.10.0/89a1922534ed102be1fb2a8c0b2c6151297a12bf/junit-platform-launcher-1.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.jupiter/junit-jupiter-params/5.10.0/9041c7365495a897a64782ea5a6fdb99dab1814e/junit-jupiter-params-5.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.jupiter/junit-jupiter-engine/5.10.0/90587932d718fc51a48112d33045a18476c542ad/junit-jupiter-engine-5.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.jupiter/junit-jupiter-api/5.10.0/2fe4ba3d31d5067878e468c96aa039005a9134d3/junit-jupiter-api-5.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.platform/junit-platform-engine/1.10.0/276c4edcf64fabb5a139fa7b4f99330d7a93b804/junit-platform-engine-1.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.junit.platform/junit-platform-commons/1.10.0/d533ff2c286eaf963566f92baf5f8a06628d2609/junit-platform-commons-1.10.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.mockito/mockito-core/4.8.1/d8eb9dec8747d08645347bb8c69088ac83197975/mockito-core-4.8.1.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.assertj/assertj-core/3.22.0/c300c0c6a24559f35fa0bd3a5472dc1edcd0111e/assertj-core-3.22.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/net.bytebuddy/byte-buddy/1.12.16/7817a8128b38ff8cb8570c8f3c85c1a41002a09d/byte-buddy-1.12.16.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/net.bytebuddy/byte-buddy-agent/1.12.16/c2d5dd150c17028c494e7f02a17f4a995dcb4e9f/byte-buddy-agent-1.12.16.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.objenesis/objenesis/3.2/7fadf57620c8b8abdf7519533e5527367cb51f09/objenesis-3.2.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/junit/junit/4.13.2/8ac9e16d933b6fb43bc7f576336b8f4d7eb5ba12/junit-4.13.2.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.opentest4j/opentest4j/1.3.0/152ea56b3a72f655d4fd677fc0ef2596c3dd5e6e/opentest4j-1.3.0.jar:/home/dahoppe/.gradle/caches/modules-2/files-2.1/org.hamcrest/hamcrest-core/1.3/42a25dc3219429f0e5d060061f71acb49bf010a0/hamcrest-core-1.3.jar:/home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/classes/java/test:/home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/resources/test:/home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/test-results/test/testlist \ -imagemp \ /home/dahoppe/javas/graalvm-ce-java17-22.3.2/lib/svm/library-support.jar \ -H:CLibraryPath=/home/dahoppe/javas/graalvm-ce-java17-22.3.2/lib/svm/clibraries/linux-amd64 \ -H:Path=/home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/native/nativeTestCompile \ -H:DynamicProxyConfigurationResources@file:///home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/resources/test/META-INF/native-image/test/proxy-config.json=META-INF/native-image/test/proxy-config.json \ -H:FallbackThreshold=0 \ -H:Optimize=b \ -H:Name=/home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/native/nativeTestCompile/org.mockito.mockito-core_tests-tests \ -H:ConfigurationFileDirectories=/home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/native/generated/generateTestResourcesConfigFile,/home/dahoppe/Repos/graalvm-reachability-metadata/metadata/org.mockito/mockito-core/4.8.1 \ -H:Features=org.graalvm.junit.platform.JUnitPlatformFeature \ -H:+StrictConfiguration \ '-H:Class@explicit main-class=org.graalvm.junit.platform.NativeImageJUnitLauncher' \ '-H:Features@jar:file:///home/dahoppe/javas/graalvm-ce-java17-22.3.2/lib/svm/library-support.jar!/META-INF/native-image/com.oracle.svm/thirdparty/native-image.properties=com.oracle.svm.thirdparty.gson.GsonFeature' \ '-H:Features@jar:file:///home/dahoppe/javas/graalvm-ce-java17-22.3.2/lib/svm/library-support.jar!/META-INF/native-image/com.oracle.svm/polyglot/native-image.properties=com.oracle.svm.polyglot.groovy.GroovyIndyInterfaceFeature,com.oracle.svm.polyglot.scala.ScalaFeature' ] You enabled -Ob for this image build. This will configure some optimizations to reduce image build time. This feature should only be used during development and never for deployment. ======================================================================================================================== GraalVM Native Image: Generating '/home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/native/nativeTestCompile/org.mockito.mockito-core_tests-tests' (executable)... ======================================================================================================================== Warning: Could not resolve kotlin.jvm.JvmInline for reflection configuration. Reason: java.lang.ClassNotFoundException: kotlin.jvm.JvmInline. Warning: Could not resolve org.mockito.configuration.MockitoConfiguration for reflection configuration. Reason: java.lang.ClassNotFoundException: org.mockito.configuration.MockitoConfiguration. WARNING: Cannot register dynamic proxy for interface list: org_mockito.mockito_core.MyService. Reason: Class org_mockito.mockito_core.MyService is not an interface. [1/7] Initializing... (6.0s @ 0.32GB) Version info: 'GraalVM 22.3.2 Java 17 CE' Java version info: '17.0.7+7-jvmci-22.3-b18' C compiler: gcc (redhat, x86_64, 8.5.0) Garbage collector: Serial GC 1 user-specific feature(s) - org.graalvm.junit.platform.JUnitPlatformFeature [junit-platform-native] Running in 'test listener' mode using files matching pattern [junit-platform-unique-ids*] found in folder [/home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/test-results/test/testlist] and its subfolders. [2/7] Performing analysis... [******] (32.8s @ 2.12GB) 7,410 (83.92%) of 8,830 classes reachable 10,641 (62.12%) of 17,130 fields reachable 31,959 (51.99%) of 61,476 methods reachable 195 classes, 93 fields, and 849 methods registered for reflection 59 classes, 59 fields, and 52 methods registered for JNI access 4 native libraries: dl, pthread, rt, z [3/7] Building universe... (3.6s @ 1.08GB) [4/7] Parsing methods... [**] (3.1s @ 2.95GB) [5/7] Inlining methods... [***] (2.4s @ 3.91GB) [6/7] Compiling methods... [****] (19.7s @ 3.96GB) [7/7] Creating image... (3.3s @ 1.34GB) 12.90MB (44.87%) for code area: 19,767 compilation units 15.60MB (54.25%) for image heap: 189,497 objects and 67 resources 260.20KB ( 0.88%) for other data 28.75MB in total ------------------------------------------------------------------------------------------------------------------------ Top 10 packages in code area: Top 10 object types in image heap: 908.73KB java.util 2.86MB byte[] for code metadata 622.58KB java.lang.invoke 1.75MB java.lang.String 484.25KB c.s.org.apache.xerces.internal.impl.xs.traversers 1.73MB java.lang.Class 415.51KB com.sun.crypto.provider 1.48MB byte[] for general heap data 412.63KB com.sun.org.apache.xerces.internal.impl 1.36MB byte[] for java.lang.String 407.25KB java.lang 752.11KB byte[] for embedded resources 340.85KB com.sun.org.apache.xerces.internal.impl.xs 636.80KB com.oracle.svm.core.hub.DynamicHubCompanion 308.79KB java.util.concurrent 532.88KB java.util.HashMap$Node 280.67KB org.assertj.core.internal.bytebuddy.jar.asm 513.00KB int[][] 279.12KB jdk.internal.org.objectweb.asm 343.50KB java.lang.String[] 8.40MB for 308 more packages 3.55MB for 1738 more object types ------------------------------------------------------------------------------------------------------------------------ 2.4s (3.2% of total time) in 22 GCs | Peak RSS: 5.01GB | CPU load: 5.60 ------------------------------------------------------------------------------------------------------------------------ Produced artifacts: /home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/native/nativeTestCompile/org.mockito.mockito-core_tests-tests (executable) /home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/native/nativeTestCompile/org.mockito.mockito-core_tests-tests.build_artifacts.txt (txt) ======================================================================================================================== Finished generating '/home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/native/nativeTestCompile/org.mockito.mockito-core_tests-tests' in 1m 14s. [native-image-plugin] Native Image written to: /home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/native/nativeTestCompile > Task :nativeTest FAILED JUnit Platform on Native Image - report ---------------------------------------- org_mockito.mockito_core.MockitoTest > test() FAILED Failures (1): JUnit Jupiter:MockitoTest:test() MethodSource [className = 'org_mockito.mockito_core.MockitoTest', methodName = 'test', methodParameterTypes = ''] => com.oracle.svm.core.jdk.UnsupportedFeatureError: Proxy class defined by interfaces [interface org.mockito.plugins.MockMaker] not found. Generating proxy classes at runtime is not supported. Proxy classes need to be defined at image build time by specifying the list of interfaces that they implement. To define proxy classes use -H:DynamicProxyConfigurationFiles=<comma-separated-config-files> and -H:DynamicProxyConfigurationResources=<comma-separated-config-resources> options. org.graalvm.nativeimage.builder/com.oracle.svm.core.util.VMError.unsupportedFeature(VMError.java:89) org.graalvm.nativeimage.builder/com.oracle.svm.core.reflect.proxy.DynamicProxySupport.getProxyClass(DynamicProxySupport.java:171) [email protected]/java.lang.reflect.Proxy.getProxyConstructor(Proxy.java:47) [email protected]/java.lang.reflect.Proxy.newProxyInstance(Proxy.java:1037) org.mockito.internal.configuration.plugins.PluginLoader.loadPlugin(PluginLoader.java:77) org.mockito.internal.configuration.plugins.PluginLoader.loadPlugin(PluginLoader.java:50) org.mockito.internal.configuration.plugins.PluginRegistry.<init>(PluginRegistry.java:27) org.mockito.internal.configuration.plugins.Plugins.<clinit>(Plugins.java:22) org.mockito.internal.MockitoCore.<clinit>(MockitoCore.java:73) org.mockito.Mockito.<clinit>(Mockito.java:1647) [...] Test run finished after 75 ms [ 3 containers found ] [ 0 containers skipped ] [ 3 containers started ] [ 0 containers aborted ] [ 3 containers successful ] [ 0 containers failed ] [ 1 tests found ] [ 0 tests skipped ] [ 1 tests started ] [ 0 tests aborted ] [ 0 tests successful ] [ 1 tests failed ] FAILURE: Build failed with an exception. * What went wrong: Execution failed for task ':nativeTest'. > Process 'command '/home/dahoppe/Repos/graalvm-reachability-metadata/tests/src/org.mockito/mockito-core/4.8.1/build/native/nativeTestCompile/org.mockito.mockito-core_tests-tests'' finished with non-zero exit value 1 * Try: > Run with --stacktrace option to get the stack trace. > Run with --info or --debug option to get more log output. > Run with --scan to get full insights. * Get more help at https://help.gradle.org BUILD FAILED in 1m 22s 15 actionable tasks: 2 executed, 13 up-to-date > Task :test-org.mockito-mockito-core-4.8.1 FAILED FAILURE: Build failed with an exception. * What went wrong: Execution failed for task ':test-org.mockito-mockito-core-4.8.1'. > Test for org.mockito:mockito-core:4.8.1 failed with exit code 1. * Try: > Run with --stacktrace option to get the stack trace. > Run with --info or --debug option to get more log output. > Run with --scan to get full insights. * Get more help at https://help.gradle.org BUILD FAILED in 1m 25s 9 actionable tasks: 1 executed, 8 up-to-date ```
System Info (please complete the following information):
Oracle Linux 8
OpenJDK 64-Bit Server VM GraalVM CE 22.3.2
17
org.mockito:mockito-core:4.8.1
Additional context Oracle internal slack thread: https://dyn.slack.com/archives/CJAB85R1C/p1711037981248469
The text was updated successfully, but these errors were encountered:
No branches or pull requests
Describe the bug
Mockito is currently supported only for mocking interfaces. This is a fairly big caveat, sufficient I feel for it not to be included in https://www.graalvm.org/native-image/libraries-and-frameworks/ without a disclaimer.
To Reproduce
Steps to reproduce the behavior:
Small diff from master to make it mock a class rather than an instance.
Run tests:
./gradlew test -Pcoordinates=org.mockito:mockito-core:4.8.1
Expected behavior
Test should still pass.
Logs
Build fails like so:
System Info (please complete the following information):
Oracle Linux 8
OpenJDK 64-Bit Server VM GraalVM CE 22.3.2
17
org.mockito:mockito-core:4.8.1
Additional context
Oracle internal slack thread: https://dyn.slack.com/archives/CJAB85R1C/p1711037981248469
The text was updated successfully, but these errors were encountered: