SpringBoot【实用篇】- 测试

文章目录

目标:

  • 加载测试专用属性
  • 加载测试专用配置
  • Web环境模拟测试
  • 数据层测试回滚
  • 测试用例数据设定
1.加载测试专用属性

我们在前面讲配置高级的时候是这样写的:

复制代码
test:
  prop: testValue

测试类:

复制代码
@SpringBootTest
public class PropertiesAndArgsTest {

    @Value("${test.prop}")
    private String msg;

    @Test
    void testProperties(){
        System.out.println(msg);
    }
}

那如果我把yml文件中的配置注释掉,我们还可以通过@SprinBootTest 来添加临时属性

复制代码
@SpringBootTest("test.prop = testValue")
public class PropertiesAndArgsTest {

    @Value("${test.prop}")
    private String msg;

    @Test
    void testProperties(){
        System.out.println(msg);
    }
}

如果两个都有谁生效呢? 答案是在这个测试类properties属性添加的临时属性配置中会覆盖yml的配置。

用args配也是可以的,使用args属性可以为当前测试用例添加临时的命令行参数

复制代码
//@SpringBootTest("test.prop = testValue")
@SpringBootTest(args = {"--test.prop=testValue2"})
public class PropertiesAndArgsTest {

    @Value("${test.prop}")
    private String msg;

    @Test
    void testProperties(){
        System.out.println(msg);
    }
}

那如果三个都有呢?

答案: 命令行级别参数(源码级别) > properties(idea)
小结:

加载测试临时属性应用小于小范围测试环境.

3.Web环境模拟测试

如果我们要想加入一个外部的bean来辅助我们测试:

复制代码
@Configuration
public class MsgConfig {

    @Bean
    public String msg(){
        return "bean msg";
    }
    
}

测试类中:

复制代码
@SpringBootTest
@Import(MsgConfig.class)
public class ConfigurationTest {

    @Autowired
    private String msg;

    @Test
    void testConfiguration() {
        System.out.println(msg);
    }

}


小结: 加载测试范围配置应用与小范围测试环境

能不能在测试样例中测试表现层呢?

2.加载测试专用配置
复制代码
@SpringBootTest
public class WebTest {

    @Test
    void test(){

    }
}

ctrl+左键 =》 查看SpringBootTest的源码,ctrl + f12查看方法

复制代码
@SpringBootTest(webEnvironment =SpringBootTest.WebEnvironment.RANDOM_PORT)

创建controller 然后模拟调用

复制代码
@RestController
@RequestMapping("/books")
public class BookController {

    @GetMapping
    public String getById(){
        System.out.println("getById is running...");
        return "SpringBoot";
    }
}



 @Test
    void testWeb(@Autowired MockMvc mvc) throws Exception {
        //http:localhost:8080/books
        //创建虚拟请求 当前访问路径为/books
        MockHttpServletRequestBuilder builder = MockMvcRequestBuilders.get("/books");
        mvc.perform(builder);

    }

ctrl + 左键 进去RequestBuilder查看源码,然后ctrl+h查看实现类


复制代码
   @Test
    void testStatus(@Autowired MockMvc mvc) throws Exception {
        MockHttpServletRequestBuilder builder = MockMvcRequestBuilders.get("/books");
        ResultActions action = mvc.perform(builder);

        //设定预期值与真实值进行比较,成功测试通过,失败测试失败
        StatusResultMatchers status = MockMvcResultMatchers.status();
        //预计本次调用时成功的:状态200
        ResultMatcher ok = status.isOk();
        //添加预计值到本次调用过程中进行匹配
        action.andExpect(ok);

    }

如果你修改为book1


执行结果的匹配

复制代码
 @Test
    void testBody(@Autowired MockMvc mvc) throws Exception {
        MockHttpServletRequestBuilder builder = MockMvcRequestBuilders.get("/books");
        ResultActions action = mvc.perform(builder);

        //设定预期值与真实值进行比较,成功测试通过,失败测试失败
        ContentResultMatchers content = MockMvcResultMatchers.content();
        ResultMatcher result = content.string("springboot");
        action.andExpect(result);

    }

但是我们以后是对json做匹配

复制代码
import lombok.Data;

@Data
public class Book {
    private int id;
    private String name;
    private String type;
    private String description;
}


 @GetMapping
    public Book getById(){
        System.out.println("getById is running...");
        Book book = new Book();
        book.setId(1);
        book.setName("SpringBoot");
        book.setType("Spring Framework");
        book.setDescription("This is a book about Spring Boot");
        return book;
    }
复制代码
 @Test
    void testJson(@Autowired MockMvc mvc) throws Exception {
        MockHttpServletRequestBuilder builder = MockMvcRequestBuilders.get("/books");
        ResultActions action = mvc.perform(builder);

        //设定预期值与真实值进行比较,成功测试通过,失败测试失败
        ContentResultMatchers content = MockMvcResultMatchers.content();
        ResultMatcher result = content.json("{
" +
                "    "id": 1,
" +
                "    "name": "SpringBoot",
" +
                "    "type": "Spring Framework",
" +
                "    "description": "This is a book about Spring Boot"
" +
                "}");

        action.andExpect(result);

    }

我们也可以测试header-type 虚拟请求头匹配

复制代码
  @Test
    void testContentType(@Autowired MockMvc mvc) throws Exception {
        MockHttpServletRequestBuilder builder = MockMvcRequestBuilders.get("/books");
        ResultActions action = mvc.perform(builder);
        //设定预期值与真实值进行比较,成功测试通过,失败测试失败
        HeaderResultMatchers header = MockMvcResultMatchers.header();
        ResultMatcher contentType = header.string("Content-Type", "application/json;charset=UTF-8");
        action.andExpect(contentType);
    }
4.数据层测试回滚

有一种情况是:当我们测试业务层或者Dao层会留下结果数据,真实的企业开发会生成两个sql文件一个数据库的表创建的sql,一个数据库初始化的sql,但是当我们在开发的时候仍然需要测试仍然会留下数据,但是我们是想着我们测试只是想看看写的代码有没有问题,不需要留下数据,下面说的方法只服务于开发,上线后的另说。

我们可以用事务来进行回滚,

如何生成随机值来进行测试呢?

5.测试用例数据设定


封装实体类:


小结: 使用随机数据替换固定数据。

相关推荐
澈2074 小时前
C++并查集:高效解决连通性问题
java·c++·算法
易安说AI4 小时前
Codex 直接住进 JetBrains IDE 里:AI Agent 正在接管熟悉的开发入口
后端
子兮曰5 小时前
Node.js v26.1.0 深度解读:FFI、后量子密码与调试器的进化
前端·后端·node.js
2401_873479405 小时前
运营活动被薅羊毛怎么防?用IP查询+设备指纹联动封堵漏洞
java·网络·tcp/ip·github
ShiJiuD6668889995 小时前
大事件板块一
java
摇滚侠6 小时前
@Autowired 和 @Resource 的区别
java·开发语言
Wy_编程6 小时前
go语言中的结构体
开发语言·后端·golang
SeaTunnel6 小时前
(八)收官篇 | 数据平台最后一公里:数据集成开发设计与上线治理实战
java·大数据·开发语言·白鲸开源
Ting-yu6 小时前
SpringCloud快速入门(7)---- 数据隔离
spring boot·spring·spring cloud
吴声子夜歌7 小时前
Java——线程的基本协作机制
java·线程协作