Аннотация JUnit @TestMethodOrder не работает

У меня проблема со следующим интеграционным тестом

import org.junit.jupiter.api.Order;
import org.junit.jupiter.api.TestMethodOrder;
import org.junit.jupiter.api.MethodOrderer.OrderAnnotation;

@SpringBootTest
@ActiveProfiles("test")
@TestMethodOrder(OrderAnnotation.class)
public class FooServiceIT {
    @Test
    @Order(1)
    void testUploadSuccess() { ... }
    @Test
    @Order(2)
    void testDownloadSuccess() { ... }
    @Test
    @Order(3)
    void testDeleteSuccess() { ... }
}

Я ожидаю, что при запуске теста порядок выполнения будет 1, 2, 3, но по какой-то причине фактический порядок выполнения равен 2, 3, 1.

Tbh, я понятия не имею, почему аннотация не работает. Я использую Spring Boot 2.1.3 с JUnit 5.4.

теоретически вы должны писать свои тесты так, чтобы они могли выполняться в любом порядке... зачем вам их упорядочивать?

Ruth 01.03.2019 16:31

Вы неправильно настроили. Попробуйте поставить @TestMethodOrder(MethodOrderer.OrderAnnotation.class)https://junit.org/junit5/docs/current/api/org/junit/jupiter/‌​api/TestMethodOrder.‌​html

Valijon 01.03.2019 16:33

@Valijon Я обновил импорт, я уже правильно использовал класс OrderAnnotation. @RuthiRuth методы манипулируют файлами на удаленном сервере, очевидно, там метод загрузки/удаления завершится ошибкой, если я сначала не загружу файл на сервер (я также хотел бы, чтобы метод был отдельным, т.е. не вызывая метод загрузки в тесте загрузки).

toucheqt 01.03.2019 16:37

Не могли бы вы поделиться остальным импортом, в частности для аннотации @Test?

Sam Brannen 01.03.2019 18:29

Одной из причин заказа тестов является разрешение случаев, когда выполнение отдельных тестов в наборе завершается успешно, но выполнение нескольких тестов завершается сбоем, скажем, во втором из-за того, что тестовая система не была разорвана после первого теста, как ожидалось. Это может быть настоящей проблемой для отладки, особенно с последними версиями тестовых плагинов Maven, где конфигурации форка иногда недетерминировано взаимодействуют с junit 5.

maw 19.11.2019 22:46

Используйте эту аннотацию @TestMethodOrder(MethodOrderer.OrderAnnotation.class)

Anupam Haldkar 05.08.2020 18:40
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
В компьютерном программировании биты играют важнейшую роль в представлении и манипулировании данными на двоичном уровне. Побитовые операции...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Полный курс Java для разработчиков веб-сайтов и приложений
Полный курс Java для разработчиков веб-сайтов и приложений
Получите сертификат Java Web и Application Developer, используя наш курс.
18
6
22 970
7
Перейти к ответу Данный вопрос помечен как решенный

Ответы 7

Из документов https://junit.org/junit5/docs/current/api/org/junit/jupiter/api/TestMethodOrder.html

 @TestMethodOrder(MethodOrderer.OrderAnnotation.class)
 class OrderedTests {

     @Test
     @Order(1)
     void nullValues() {}

     @Test
     @Order(2)
     void emptyValues() {}

     @Test
     @Order(3)
     void validValues() {}
 }

Как ваш ответ решает проблему?

Diego Marin Santos 07.11.2019 17:06
Ответ принят как подходящий

Вам нужно правильно настроить вашу IDE.

Требования

<dependency>
    <groupId>org.junit.jupiter</groupId>
    <artifactId>junit-jupiter-engine</artifactId>
    <version>5.4.0</version>
</dependency>

Не используйте Юнит 5, который предлагает ваша IDE. Если вы добавите его как библиотеку, вы получите:

No tests found for with test runner 'JUnit 5' 
==================== and this exception ===================
TestEngine with ID 'junit-vintage' failed to discover tests
java.lang.SecurityException: class "org.junit.jupiter.api.TestMethodOrder"'s signer information does not match signer information of other classes in the same package

Поэтому просто включите только упомянутую зависимость, и ваш код будет работать так, как вы ожидаете:

import org.junit.jupiter.api.MethodOrderer;
import org.junit.jupiter.api.Order;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder;

@TestMethodOrder(MethodOrderer.OrderAnnotation.class)
public class FooServiceIT {

    @Test
    @Order(1)
    public void testUploadSuccess() {
        System.out.println("1");
    }

    @Test
    @Order(2)
    public void testDownloadSuccess() {
        System.out.println("2");
    }

    @Test
    @Order(3)
    public void testDeleteSuccess() {
        System.out.println("3");
    }
}

Результат JUnit:

1
2
3

Спасибо! Это была не настоящая проблема, но ваш ответ указал мне правильное направление. Проблема заключалась в том, что я использовал junit-jupiter ArtifactId в качестве зависимости агрегатора, которая по какой-то причине не содержала junit-jupiter-engine в версии 5.4.0, но в версии 5.3.2. После того, как я использовал зависимости в правильных версиях, тесты вообще не запускались, но добавление средства запуска платформы, как было предложено в stackoverflow.com/a/54652059/3750108, решило проблему. Теперь тесты работают, и работают в правильном порядке.

toucheqt 04.03.2019 09:00

Вы только что спасли меня от дополнительного наклона из-за неправильной версии зависимости. Ваше здоровье!

Kata 31.05.2019 13:39

У меня такая же проблема. Только что заменил версию junit-jupiter-engine на 5.4.0 и по-прежнему выполняется в обратном порядке. Не могли бы вы оставить отзыв? Большое спасибо.

Deminem 21.03.2020 19:37

Просто хочу добавить, что эта тема github.com/junit-team/junit5/issues/1776 также упоминала то же самое. Тем не менее не повезло - любая помощь будет оценена по достоинству. Спасибо.

Deminem 21.03.2020 19:40

@Deminem убедитесь, что junit-jupiter-engine берет правильную версию, а не из IDE. Если вы можете поделиться своим кодом, я могу посмотреть

Valijon 21.03.2020 19:48

@Valijon - я только что подтвердил, что использую junit-jupiter-engine правильную версию. Пожалуйста, посмотрите сами. com.personalitytest.demo:personalitytest:jar:1.0-SNAPSHOT \- org.junit.jupiter:junit-jupiter-engine:jar:5.4.0:test

Deminem 22.03.2020 04:43

@Valijon - проверьте код, который я разместил в отдельной ветке. Спасибо.

Deminem 22.03.2020 04:46
junit-jupiter-engine поставляется с зависимостью spring-boot-starter-test. нет необходимости добавлять его дополнительно. пожалуйста, проверьте, аннотировали ли вы класс с помощью @TestMethodOrder(MethodOrderer.OrderAnnotation.class), прежде чем добавлять другую зависимость
Fzum 21.06.2021 15:34

вам нужно правильно настроить ваш pom.xml. Смотрите мой:

<properties>
    <!-- Dependency versions -->
    <junit.jupiter.version>5.6.0</junit.jupiter.version>
    <maven-surefire-plugin.version>3.0.0-M4</maven-surefire-plugin.version>

    <!-- Java 10 -->
    <maven.compiler.source>1.10</maven.compiler.source>
    <maven.compiler.target>1.10</maven.compiler.target>

    <!-- Encoding -->
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
</properties>

<!-- Jupiter API for writing tests -->
<dependencies>
    <dependency>
        <groupId>org.junit.jupiter</groupId>
        <artifactId>junit-jupiter-engine</artifactId>
        <version>${junit.jupiter.version}</version>
        <scope>test</scope>
    </dependency>
</dependencies>

<!-- Maven Surefire plugin to run tests -->
<build>
    <plugins>
        <!-- plugin to run test cases from maven -->
        <plugin>
            <artifactId>maven-surefire-plugin</artifactId>
            <version>${maven-surefire-plugin.version}</version>
        </plugin>
        <!-- Maven plugin to use perticular java version to compile code -->
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.8.1</version>
            <configuration>
                <source>${maven.compiler.source}</source>
                <target>${maven.compiler.target}</target>
            </configuration>
        </plugin>
    </plugins>
</build>

Теперь ваши аннотации Junit 5 должны работать правильно.

Это решение только что попробовал и не работает

Arefe 24.01.2022 05:39

После применения всех настроек на основе предыдущего рекомендованного решения. У меня все еще такое же обратное или случайное выполнение @приказ.

Pom.xml

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

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-test</artifactId>
    <scope>test</scope>
</dependency>

<dependency>
    <groupId>org.junit.jupiter</groupId>
    <artifactId>junit-jupiter-engine</artifactId>
    <version>5.4.0</version>
    <scope>test</scope>
</dependency>

Дерево зависимостей Maven:

mvn dependency:tree -Dverbose -Dincludes=org.junit.jupiter:junit-jupiter-engine

[INFO] com.personalitytest.demo:personalitytest:jar:1.0-SNAPSHOT
[INFO] \- org.junit.jupiter:junit-jupiter-engine:jar:5.4.0:test

Юнит-тест:

@SpringBootTest
@ActiveProfiles("test")
@TestMethodOrder(MethodOrderer.OrderAnnotation.class)
public class JUnitOrderTest {

    private static final Logger log = LoggerFactory.getLogger(JUnitOrderTest.class);

    @Test
    @Order(1)
    public void testUploadSuccess() {
        log.info("Junit - Order 1");
    }

    @Test
    @Order(2)
    public void testDownloadSuccess() {
        log.info("Junit - Order 2");
    }

    @Test
    @Order(3)
    public void testDeleteSuccess() {
        log.info("Junit - Order 3");
    }
}

Вывод:

Running com.personalitytest.demo.security.JUnitOrderTest
08:48:35.470 [main] INFO com.personalitytest.demo.security.JUnitOrderTest - Junit - Order 2
08:48:35.480 [main] INFO com.personalitytest.demo.security.JUnitOrderTest - Junit - Order 3
08:48:35.481 [main] INFO com.personalitytest.demo.security.JUnitOrderTest - Junit - Order 1

@Valijon - Пожалуйста, взгляните на код. Любая помощь будет оценена по достоинству - Спасибо.

Deminem 22.03.2020 04:36

@Valijon - Для меня это было странно, прежде чем я заметил, что вы проводите тесты против Junit5. @MethodExecutionOrder работает только с Junit5, а любая версия SpringBoot ниже 2.0 использует Junit4 для целей тестирования. Поэтому я исключил Junit4 из настроек Spring и установил Jupiter (Junit5) вместе с MockitoJupiter (Mockito5), и теперь все работает, как и ожидалось. Спасибо за вашу помощь очень ценится!

Deminem 22.03.2020 20:04

Просто хочу добавить для других, аннотация @Test работает по-разному как для Junit4, так и для Junit5. Когда у вас настроена весенняя загрузка ниже 2.0, она использует Junit4, и вы не осознаете этого при выполнении тестов через mvn clean test.

Deminem 24.03.2020 09:52

Например, с помощью Spring Boot вы можете использовать @FixMethodOrder(MethodSorters.JVM) вместо @TestMethodOrder(MethodOrderer.OrderAnnotation.class). Все тесты выполняются в том порядке, в котором они появляются.

@FixMethodOrder(MethodSorters.JVM)
public class MyTest{

   @Test
   public void zzzz(){}

   @Test
   public void cccc(){}

   @Test
   public void aaaa(){}

   @Test
   public void bbbb(){}
}

Выполнение заказа это:

zzzz()
cccc()
aaaa()
bbbb()

Не правда. Прочтите документацию. «Обратите внимание, что порядок JVM может меняться от запуска к запуску»

Ran 30.10.2020 09:34

Я столкнулся с той же проблемой. Но, я нашел проблему, где именно на моем случае. Неправильно импортировать класс "Заказ".

Неправильный

import org.springframework.core.annotation.Order;

Правильный

*import org.junit.jupiter.api.Order;*

Кроме того, проверьте правильность импорта следующих пяти классов.

import org.junit.jupiter.api.Assertions;

import org.junit.jupiter.api.MethodOrderer.OrderAnnotation;

import org.junit.jupiter.api.Order;

import org.junit.jupiter.api.Test;

import org.junit.jupiter.api.TestMethodOrder;

Если у вас есть/была JUnit 4, проверьте импорт на аннотацию @Test: import org.junit.Test;

Для импорта JUnit 5 должно быть: import org.junit.jupiter.api.Test;

Это была моя проблема для этого вопроса

Другие вопросы по теме