JDK-13 Неподдерживаемая основная версия файла класса для плагина surefire

Я пытаюсь создать проект модуля Java с Java-13 и Maven. Мой 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:

СТРОИТЬ УСПЕХ

Но когда я пытаюсь протестировать проект с mvn clean test, я получаю сообщение об ошибке (полный журнал с -e находится здесь: https://gist.github.com/g4s8/a08e88143b7b5ceec0e534a34b7ab734):

[ОШИБКА] Не удалось выполнить цель org.apache.maven.plugins: maven-surefire-plugin: 3.0.0-M3: test (default-test) в проекте oot: Выполнение теста по умолчанию для цели org.apache.maven.plugins : maven-surefire-plugin: 3.0.0-M3: ошибка теста: неподдерживаемая основная версия файла класса 57 -> [Справка 1]

Кажется, плагин surefire не может работать с 13 JDK, но документы плагина говорит «Требования: Maven 3.x и JDK 1.7 или выше» (JDK 13 выше, чем JDK 1.7).

Итак, я настроил что-то неправильно в моем pom.xml или плагин surefire не работает с 13 JDK?

Пример проекта для воспроизведения: https://github.com/g4s8/so58710751


person Kirill    schedule 05.11.2019    source источник
comment
Казалось, проблема в вашей системе, потому что вы показываете время выполнения OpenJDK, тогда как вывод mvn --version показывает Oracle java ... помимо этого Maven / Maven Surefire протестирован на JDK 8,11,12,13,14 builds.apache.org / просмотр / MR / просмотр / Maven / job / maven-box / job /   -  person khmarbaise    schedule 05.11.2019
comment
Также было бы полезно, если бы вы добавили больше вывода журнала и только последние строки ... есть еще несколько строк ... и файл pom также поможет заполнить .... лучше всего будет иметь полный вывод журнала ... кроме того, я сомневаюсь, что тесты, которые вы выполняете с JUnit Jupiter, основаны на данной версии junit 5.X ... поэтому, исходя из этого, я полагаю, что у вас гораздо больше зависимостей, чем показано ..   -  person khmarbaise    schedule 05.11.2019
comment
@khmarbaise, спасибо, я добавил подробности и загрузил полный журнал сборки в gists. Я думаю, что vendor Oracle в порядке, поскольку maven указывает на правильный путь JDK /opt/jdk-13.0.1, а OpenJDK - это проект Oracle, см. openjdk.java.net < / а>   -  person Kirill    schedule 05.11.2019
comment
Я вижу, что ни один тест не выполняется ... Я взял этот пост и создал суть .github.com / khmarbaise / f896a5dc65d70969081580329d6a6481. который показывает, что он отлично работает на JDK 13 .. Я добавил один тестовый пример для выполнения .... одна вещь: это pom весь файл pom со всеми зависимостями?   -  person khmarbaise    schedule 05.11.2019
comment
@khmarbaise Я создал минимальный воспроизводимый проект для этой проблемы, см. github.com/g4s8/so58710751   -  person Kirill    schedule 05.11.2019
comment
Так что это совершенно другое дело, потому что вы используете модульную систему ... Первая подсказка: никогда не создавайте модули с именами каталогов, сохраняйте обычную структуру src/main/java/<package> и помещайте module-info.java в src/main/java Кроме того, я исследую это ...   -  person khmarbaise    schedule 06.11.2019
comment
Создал запрос на перенос в ваш репозиторий, который устранил проблемы.   -  person khmarbaise    schedule 06.11.2019
comment
Я также убрал несколько других вещей в вашем проекте… в частности, расположение module-info.java и структуру вашего проекта.   -  person khmarbaise    schedule 07.11.2019


Ответы (2)


В настоящее время проблема в плагине Maven Surefire заключается в том, что он использует более старую версию org.ow2.asm: asm, которая вызывает проблему. Я создал проблему с maven-surefire-plugin. Эту проблему можно временно обойти, просто добавив новую версию org.ow2.asm: asm в maven-surefire-plugin:

  <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 и выше.

person khmarbaise    schedule 07.11.2019
comment
Спасибо! Это устраняет проблему - person Kirill; 07.11.2019
comment
Для maven-surefire-plugin: 3.0.0-M4 запущено ГОЛОСОВАНИЕ, которое устраняет проблему .... - person khmarbaise; 15.11.2019
comment
Используйте версию 3.0.0-M4 плагина Surefire и Failsafe. НЕ используйте зависимость ASM под плагином! В наше время это бесполезно. - person tibor17; 29.03.2020

НЕ используйте какие-либо хаки с библиотекой ASM. Этот тип проблемы был решен раз и навсегда в принципе с использованием Java API, и нам не нужно использовать ASM. Это было исправление Surefire и Failsafe, внесенное в версию 3.0.0-M4. Он уже доступен в Maven Central, наслаждайтесь!

person tibor17    schedule 17.11.2019