使用@SpringBootTest注解进行单元测试

网友投稿 460 2022-11-21


使用@SpringBootTest注解进行单元测试

概述

@SpringBootTest注解是SpringBoot自1.4.0版本开始引入的一个用于测试的注解。基本用法如下:

1. 添加Maven依赖

UTF-8

org.springframework.boot

spring-boot-starter-parent

1.5.6.RELEASE

org.springframework.boot

spring-boot-starter-web

org.springframework.boot

<artifactId>spring-boot-starter-test

org.springframework.boot

spring-boot-maven-plugin

2. 编写启动入口类

@SpringBootApplication

public class StartUpApplication {

public static void main(String[] args) {

SpringApplication.run(StartUpApplication.class, args);

}

}

3. 编写Controller类

@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!";

}

}

4. 编写测试类

@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 response = this.restTemplate.getForEntity(

this.base.toString() + "/test", String.class, "");

System.out.println(String.format("测试结果为:%s", response.getBody()));

}

其中,classes属性指定启动类,SpringBootTest.WebEnvironment.RANDOM_PORT经常和测试类中@LocalServerPort一起在注入属性时使用。会随机生成一个端口号。

总结

我们发现,随着Spring boot 版本的提升,单元测试变得更简单了。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java如何基于DOM解析xml文件
下一篇:SparkSQL读取hive数据本地idea运行的方法详解
相关文章

 发表评论

暂时没有评论,来抢沙发吧~