SpringBoot集成Mock进行接口测试

一、前言


1、遇到的问题:

        为确保功能稳定在线上运行,功能上线前必须要进行覆盖性单元测试,但由于接口测试需要通过PostMan或者Swagger进行调用,才能进行集成测试。而且通过PostMan或者Swagger进行测试后,测试用例无法进行保存,进而无法确保测试用例是否全面覆盖,而且测试用例无法留存。

2、解决方案:        

        通过SpringBootTest注入Mock的方式,来进行接口调用单元测试。

二、功能代码


@RestController("/user")
public class UserController {

    @Autowired
    private UserService userService;

    @GetMapping("/list")
    public ResponseEntity<List<User>> list() {
        return new ResponseEntity(list, HttpStatus.OK);
    }

    /**
     * user中存放筛选过滤条件
     */
    @PostMapping("/list2")
    public ResponseEntity<List<User>> list(User user, 
        @RequestParam(name = "current", defaultValue = "1") Integer current,
        @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize) {
        return new ResponseEntity(list, HttpStatus.OK);
    }

    @PostMapping("/add")
    public ResponseEntity<String> add(@RequestBody User user){
        userService.add(user);
        return new ResponseEntity("成功", HttpStatus.OK);
    }
}

三、集成Mock


1、导入SpringBoot的测试依赖

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

2、创建一个测试用例

(1)@RunWith和@SpringBootTest:表示是一个可以启动容器的测试类。
(2)@WebAppConfiguration:表示测试环境使用的ApplicationContext将是WebApplicationContext类型的。
(3)@AutoConfigureMockMvc:表示是一个可以通过Mock方式进行单元测试的类。

@RunWith(SpringRunner.class)
@SpringBootTest(classes = Application.class)
@WebAppConfiguration
// @AutoConfigureMockMvc是用于自动配置MockMvc
@AutoConfigureMockMvc
public class UserController01Test {

    @Autowired
    private WebApplicationContext webApplicationContext;

    @Autowired
    private MockMvc mockMvc;

    @Before()
    public void setup () {
        mockMvc = MockMvcBuilders.webAppContextSetup(this.webApplicationContext).build();
    }

    @Test
    public void test () {
        // test方法中具体编写接口调用逻辑即可,主要是填入模拟接口入参调用。
    }

    @Test
    public void demo () {
        // 添加调用的接口路径
        MockHttpServletRequestBuilder postRequestBuilder = MockMvcRequestBuilders.post("/user/add");
        // 标识数据提交方式
        postRequestBuilder.contentType(MediaType.APPLICATION_JSON);
        // 参数
        postRequestBuilder.param("name", "张三");
        postRequestBuilder.param("age", "18");

        // mock调用
        ResultActions resultActions = mockMvc.perform(postRequestBuilder);

        // 执行一个期望 在调用成功后,执行什么
        resultActions.andExpect(MockMvcResultMatchers.status().isOk());
        // 执行一般操作,输出调用结果
        resultActions.andDo(MockMvcResultHandlers.print());
        // 获取返回结果信息
        MvcResult response = resultActions.andReturn();

        System.out.println("result:"+response.getResponse().getContentAsString());
    }

}

四、深入剖析

1、MockMvcRequestBuilders

 (1)MockHttpServletRequestBuilder支持http所有请求(get、post、head、put、delete等)

 (2)调用时需要指定请求方式(一般场景即get、post)和接口路径(如:/demo/test),然后获取到MockHttpServletRequestBuilder。

2、MockHttpServletRequestBuilder的装配过程

(1)headers()方法:添加头信息。


(2)contentType()方法:指定请求的contentType头信息。


(3)content()方法:指定请求Body体内容。(直接和String字符串的方式都是可以支持的)


(4)param()/params()方法:设置接口参数值。 

 ⚠️注意⚠️:主要讲述当前用到的核心方法,其他在这里不详细讲述。cookie和session也是可以模拟的,有需要的可以看参考中的开涛的博客文章,有详细讲解使用方法。

3、MockMvc的调用过程

(1)perform()方法:执行一个RequestBuilder请求,会自动执行SpringMVC的流程并映射到相应的控制器执行处理。


(2)andExpect()方法:添加ResultMatcher验证规则,验证控制器执行完成后结果是否正确。添加验证断言来判断执行请求后的结果是否是预期的。
(3)andDo()方法:添加ResultHandler结果处理器,用于对验证成功后执行的动作,比如调试时打印结果到控制台。
(4)andReturn()方法:最后返回相应的MvcResult;然后进行自定义验证/进行下一步的异步处理。

五、请求示例

1、Get请求 - 无参数

(1)代码示例

public void testGet () throws Exception {
    MockHttpServletRequestBuilder postRequestBuilder = MockMvcRequestBuilders
            .get("/user/list")
            .contentType(MediaType.APPLICATION_JSON);

    MvcResult response = mockMvc.perform(postRequestBuilder)
            .andExpect(MockMvcResultMatchers.status().isOk())
            .andDo(MockMvcResultHandlers.print())
            .andReturn();

    System.out.println("result:"+response.getResponse().getContentAsString());
}

(2)Request请求体

 (3)Response返回结果 

 2、Get请求 - 有参数

(1)代码示例

public void testGet () throws Exception {
    MockHttpServletRequestBuilder postRequestBuilder = MockMvcRequestBuilders
            .get("/user/list")
            .contentType(MediaType.APPLICATION_JSON)
            .param("biz_date", "2021-11-05")
            .param("operator_name", "张三");

    MvcResult response = mockMvc.perform(postRequestBuilder)
            .andExpect(MockMvcResultMatchers.status().isOk())
            .andDo(MockMvcResultHandlers.print())
            .andReturn();

    System.out.println("result:"+response.getResponse().getContentAsString());
}

(2)Request请求体

(3)Response返回结果

3、Post请求 - Paramter形式

(1)代码示例

public void testPost () throws Exception {
    MockHttpServletRequestBuilder postRequestBuilder = MockMvcRequestBuilders
            .post("/user/add")
            .contentType(MediaType.APPLICATION_JSON)
            .param("name", "张三")
            .param("age", "18");

    MvcResult response = mockMvc.perform(postRequestBuilder)
            .andExpect(MockMvcResultMatchers.status().isOk())
            .andDo(MockMvcResultHandlers.print())
            .andReturn();

    System.out.println("result:"+response.getResponse().getContentAsString());
}

(2)Request请求体

(3)Response返回结果

 4、Post请求 - RequestBody content形式

(1)代码示例

public void testPost () throws Exception {
    Map<String, String> paramMap = new HashMap<>();
    paramMap.put("name", "张三");
    paramMap.put("age", "18");
        
    MockHttpServletRequestBuilder postRequestBuilder = MockMvcRequestBuilders
            .post("/user/add")
            .contentType(MediaType.APPLICATION_JSON)
            .content(JSON.toJSON(paramMap).toString());

    MvcResult response = mockMvc.perform(postRequestBuilder)
            .andExpect(MockMvcResultMatchers.status().isOk())
            .andDo(MockMvcResultHandlers.print())
            .andReturn();

    System.out.println("result:"+response.getResponse().getContentAsString());
}

(2)Request请求体

(3)Response返回结果

       以上是对SpringBoot集成Mock进行接口单元测试的整体流程,小伙伴有问题请及时跟我沟通交流,感谢大家!!!

 

参考资料

Spring官网测试用例
Spring MVC测试框架详解——服务端测试

  • 4
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值