Аннотация @SpringBootTest — это аннотация, введенная SpringBoot начиная с версии 1.4.0 для тестирования.
В этой статье в основном объясняется, как использовать SpringBootTest.
SpringBootTest по умолчанию интегрирует следующие функции:
JUnit 5: JavaМодульное тестированиерамка
Spring Test & Spring Boot Test: Spring Инструменты и поддержка тестирования Boot
AssertJ: утверждение потоковой передачи
Hamcrest: Аффирмация Хэмкреста
Mockito: Java Макет рамки
JSONassert: Утверждение JSON
JsonPath: XPath for JSON
В целом типы тестов, поддерживаемые Spring Boot Test, можно условно разделить на следующие три категории:
Модульное Обучение: Как правило, ориентированное на метод, при написании общего бизнес-кода стоимость теста относительно высока. В задействованной аннотации есть @Test.
Тест нарезки: обычно ориентирован на граничные функции, которые трудно протестировать, между Модульным тестированиеи Функциональное между ними. Есть аннотации @WebMvcTest и др. Главное — отделить уровень Сервиса для Контроллера, который включает в себя компоненты, от которых зависит уровень управления Moc.
Функциональное Обновление: Обычно ориентировано на полную бизнес-функцию, вы также можете использовать возможность макетирования в аспекте тестирования, что рекомендуется. Задействована аннотация @SpringBootTest и так далее.
————————————————
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.6.RELEASE</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
@SpringBootApplication
public class StartUpApplication {
public static void main(String[] args) {
SpringApplication.run(StartUpApplication.class, args);
}
}
@RestController
public class HelloController {
@RequestMapping("/")
public String index() {
return "Hello Spring Boot,Index!";
}
@RequestMapping(value = "/test", method = RequestMethod.GET)
public String test() {
return "Spring Boot Test Demo!";
}
}
Атрибут groups указывает класс запуска. SpringBootTest.WebEnvironment.RANDOM_PORT часто используется вместе с @LocalServerPort в тестовом классе при внедрении свойств. Номер порта будет сгенерирован случайным образом.
@RunWith(SpringRunner.class)
@SpringBootTest(classes = StartUpApplication.class, webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
public class HelloControllerTest {
/**
* @LocalServerPort предоставил @Value("${local.server.port}") вместо
*/
@LocalServerPort
private int port;
private URL base;
@Autowired
private TestRestTemplate restTemplate;
@Before
public void setUp() throws Exception {
String url = String.format("http://localhost:%d/", port);
System.out.println(String.format("port is : [%d]", port));
this.base = new URL(url);
}
/**
* Отправьте запрос на адрес «/test» и распечатайте возвращаемый результат.
* @throws Exception
*/
@Test
public void test1() throws Exception {
ResponseEntity<String> response = this.restTemplate.getForEntity(
this.base.toString() + "/test", String.class, "");
System.out.println(String.format("Результат теста: %s", response.getBody()));
}