У меня проблема со следующим интеграционным тестом
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.
Вы неправильно настроили. Попробуйте поставить @TestMethodOrder(MethodOrderer.OrderAnnotation.class)https://junit.org/junit5/docs/current/api/org/junit/jupiter/api/TestMethodOrder.html
@Valijon Я обновил импорт, я уже правильно использовал класс OrderAnnotation. @RuthiRuth методы манипулируют файлами на удаленном сервере, очевидно, там метод загрузки/удаления завершится ошибкой, если я сначала не загружу файл на сервер (я также хотел бы, чтобы метод был отдельным, т.е. не вызывая метод загрузки в тесте загрузки).
Не могли бы вы поделиться остальным импортом, в частности для аннотации @Test?
Одной из причин заказа тестов является разрешение случаев, когда выполнение отдельных тестов в наборе завершается успешно, но выполнение нескольких тестов завершается сбоем, скажем, во втором из-за того, что тестовая система не была разорвана после первого теста, как ожидалось. Это может быть настоящей проблемой для отладки, особенно с последними версиями тестовых плагинов Maven, где конфигурации форка иногда недетерминировано взаимодействуют с junit 5.
Используйте эту аннотацию @TestMethodOrder(MethodOrderer.OrderAnnotation.class)




Из документов 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() {}
}
Как ваш ответ решает проблему?
Вам нужно правильно настроить вашу 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, решило проблему. Теперь тесты работают, и работают в правильном порядке.
Вы только что спасли меня от дополнительного наклона из-за неправильной версии зависимости. Ваше здоровье!
У меня такая же проблема. Только что заменил версию junit-jupiter-engine на 5.4.0 и по-прежнему выполняется в обратном порядке. Не могли бы вы оставить отзыв? Большое спасибо.
Просто хочу добавить, что эта тема github.com/junit-team/junit5/issues/1776 также упоминала то же самое. Тем не менее не повезло - любая помощь будет оценена по достоинству. Спасибо.
@Deminem убедитесь, что junit-jupiter-engine берет правильную версию, а не из IDE. Если вы можете поделиться своим кодом, я могу посмотреть
@Valijon - я только что подтвердил, что использую junit-jupiter-engine правильную версию. Пожалуйста, посмотрите сами. com.personalitytest.demo:personalitytest:jar:1.0-SNAPSHOT \- org.junit.jupiter:junit-jupiter-engine:jar:5.4.0:test
@Valijon - проверьте код, который я разместил в отдельной ветке. Спасибо.
junit-jupiter-engine поставляется с зависимостью spring-boot-starter-test. нет необходимости добавлять его дополнительно. пожалуйста, проверьте, аннотировали ли вы класс с помощью @TestMethodOrder(MethodOrderer.OrderAnnotation.class), прежде чем добавлять другую зависимость
вам нужно правильно настроить ваш 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 должны работать правильно.
Это решение только что попробовал и не работает
После применения всех настроек на основе предыдущего рекомендованного решения. У меня все еще такое же обратное или случайное выполнение @приказ.
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 - Пожалуйста, взгляните на код. Любая помощь будет оценена по достоинству - Спасибо.
@Valijon - Для меня это было странно, прежде чем я заметил, что вы проводите тесты против Junit5. @MethodExecutionOrder работает только с Junit5, а любая версия SpringBoot ниже 2.0 использует Junit4 для целей тестирования. Поэтому я исключил Junit4 из настроек Spring и установил Jupiter (Junit5) вместе с MockitoJupiter (Mockito5), и теперь все работает, как и ожидалось. Спасибо за вашу помощь очень ценится!
Просто хочу добавить для других, аннотация @Test работает по-разному как для Junit4, так и для Junit5. Когда у вас настроена весенняя загрузка ниже 2.0, она использует Junit4, и вы не осознаете этого при выполнении тестов через mvn clean test.
Например, с помощью 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 может меняться от запуска к запуску»
Я столкнулся с той же проблемой. Но, я нашел проблему, где именно на моем случае. Неправильно импортировать класс "Заказ".
Неправильный
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;
Это была моя проблема для этого вопроса
теоретически вы должны писать свои тесты так, чтобы они могли выполняться в любом порядке... зачем вам их упорядочивать?