Maven Java Surefire 无法创建测试类

Sec*_*guy 5 java unit-testing maven maven-surefire-plugin

我在运行时遇到了这个问题mvn test。这是输出的一部分:

Please refer to dump files (if any exist) [date].dump, [date]-jvmRun[N].dump and [date].dumpstream.
[ERROR] There was an error in the forked process
[ERROR] Unable to create test class 'com.models.ExampleTest'
[ERROR] org.apache.maven.surefire.booter.SurefireBooterForkException: There was an error in the forked process
[ERROR] Unable to create test class 'com.ExampleTest'
[ERROR]     at org.apache.maven.plugin.surefire.booterclient.ForkStarter.fork(ForkStarter.java:657)
[ERROR]     at org.apache.maven.plugin.surefire.booterclient.ForkStarter.run(ForkStarter.java:283)
[ERROR]     at org.apache.maven.plugin.surefire.booterclient.ForkStarter.run(ForkStarter.java:246)
[ERROR]     at org.apache.maven.plugin.surefire.AbstractSurefireMojo.executeProvider(AbstractSurefireMojo.java:1161)
[ERROR]     at org.apache.maven.plugin.surefire.AbstractSurefireMojo.executeAfterPreconditionsChecked(AbstractSurefireMojo.java:1002)
Run Code Online (Sandbox Code Playgroud)

这是我的 pom.xml 的一部分:

<build>
       <plugins>    
            <plugin>
                <artifactId>maven-surefire-plugin</artifactId>
                <version>3.0.0-M3</version>
                <configuration>
                    <useSystemClassLoader>false</useSystemClassLoader>
                </configuration>
            </plugin>
        </plugins>
</build>
<dependencies>
        <!-- https://mvnrepository.com/artifact/junit/junit -->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>
</dependencies>
Run Code Online (Sandbox Code Playgroud)

我添加<useSystemClassLoader>false</useSystemClassLoader>是因为当 mvn test 命令给我时我遇到了问题Could not find or load main class org.apache.maven.surefire.booter.ForkedBooter。所以我想我的 ClassLoader 有一些东西。我使用 Ubuntu 18.04、openjdk-11 和 maven 3.6.0。但是我尝试使用 oracle-jdk-11 和 openjdk-8 运行它。更重要的是,这个问题不依赖于一个项目。我用 maven 创建了一个空项目,并在那里添加了简单的类和简单的测试——结果是一样的。

小智 1

正如日志所说:

请参阅转储文件(如果存在)[date].dump、[date]-jvmRun[N].dump 和 [date].dumpstream

您需要查看该xxx.dump文件。您应该在项目target目录中找到它。在该文件中,您将找到导致该问题的原因和堆栈跟踪

[错误]无法创建测试类“com.models.ExampleTest”

该堆栈跟踪将与您输出中的堆栈跟踪不同,并将帮助您确定错误的真正原因(在我的情况下,它是 Javassist 版本,但它可能与您的情况无关)。

根据我的理解(我对 Surefire 不了解),Surefire 充当容器并创建一个进程来运行测试。如果这个“内部”进程出现问题,它将被记录在转储文件中。但这不是 Surefire 的错(正如输出可能让我们思考的那样)。