Попытка получить покрытие через jacoco с использованием автономного инструментария (невозможно использовать инструментарий «на лету»: из-за тестовых случаев powermock) для проекта maven. Добавлен jacocoagent.jar в путь к классам в плагине surefire, как показано ниже. Переименовал «org.jacoco.agent-0.7.7.201606060606-runtime.jar» (из локального репозитория maven) в «jacocoagent.jar» и сохранил его в той же папке, где находится этот pom.xml. Я нажимаю ниже исключение даже после добавления его в путь к классам.
фрагмент pom.xml (surefire — конфигурация плагина)
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<configuration>
<forkmode>once</forkmode>
<additionalClasspathElements>
<additionalClasspathElement>jacocoagent.jar</additionalClasspathElement>
</additionalClasspathElements>
</configuration>
</plugin>
Исключение на консоли:
#############
Number of foreign imports: 1
import: Entry[import from realm ClassRealm[maven.api, parent: null]]
-----------------------------------------------------
at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:166)
... 21 more
Caused by: java.lang.NoClassDefFoundError: org/jacoco/agent/rt/internal_6da5971/Offline
at com.cisco.ise.ups.modelframework.hibernate.OracleNamingStrategy.$jacocoInit(OracleNamingStrategy.java)
at com.cisco.ise.ups.modelframework.hibernate.OracleNamingStrategy.<clinit>(OracleNamingStrategy.java)
at sun.misc.Unsafe.ensureClassInitialized(Native Method)
at sun.reflect.UnsafeFieldAccessorFactory.newFieldAccessor(UnsafeFieldAccessorFactory.java:43)
at sun.reflect.ReflectionFactory.newFieldAccessor(ReflectionFactory.java:142)
at java.lang.reflect.Field.acquireFieldAccessor(Field.java:1082)
at java.lang.reflect.Field.getFieldAccessor(Field.java:1063)
at java.lang.reflect.Field.get(Field.java:387)
at com.cisco.ise.ups.build.WorkflowRunnerMojo.namingStrategyInstance(WorkflowRunnerMojo.java:335)
at com.cisco.ise.ups.build.WorkflowRunnerMojo.setupWorkflowEnvironment(WorkflowRunnerMojo.java:514)
at com.cisco.ise.ups.build.WorkflowRunnerMojo.execute(WorkflowRunnerMojo.java:816)
at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:134)
... 21 more
Caused by: java.lang.ClassNotFoundException: org.jacoco.agent.rt.internal_6da5971.Offline
at org.codehaus.plexus.classworlds.strategy.SelfFirstStrategy.loadClass(SelfFirstStrategy.java:50)
at org.codehaus.plexus.classworlds.realm.ClassRealm.unsynchronizedLoadClass(ClassRealm.java:271)
at org.codehaus.plexus.classworlds.realm.ClassRealm.loadClass(ClassRealm.java:247)
at org.codehaus.plexus.classworlds.realm.ClassRealm.loadClass(ClassRealm.java:239)
... 33 more
[ERROR]
###############
Выполненные действия:
- "сборка mvn" .
- "mvn org.jacoco:jacoco-maven-plugin:instrument"
- «mvn test» — на этом шаге возникло исключение.
Пожалуйста, дайте мне знать, как избавиться от этого исключения? Было ли это правильным местом для добавления пути к классам ?? (в плагине surefire) ИЛИ это должно быть указано где-то??
Спасибо.
<dependencies>
pom со значением scope=test. - person Little Santi   schedule 16.10.2016dependencies
и узелplugins/pugin/dependencies
. - person Little Santi   schedule 18.10.2016