Jacoco: Найти покрытие кода для теста черного ящика - PullRequest
0 голосов
/ 22 апреля 2020

Я пытаюсь выяснить покрытие кода для приложения. Я написал для них черный функциональный тест. Я читал этот учебник.

мои шаги:

  1. Я скачал их исходный код с - 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>
    
  2. Ран с чистым пакетом mvn

  3. Использовал инструмент декомпилятора 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();
      }
    }
    
  4. Я запустил приложение с помощью следующей команды:

    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
    
  5. Я создал 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.

...