We are expanding our test coverage and attempting to implement the support for code coverage as documented in the readme - https://github.com/karatelabs/karate/tree/master/karate-demo#code-coverage-using-jacoco
When trying to execute the sample test for Jacoco, in karate-demo, as stated - mvn clean test -Pcoverage
the following errors are returned. Is this project up to date or is it outdated?
Errors:
karate-demo % mvn clean test -Pcoverage
[INFO] Scanning for projects...
[INFO]
[INFO] ---------------------< io.karatelabs:karate-demo >----------------------
[INFO] Building karate-demo 1.5.0
[INFO] from pom.xml
[INFO] --------------------------------[ jar ]---------------------------------
[WARNING] 1 problem was encountered while building the effective model for org.javassist:javassist:jar:3.20.0-GA during dependency collection step for project (use -X to see details)
[INFO]
[INFO] --- clean:3.2.0:clean (default-clean) @ karate-demo ---
[INFO] Deleting /Users/xxx/karate/karate-demo/target
[INFO]
[INFO] --- jacoco:0.7.9:prepare-agent (default-prepare-agent) @ karate-demo ---
[INFO] argLine set to -javaagent:/Users/xxx/.m2/repository/org/jacoco/org.jacoco.agent/0.7.9/org.jacoco.agent-0.7.9-runtime.jar=destfile=/Users/xxx/karate/karate-demo/target/jacoco.exec
[INFO]
[INFO] --- resources:3.3.1:resources (default-resources) @ karate-demo ---
[INFO] Copying 6 resources from src/main/resources to target/classes
[INFO]
[INFO] --- compiler:3.13.0:compile (default-compile) @ karate-demo ---
[INFO] Recompiling the module because of changed source code.
[INFO] Compiling 33 source files with javac [debug target 17] to target/classes
[INFO] /Users/xxx/karate/karate-demo/src/main/java/com/intuit/karate/demo/controller/WebSocketHandler.java: Some input files use unchecked or unsafe operations.
[INFO] /Users/xxx/karate/karate-demo/src/main/java/com/intuit/karate/demo/controller/WebSocketHandler.java: Recompile with -Xlint:unchecked for details.
[INFO]
[INFO] --- resources:3.3.1:testResources (default-testResources) @ karate-demo ---
[INFO] Copying 151 resources from src/test/java to target/test-classes
[INFO]
[INFO] --- compiler:3.13.0:testCompile (default-testCompile) @ karate-demo ---
[INFO] Recompiling the module because of changed dependency.
[INFO] Compiling 51 source files with javac [debug target 17] to target/test-classes
[INFO] /Users/xxx/karate/karate-demo/src/test/java/demo/DemoTestSelected.java: Some input files use unchecked or unsafe operations.
[INFO] /Users/xxx/karate/karate-demo/src/test/java/demo/DemoTestSelected.java: Recompile with -Xlint:unchecked for details.
[INFO]
[INFO] --- surefire:3.2.5:test (default-test) @ karate-demo ---
[INFO] Using auto detected provider org.apache.maven.surefire.junitplatform.JUnitPlatformProvider
[INFO]
[INFO] -------------------------------------------------------
[INFO] T E S T S
[INFO] -------------------------------------------------------
Exception in thread "main" java.lang.reflect.InvocationTargetException
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.base/java.lang.reflect.Method.invoke(Method.java:569)
at java.instrument/sun.instrument.InstrumentationImpl.loadClassAndStartAgent(InstrumentationImpl.java:491)
at java.instrument/sun.instrument.InstrumentationImpl.loadClassAndCallPremain(InstrumentationImpl.java:503)
Caused by: java.lang.RuntimeException: Class java/util/UUID could not be instrumented.
at org.jacoco.agent.rt.internal_8ff85ea.core.runtime.ModifiedSystemClassRuntime.createFor(ModifiedSystemClassRuntime.java:140)
at org.jacoco.agent.rt.internal_8ff85ea.core.runtime.ModifiedSystemClassRuntime.createFor(ModifiedSystemClassRuntime.java:101)
at org.jacoco.agent.rt.internal_8ff85ea.PreMain.createRuntime(PreMain.java:55)
at org.jacoco.agent.rt.internal_8ff85ea.PreMain.premain(PreMain.java:47)
... 6 more
Caused by: java.lang.NoSuchFieldException: $jacocoAccess
at java.base/java.lang.Class.getField(Class.java:2117)
at org.jacoco.agent.rt.internal_8ff85ea.core.runtime.ModifiedSystemClassRuntime.createFor(ModifiedSystemClassRuntime.java:138)
... 9 more
*** java.lang.instrument ASSERTION FAILED ***: "!errorOutstanding" with message Outstanding error when calling method in invokeJavaAgentMainMethod at src/java.instrument/share/native/libinstrument/JPLISAgent.c line: 619
*** java.lang.instrument ASSERTION FAILED ***: "success" with message invokeJavaAgentMainMethod failed at src/java.instrument/share/native/libinstrument/JPLISAgent.c line: 459
*** java.lang.instrument ASSERTION FAILED ***: "result" with message agent load/premain call failed at src/java.instrument/share/native/libinstrument/JPLISAgent.c line: 422
/bin/sh: line 1: 48527 Abort trap: 6 '/Library/Java/JavaVirtualMachines/zulu-17.jdk/Contents/Home/bin/java' '-Dfile.encoding=UTF-8' '-javaagent:/Users/xxx/.m2/repository/org/jacoco/org.jacoco.agent/0.7.9/org.jacoco.agent-0.7.9-runtime.jar=destfile=/Users/xxx/karate/karate-demo/target/jacoco.exec' '-jar' '/Users/xxx/karate/karate-demo/target/surefire/surefirebooter-20241217135432930_3.jar' '/Users/xxx/karate/karate-demo/target/surefire' '2024-12-17T13-54-32_873-jvmRun1' 'surefire-20241217135432930_1tmp' 'surefire_0-20241217135432930_2tmp'
[INFO]
[INFO] Results:
[INFO]
[INFO] Tests run: 0, Failures: 0, Errors: 0, Skipped: 0
[INFO]
[WARNING] Corrupted channel by directly writing to native stream in forked JVM 1. See FAQ web page and the dump file /Users/xxx/karate/karate-demo/target/surefire-reports/2024-12-17T13-54-32_873-jvmRun1.dumpstream
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 2.925 s
[INFO] Finished at: 2024-12-17T13:54:33-07:00
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-surefire-plugin:3.2.5:test (default-test) on project karate-demo:
[ERROR]
[ERROR] Please refer to /Users/xxx/karate/karate-demo/target/surefire-reports for the individual test results.
[ERROR] Please refer to dump files (if any exist) [date].dump, [date]-jvmRun[N].dump and [date].dumpstream.
[ERROR] The forked VM terminated without properly saying goodbye. VM crash or System.exit called?
[ERROR] Command was /bin/sh -c cd '/Users/xxx/karate/karate-demo' && '/Library/Java/JavaVirtualMachines/zulu-17.jdk/Contents/Home/bin/java' '-Dfile.encoding=UTF-8' '-javaagent:/Users/xxx/.m2/repository/org/jacoco/org.jacoco.agent/0.7.9/org.jacoco.agent-0.7.9-runtime.jar=destfile=/Users/xxx/karate/karate-demo/target/jacoco.exec' '-jar' '/Users/xxx/karate/karate-demo/target/surefire/surefirebooter-20241217135432930_3.jar' '/Users/xxx/karate/karate-demo/target/surefire' '2024-12-17T13-54-32_873-jvmRun1' 'surefire-20241217135432930_1tmp' 'surefire_0-20241217135432930_2tmp'
[ERROR] Error occurred in starting fork, check output in log
[ERROR] Process Exit Code: 134
[ERROR] org.apache.maven.surefire.booter.SurefireBooterForkException: The forked VM terminated without properly saying goodbye. VM crash or System.exit called?
[ERROR] Command was /bin/sh -c cd '/Users/xxx/karate/karate-demo' && '/Library/Java/JavaVirtualMachines/zulu-17.jdk/Contents/Home/bin/java' '-Dfile.encoding=UTF-8' '-javaagent:/Users/xxx/.m2/repository/org/jacoco/org.jacoco.agent/0.7.9/org.jacoco.agent-0.7.9-runtime.jar=destfile=/Users/xxx/karate/karate-demo/target/jacoco.exec' '-jar' '/Users/xxx/karate/karate-demo/target/surefire/surefirebooter-20241217135432930_3.jar' '/Users/xxx/karate/karate-demo/target/surefire' '2024-12-17T13-54-32_873-jvmRun1' 'surefire-20241217135432930_1tmp' 'surefire_0-20241217135432930_2tmp'
[ERROR] Error occurred in starting fork, check output in log
[ERROR] Process Exit Code: 134
[ERROR] at org.apache.maven.plugin.surefire.booterclient.ForkStarter.fork(ForkStarter.java:643)
[ERROR] at org.apache.maven.plugin.surefire.booterclient.ForkStarter.run(ForkStarter.java:285)
[ERROR] at org.apache.maven.plugin.surefire.booterclient.ForkStarter.run(ForkStarter.java:250)
[ERROR] at org.apache.maven.plugin.surefire.AbstractSurefireMojo.executeProvider(AbstractSurefireMojo.java:1241)
[ERROR] at org.apache.maven.plugin.surefire.AbstractSurefireMojo.executeAfterPreconditionsChecked(AbstractSurefireMojo.java:1090)
[ERROR] at org.apache.maven.plugin.surefire.AbstractSurefireMojo.execute(AbstractSurefireMojo.java:910)
[ERROR] at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:126)
[ERROR] at org.apache.maven.lifecycle.internal.MojoExecutor.doExecute2(MojoExecutor.java:328)
[ERROR] at org.apache.maven.lifecycle.internal.MojoExecutor.doExecute(MojoExecutor.java:316)
[ERROR] at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:212)
[ERROR] at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:174)
[ERROR] at org.apache.maven.lifecycle.internal.MojoExecutor.access$000(MojoExecutor.java:75)
[ERROR] at org.apache.maven.lifecycle.internal.MojoExecutor$1.run(MojoExecutor.java:162)
[ERROR] at org.apache.maven.plugin.DefaultMojosExecutionStrategy.execute(DefaultMojosExecutionStrategy.java:39)
[ERROR] at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:159)
[ERROR] at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:105)
[ERROR] at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:73)
[ERROR] at org.apache.maven.lifecycle.internal.builder.singlethreaded.SingleThreadedBuilder.build(SingleThreadedBuilder.java:53)
[ERROR] at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.java:118)
[ERROR] at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:261)
[ERROR] at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:173)
[ERROR] at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:101)
[ERROR] at org.apache.maven.cli.MavenCli.execute(MavenCli.java:906)
[ERROR] at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:283)
[ERROR] at org.apache.maven.cli.MavenCli.main(MavenCli.java:206)
[ERROR] at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
[ERROR] at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
[ERROR] at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
[ERROR] at java.base/java.lang.reflect.Method.invoke(Method.java:569)
[ERROR] at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:255)
[ERROR] at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:201)
[ERROR] at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:361)
[ERROR] at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:314)
[ERROR]
[ERROR] -> [Help 1]
[ERROR]
[ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR]
[ERROR] For more information about the errors and possible solutions, please read the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoExecutionException
Results in target/sunfire-reports folder
# Created at 2024-12-17T13:54:33.211
Corrupted channel by directly writing to native stream in forked JVM 1. Stream 'FATAL ERROR in native method: processing of -javaagent failed, processJavaStart failed'.
# Created at 2024-12-17T13:54:33.212
Corrupted channel by directly writing to native stream in forked JVM 1. Stream 'Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code)'.
# Created at 2024-12-17T13:54:33.212
Corrupted channel by directly writing to native stream in forked JVM 1. Stream 'V [libjvm.dylib+0x4dd8a4] jni_FatalError+0x10c'.
# Created at 2024-12-17T13:54:33.213
Corrupted channel by directly writing to native stream in forked JVM 1. Stream 'V [libjvm.dylib+0x649c40] JvmtiExport::post_vm_initialized()+0x284'.
# Created at 2024-12-17T13:54:33.213
Corrupted channel by directly writing to native stream in forked JVM 1. Stream 'V [libjvm.dylib+0x9b60b0] Threads::create_vm(JavaVMInitArgs*, bool*)+0x864'.
# Created at 2024-12-17T13:54:33.213
Corrupted channel by directly writing to native stream in forked JVM 1. Stream 'V [libjvm.dylib+0x4fa9e8] JNI_CreateJavaVM+0x78'.
# Created at 2024-12-17T13:54:33.214
Corrupted channel by directly writing to native stream in forked JVM 1. Stream 'C [libjli.dylib+0xac08] JavaMain+0x104'.
# Created at 2024-12-17T13:54:33.214
Corrupted channel by directly writing to native stream in forked JVM 1. Stream 'C [libjli.dylib+0xda74] ThreadJavaMain+0xc'.
# Created at 2024-12-17T13:54:33.327
Corrupted channel by directly writing to native stream in forked JVM 1. Stream 'C [libsystem_pthread.dylib+0x72e4] _pthread_start+0x88'.
According to
/bin/sh: line 1: 48527 Abort trap: 6 '/Library/Java/JavaVirtualMachines/zulu-17.jdk/Contents/Home/bin/java'
you're using Java version 17
and according to
[INFO] --- jacoco:0.7.9:prepare-agent (default-prepare-agent) @ karate-demo ---
you're using JaCoCo version 0.7.9, which is 7 years old and does not support Java 17.
Support for Java 17 was added in JaCoCo version 0.8.8, and the latest released as of today version is 0.8.12 - see https://www.jacoco.org/jacoco/trunk/doc/changes.html
After upgrade to 0.8.12 (https://github.com/karatelabs/karate/pull/2635) execution of
mvn clean test -Pcoverage
succeeds with Java 17 and even with Java 21.