Я пытаюсь выяснить покрытие кода для приложения. Я написал для них черный функциональный тест. Я читал этот учебник.
мои шаги:
Я скачал их исходный код с - https://github.com/llatinov/sample-dropwizard-rest-stub и добавлены следующие изменения в pom:
<build>
<plugins>
<plugin>
<groupId>org.jacoco</groupId>
<artifactId>jacoco-maven-plugin</artifactId>
<version>0.7.4.201502262128</version>
<executions>
<execution>
<id>jacoco-instrument</id>
<phase>test</phase>
<goals>
<goal>instrument</goal>
</goals>
<configuration>
<skip>${jacoco.skip.instrument}</skip>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
Ран с чистым пакетом mvn
Использовал инструмент декомпилятора Java для проверки занятия инструментированы или нет. Я мог видеть инструментированные коды:
import org.jacoco.agent.rt.internal_43f5073.Offline;
@Path("/books")
public class BookService {
public BookService() {
arrayOfBoolean[0] = true;
}
@GET
@Timed
@Produces({"application/json"})
public List<Book> getBooks() {
boolean[] arrayOfBoolean = $jacocoInit();
arrayOfBoolean[1] = true;
return BookDB.getAll();
}
}
Я запустил приложение с помощью следующей команды:
java -Djacoco-agent.output=tcpserver -Djacoco-agent.destfile=/home/sb/Desktop/jacoco.exec -Djacoco-agent.includes=* -Djacoco-agent.dumponexit=false -Djacoco-agent.address=* -Djacoco-agent.port=6300 -cp /home/sb/Downloads/jacoco/lib/jacocoagent.jar:target/sample-dropwizard-rest-stub-1.0-SNAPSHOT.jar com.automationrhapsody.reststub.RestStubApp server config.yml
Я создал Maven Test Project и выполнил тест для приложения. Но все равно файл jacoco.exe c не создан. Мой pom. xml для тестового проекта:
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>TestJACOCOApp</groupId>
<artifactId>TestJACOCOApp</artifactId>
<version>0.0.1-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>io.rest-assured</groupId>
<artifactId>rest-assured</artifactId>
<version>3.0.2</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.testng/testng -->
<dependency>
<groupId>org.testng</groupId>
<artifactId>testng</artifactId>
<version>7.1.0</version>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>3.0.0-M4</version>
<configuration>
<systemPropertyVariables>
<jacoco-agent.destfile>target/jacoco.exec</jacoco-agent.destfile>
</systemPropertyVariables>
</configuration>
</plugin>
<plugin>
<groupId>org.jacoco</groupId>
<artifactId>jacoco-maven-plugin</artifactId>
<version>0.8.5</version>
<executions>
<execution>
<id>default-prepare-agent</id>
<goals>
<goal>prepare-agent</goal>
</goals>
</execution>
<execution>
<id>default-report</id>
<goals>
<goal>report</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>
Обратите внимание, что файл jacoco.exe c не создается в указанном месте даже после завершения работы JVM , У меня есть разрешение файла фляги jacocoagent jar 755.