JDK-13不支持surefire插件的类文件主版本

7

我正在尝试使用Java-13和Maven创建Java模块项目。我的pom.xml文件如下:

<?xml version="1.0" encoding="UTF-8"?>
<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>wtf.g4s8</groupId>
  <artifactId>oot</artifactId>
  <version>1.0-SNAPSHOT</version>
  <packaging>jar</packaging>
  <properties>
    <junit-platform.version>5.3.1</junit-platform.version>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <jdk.version>13</jdk.version>
  </properties>
  <dependencies>
    <dependency>
      <groupId>org.hamcrest</groupId>
      <artifactId>hamcrest</artifactId>
      <version>2.1</version>
    </dependency>
    <dependency>
      <groupId>org.junit.jupiter</groupId>
      <artifactId>junit-jupiter-api</artifactId>
      <version>${junit-platform.version}</version>
      <scope>test</scope>
    </dependency>
    <dependency>
      <groupId>org.junit.jupiter</groupId>
      <artifactId>junit-jupiter-engine</artifactId>
      <version>${junit-platform.version}</version>
      <scope>test</scope>
    </dependency>
  </dependencies>
  <build>
    <plugins>
      <plugin>
        <artifactId>maven-compiler-plugin</artifactId>
        <version>3.8.1</version>
        <configuration>
          <target>${jdk.version}</target>
          <source>${jdk.version}</source>
          <release>${jdk.version}</release>
          <useIncrementalCompilation>false</useIncrementalCompilation>
        </configuration>
      </plugin>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-surefire-plugin</artifactId>
        <version>3.0.0-M3</version>
      </plugin>
    </plugins>
  </build>
</project>

版本:

$ mvn help:system | grep -i jdk
sun.boot.library.path=/opt/jdk-13.0.1/lib
jdk.debug=release
java.home=/opt/jdk-13.0.1
java.runtime.name=OpenJDK Runtime Environment
java.vm.name=OpenJDK 64-Bit Server VM
JDK_HOME=/opt/jdk-13.0.1
JAVA_HOME=/opt/jdk-13.0.1
JAVAC=/opt/jdk-13.0.1/bin/javac

$ mvn -version
Apache Maven 3.6.1 (d66c9c0b3152b2e69ee9bac180bb8fcc8e6af555; 2019-04-04T22:00:29+03:00)
Maven home: /usr/share/maven-bin-3.6
Java version: 13.0.1, vendor: Oracle Corporation, runtime: /opt/jdk-13.0.1
Default locale: en_US, platform encoding: UTF-8
OS name: "linux", version: "5.3.2-gentoo", arch: "amd64", family: "unix"

如果我使用mvn clean package -DskipTests命令,项目可以正常工作:

BUILD SUCCESS

但是,当我运行mvn clean test时,出现错误(包含-e的完整日志在此处:https://gist.github.com/g4s8/a08e88143b7b5ceec0e534a34b7ab734):

[ERROR] Failed to execute goal org.apache.maven.plugins:maven-surefire-plugin:3.0.0-M3:test (default-test) on project oot: Execution default-test of goal org.apache.maven.plugins:maven-surefire-plugin:3.0.0-M3:test failed: Unsupported class file major version 57 -> [Help 1]

看起来surefire插件无法与JDK 13一起使用,但是插件文档中写到:“要求:Maven 3.x和JDK 1.7或更高版本”(JDK 13比JDK 1.7更高)。所以,我在我的pom.xml文件中配置了错误吗?还是说surefire插件不能与JDK 13一起使用?这是一个可以重现问题的示例项目:https://github.com/g4s8/so58710751

2
你的系统似乎存在问题,因为你显示了OpenJDK的运行时,而mvn --version的输出显示了Oracle Java...除此之外,Maven/Maven Surefire已在JDK 8、11、12、13、14上进行了测试。https://builds.apache.org/view/M-R/view/Maven/job/maven-box/job/maven-surefire/job/master/ - khmarbaise
1
如果您增加更多的日志输出,并且仅保留最后几行,那将非常有帮助...还有几行代码...同时,一个pom文件也会很有帮助...最好是拥有完整的日志输出...此外,我怀疑您正在使用基于JUnit Jupiter的测试,根据给定的JUnit版本5.X...因此,我认为您有比所示更多的依赖项。 - khmarbaise
1
我发现没有执行任何测试...我已经获取了这篇文章的pom并创建了一个https://gist.github.com/khmarbaise/f896a5dc65d70969081580329d6a6481。它在JDK 13上运行良好...我添加了一个要执行的单个测试用例....有一件事是:这个pom文件是包含所有依赖项的完整pom文件吗? - khmarbaise
1
所以这完全不同,因为你正在使用模块系统...第一个提示是永远不要创建名为directories的模块,保持通常的结构src/main/java/<package>,并将module-info.java放入src/main/java。除此之外,我正在调查这个问题... - khmarbaise
1
我已经向您的代码库创建了一个拉取请求,修复了这些问题。 - khmarbaise
显示剩余3条评论
2个回答

10

目前 Maven Surefire 插件的问题是它使用了一个较旧的 org.ow2.asm:asm 版本,导致出现问题。我在 maven-surefire-plugin 上创建了一个 问题。可以通过简单地向 maven-surefire-plugin 添加新版本的 org.ow2.asm:asm 来暂时解决此问题:

  <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-surefire-plugin</artifactId>
    <version>3.0.0-M3</version>
    <dependencies>
      <dependency>
        <groupId>org.ow2.asm</groupId>
        <artifactId>asm</artifactId>
        <version>7.2</version>
      </dependency>
    </dependencies>
  </plugin>
</plugins>

更新 不要在3.0.0-M4及以上版本中使用此修复方法。


谢谢!它修复了这个问题。 - Kirill
1
有一个 VOTE 正在运行,针对 maven-surefire-plugin:3.0.0-M4 版本进行修复。 - khmarbaise
1
请使用 Surefire 和 Failsafe 插件的版本 3.0.0-M4。不要使用插件下面的 ASM 依赖项!现在它已经没用了。 - tibor17

5

请勿使用任何ASM库的黑客方法。这种问题已经通过使用Java API进行原则性修复,我们不需要使用ASM。这是在版本3.0.0-M4中使用Surefire和Failsafe进行修复的。它已经在Maven Central中可用,尽情享用!


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接