5

JUnit-Tests を Surefire と Cobertura で使用して Maven でプロジェクトをビルドし、テスト カバレッジを取得すると、通常はすべて正常に機能しました。しかし、最近、一部のテストでスローされる可能性がある (および例外となる) 例外を追加したとき、maven は常に次のように言いました。

[ERROR] Failed to execute goal org.apache.maven.plugins:maven-surefire-plugin:2.18.1:test (default-test) on project backend-server: Execution default-test of goal org.apache.maven.plugins:maven-surefire-plugin:2.18.1:test failed: There was an error in the forked process
[ERROR] java.lang.NoClassDefFoundError: de/unileipzig/irpsim/backend/simulation/TimerowTooShortException
[ERROR] at java.lang.Class.getDeclaredMethods0(Native Method)
[ERROR] at java.lang.Class.privateGetDeclaredMethods(Class.java:2701)
[ERROR] at java.lang.Class.privateGetMethodRecursive(Class.java:3048)
[ERROR] at java.lang.Class.getMethod0(Class.java:3018)
[ERROR] at java.lang.Class.getMethod(Class.java:1784)
[ERROR] at org.apache.maven.surefire.util.ReflectionUtils.tryGetMethod(ReflectionUtils.java:57)
[ERROR] at org.apache.maven.surefire.common.junit3.JUnit3TestChecker.isSuiteOnly(JUnit3TestChecker.java:64)
[ERROR] at org.apache.maven.surefire.common.junit3.JUnit3TestChecker.isValidJUnit3Test(JUnit3TestChecker.java:59)
[ERROR] at org.apache.maven.surefire.common.junit3.JUnit3TestChecker.accept(JUnit3TestChecker.java:54)
[ERROR] at org.apache.maven.surefire.common.junit4.JUnit4TestChecker.accept(JUnit4TestChecker.java:52)
[ERROR] at org.apache.maven.surefire.util.DefaultScanResult.applyFilter(DefaultScanResult.java:97)
[ERROR] at org.apache.maven.surefire.junit4.JUnit4Provider.scanClassPath(JUnit4Provider.java:222)
[ERROR] at org.apache.maven.surefire.junit4.JUnit4Provider.invoke(JUnit4Provider.java:107)
[ERROR] at org.apache.maven.surefire.booter.ForkedBooter.invokeProviderInSameClassLoader(ForkedBooter.java:203)
[ERROR] at org.apache.maven.surefire.booter.ForkedBooter.runSuitesInProcess(ForkedBooter.java:155)
[ERROR] at org.apache.maven.surefire.booter.ForkedBooter.main(ForkedBooter.java:103)
[ERROR] Caused by: java.lang.ClassNotFoundException: de.unileipzig.irpsim.backend.simulation.TimerowTooShortException
[ERROR] at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
[ERROR] at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
[ERROR] at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
[ERROR] at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
[ERROR] ... 16 more
[ERROR] -> [Help 1]

-X またはこのようなものを使用して実行しても、残念ながら役に立ちませんでした。また、Maven の実行時にhttp://maven.apache.org/surefire/maven-surefire-plugin/examples/class-loading.htmlまたは断続的な NoClassDefFoundError を確認することもできませんでした。ジェンキンスの /surefire ビルドは、この問題に関する有用なヒントを提供しませんでした。

私のsurefire-pluginは次のように定義されています:

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-surefire-plugin</artifactId>
    <version>2.18.1</version>
    <configuration>
        <forkedProcessTimeoutInSeconds>900</forkedProcessTimeoutInSeconds>
        <argLine>-Djava.library.path=${nativelib.directory}</argLine>
        <excludes>
            <exclude>**/DatabaseTest.java</exclude>
        </excludes>
    </configuration>
</plugin>

フォークを非アクティブ化すると、すべてが正常に機能し始めますが、ネイティブ ライブラリが含まれていないため、これはオプションではありません。また、 を使用するすべてのテストを除外するとTimerowTooShortException、すべて正常に動作します。

何度か試してみたところ、 でテストを実行した場合でも cobertura が-Dcobertura.skip=true問題の原因であることがわかりました。Cobertura はプラグインで次のように定義されています。

<plugin>
    <groupId>org.codehaus.mojo</groupId>
    <artifactId>cobertura-maven-plugin</artifactId>
    <version>2.6</version>
    <configuration>
        <formats>
            <format>xml</format>
        </formats>
    </configuration>
    <dependencies>
        <dependency>
            <groupId>org.ow2.asm</groupId>
            <artifactId>asm</artifactId>
            <version>5.0.3</version>
        </dependency>
    </dependencies>
    <executions>
        <execution>
            <phase>package</phase>
            <goals>
                <goal>cobertura</goal>
            </goals>
        </execution>
    </executions>
</plugin>

残念ながら、確実な例外と一緒にsurefireとcoberturaを使用した場合、この特定の問題に関する情報は見つかりませんでした。coberturaを使用するとなぜこれが起こるのか誰かが知っていますか? そして、これに対する回避策はありますか?

4

3 に答える 3

3

マルチモジュール プロジェクトで同様のエラーが発生しました。を追加するたびに-Dcobertura.skip=true、NoClassDefFound および ClassNotFound 例外が発生しました。

残念ながら、私はその理由を理解できませんでした。私の推測では、すべての cobertura-goal がパラメーターを取るわけではありません。

ただし、プロファイルを使用して問題を「解決」しました。つまり、cobertura プラグインをデフォルトのビルド構成から cobertura プロファイルに移動しました。

<profiles>
   <profile>
       <id>cobertura-run</id>
       <properties>
            <maven.test.skip>false</maven.test.skip>
       </properties>
       <build>
           <plugins>
                <plugin>
                    <groupId>org.codehaus.mojo</groupId>
                    <artifactId>cobertura-maven-plugin</artifactId>
                    <version>2.7</version>
                    <configuration>
                        <formats>
                            <format>xml</format>
                        </formats>
                    </configuration>
                    <executions>
                        <execution>
                            <phase>package</phase>
                            <goals>
                                <goal>cobertura</goal>
                            </goals>
                        </execution>
                    </executions>
                </plugin>
           </plugins>
       </build>
   </profile>
</profiles>

cobertura を実行したいときはいつでも-P cobertura-run、コマンドラインで cobertura を無効または有効にする代わりに使用します。

于 2015-10-13T07:25:33.970 に答える
0

同じエラーがありましたが、追加しました

`<testFailureIgnore>false</testFailureIgnore>`

問題を解決します。したがって、次の構成で問題が解決するはずです。

        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-surefire-plugin</artifactId>
            <version>2.18.1</version>
            <configuration>
                <skipTests>${skipTests}</skipTests>
                <testFailureIgnore>false</testFailureIgnore>
                <includes>
                 <include>**/*.java</include>
                </includes>
            </configuration>
        </plugin>
于 2015-06-11T14:00:16.690 に答える