Разветвленная ВМ прервалась, не попрощавшись.Виртуальный сбой или System.exit называется? - PullRequest
0 голосов
/ 28 декабря 2018

Я настроил maven-surefire-plugin и плагин jacoco для генерации отчета о покрытии кода junit.Тем не менее, я получаю 2 разные ошибки в 2 разных сценариях.Можете ли вы взглянуть на приведенные ниже ошибки и помочь мне?Любая помощь действительно ощутима.

Когда я сохраняю свой forkCount как 0 (ноль) в конфигурации maven-surefire-plugin, тогда все тесты выполняются успешно, но отчет jacoco не генерируется.Он выдает мне сообщение «Пропуск выполнения JaCoCo из-за отсутствия файла данных выполнения».

Когда я сохраняю свой forkCount равным 1 в конфигурации подключаемого модуля maven-surefire, то я получаю следующую ошибку: [ОШИБКА] Разветвленная виртуальная машинапрекратил без должного прощания.Виртуальный сбой или System.exit называется?[ОШИБКА] Произошла ошибка при запуске форка, проверьте вывод в журнале [ОШИБКА] Код выхода процесса: 1 [ОШИБКА] в org.apache.maven.plugin.surefire.booterclient.ForkStarter.fork (ForkStarter.java:671) [ОШИБКА]в org.apache.maven.plugin.surefire.booterclient.ForkStarter.fork (ForkStarter.java:533) [ОШИБКА] в org.apache.maven.plugin.surefire.booterclient.ForkStarter.run (ForkStarter.java:27)ОШИБКА] в org.apache.maven.plugin.surefire.booterclient.ForkStarter.run (ForkStarter.java:244) [ОШИБКА] в org.apache.maven.plugin.surefire.AbstractSurefireMojo.executeProvider (AbstractSurejireM:ОШИБКА] в org.apache.maven.plugin.surefire.AbstractSurefireMojo.executeAfterPreconditionsChecked (AbstractSurefireMojo.java:1022) [ОШИБКА] в org.apache.maven.plugin.surefire.AbstractSurefireMORjoj.exj.exj.exj.exj.exj.exj.exj.exj.exj.exj.exj.exj.exj.exj.exj.exj.exj.в org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo (DefaultBuildPluginManager.java:137)

При необходимости вы можете обратиться к приведенному ниже файлу pom.xml, чтобы узнатьпричина беспокойства,

http://maven.apache.org/xsd/maven-4.0.0.xsd"> 4.0.0 тестовый модуль com.testmodule 1.0.6 Тестовый модуль

<properties>
    <maven.compiler.source>10</maven.compiler.source>
    <maven.compiler.target>10</maven.compiler.target>
    <tomcat.version>8.5.4</tomcat.version>
    <maven.test.skip>false</maven.test.skip>
    <maven.build.timestamp.format>yy.MM</maven.build.timestamp.format>
    <powermock.version>2.0.0-beta.5</powermock.version>

    <!-- Sonar-JaCoCo properties -->
    <sonar.java.coveragePlugin>jacoco</sonar.java.coveragePlugin>
    <sonar.dynamicAnalysis>reuseReports</sonar.dynamicAnalysis>
    <sonar.jacoco.reportPath>target/jacoco.exec</sonar.jacoco.reportPath>
    <sonar.language>java</sonar.language>
</properties>

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.0.3.RELEASE</version>
</parent>

<dependencies>
    <!-- START Spring boot dependencies -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter</artifactId>
        <exclusions>
            <exclusion>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-logging</artifactId>
            </exclusion>
            <exclusion>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-tomcat</artifactId>
            </exclusion>
            <exclusion>
                <groupId>javax.annotation</groupId>
                <artifactId>javax.annotation-api</artifactId>
            </exclusion>
        </exclusions>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.ws</groupId>
        <artifactId>spring-xml</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-oxm</artifactId>
    </dependency>

    <dependency>
        <groupId>com.testmodule</groupId>
        <artifactId>test-module-common</artifactId>
        <version>1.0.6</version>
        <exclusions>
            <exclusion>
                <groupId>com.fasterxml.jackson.core</groupId>
                <artifactId>jackson-databind</artifactId>
            </exclusion>
            <exclusion>
                <groupId>javax.xml.ws</groupId>
                <artifactId>jaxws-api</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-core</artifactId>
        <version>2.9.6</version>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-annotations</artifactId>
        <version>2.9.6</version>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-databind</artifactId>
        <version>2.9.6</version>
    </dependency>

    <dependency>
        <groupId>org.apache.httpcomponents</groupId>
        <artifactId>httpclient</artifactId>
        <version>4.5.6</version>
    </dependency>
    <dependency>
        <groupId>org.apache.httpcomponents</groupId>
        <artifactId>httpcore</artifactId>
    </dependency>

    <dependency>
        <groupId>org.json</groupId>
        <artifactId>json</artifactId>
        <version>20180813</version>
    </dependency>

    <!-- START JUnit Test dependencies -->
    <dependency>
        <groupId>com.google.code.tempus-fugit</groupId>
        <artifactId>tempus-fugit</artifactId>
        <version>1.1</version>
        <scope>test</scope>
    </dependency>

    <dependency>
        <groupId>org.powermock</groupId>
        <artifactId>powermock-core</artifactId>
        <version>${powermock.version}</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>org.powermock</groupId>
        <artifactId>powermock-module-junit4</artifactId>
        <version>${powermock.version}</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>org.powermock</groupId>
        <artifactId>powermock-api-mockito2</artifactId>
        <version>${powermock.version}</version>
        <scope>test</scope>
    </dependency>
    <!-- END JUnit Test dependencies -->

    <dependency>
        <groupId>com.fasterxml.jackson.datatype</groupId>
        <artifactId>jackson-datatype-jdk8</artifactId>
    </dependency>
    <dependency>
        <groupId>com.google.code.gson</groupId>
        <artifactId>gson</artifactId>
    </dependency>

    <dependency>
        <groupId>javax.xml.soap</groupId>
        <artifactId>javax.xml.soap-api</artifactId>
        <version>1.4.0</version>
    </dependency>
</dependencies>

<build>
    <plugins>
        <plugin>
            <artifactId>maven-surefire-plugin</artifactId>
            <version>2.22.0</version>
            <configuration>
                <forkCount>1</forkCount>
                <reuseForks>true</reuseForks>
                <argLine>${jacoco.agent.argLine}</argLine>
            </configuration>        
            <dependencies>
                <dependency>
                    <groupId>org.ow2.asm</groupId>
                    <artifactId>asm</artifactId>
                    <version>6.2</version>
                </dependency>
            </dependencies>
        </plugin>
        <plugin>
            <groupId>org.jacoco</groupId>
            <artifactId>jacoco-maven-plugin</artifactId>
            <version>0.8.1</version>
            <configuration>
                 <append>true</append>
            </configuration>
            <executions>
                <execution>
                    <id>jacoco-initialize</id>
                    <phase>initialize</phase>
                    <goals>
                        <goal>prepare-agent</goal>
                    </goals>
                      <configuration>
                          <propertyName>jacoco.agent.argLine</propertyName>
                          <destFile>target/jacoco.exec</destFile>                                 
                      </configuration>
                    </execution>
                    <execution>
                      <id>jacoco-report</id>
                      <phase>verify</phase>
                      <goals>
                        <goal>report</goal>
                      </goals>                        
                 </execution>           
            </executions>
        </plugin>   
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <configuration>
              <mainClass>com.testmodule.module</mainClass>
              <finalName>test-module</finalName>
              <outputDirectory>${project.build.directory}/lib</outputDirectory>
             </configuration>
            <executions>
                <execution>
                    <goals>
                        <goal>repackage</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>
        <!-- Added for java 10 -->
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.7.0</version>
            <dependencies>
                <dependency>
                    <groupId>org.ow2.asm</groupId>
                    <artifactId>asm</artifactId>
                    <version>6.2</version>
                </dependency>
            </dependencies>
        </plugin>

        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-assembly-plugin</artifactId>
            <configuration>
                <finalName>test-module</finalName>
                <appendAssemblyId>false</appendAssemblyId>
                <descriptors>
                    <descriptor>resources/distribution.xml</descriptor>
                </descriptors>
            </configuration>
            <executions>
                <execution>
                    <id>make-assembly</id> <!-- this is used for inheritance merges -->
                    <phase>package</phase> <!-- append to the packaging phase. -->
                    <goals>
                        <goal>single</goal> <!-- goals == mojos -->
                    </goals>
                </execution>
            </executions>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-antrun-plugin</artifactId>
            <version>1.1</version>
            <executions>
                <execution>
                    <phase>validate</phase>
                    <goals>
                        <goal>run</goal>
                    </goals>
                    <configuration>
                    <tasks>
                      <echo file="version.txt">${maven.build.timestamp}.${BUILD_NUMBER}</echo>
                    </tasks>
                </configuration>
                </execution>
            </executions>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-jar-plugin</artifactId>
            <configuration>
                <archive>
                    <manifestEntries>
                        <Implementation-Version>${maven.build.timestamp}.${BUILD_NUMBER}</Implementation-Version>
                    </manifestEntries>
                </archive>
            </configuration>  
        </plugin>
    </plugins>
</build>

1 Ответ

0 голосов
/ 08 марта 2019

Вы должны обновить версию jacoco, так как вы используете java10.Вы можете использовать JaCoCo версии 0.8.3. Кажется, проблема решена.

...