Spring Boot实用技巧之单元测试

一、单元测试的概念

二、单元测试的优势

  1. 非常简单、快速、直观的测试某一个功能是否符合预期
  2. 单元测试时可以不启动tomcat
  3. 在我们打包之前,所有的单元测试都会被执行一遍,一旦有一个单元测试没通过,都会打包失败
  4. 使用单元测试时,可以不污染数据库,也就是说可以在不对数据库进行任何修改的情况下,对 Mapper 层的代码进行测试,技术支持:回滚

三、Spring Boot实现单元测试

(一)添加依赖

  Spring Boot 项目创建时会默认添加上单元测试框架 spring-boot-starter-test,这个框架主要是依赖另一个著名测试框架 JUnit 实现的,如下图所示:   我们通过查看 spring-boot-starter-test 的源码,就能看到它和 JUnit 的关系

(二)生成单元测试的类

  1. 在需要进行单元测试的类或接口里面设置
  2. 上述生成的单元测试类其中的方法中是没有内容的;其次生成的单元测试类位于test包下,如图:

(三) 添加注解和业务代码

1. 添加 @SpringBootTest 注解

// 表明当前单元测试运行在 spring boot 环境中
@SpringBootTest
class UserMapperTest {
          
   

    @Test
    void getUserById() {
          
   
    }
}

2. 添加单元测试的业务代码

// 表明当前单元测试运行在 spring boot 环境中
@SpringBootTest
class UserMapperTest {
          
   

    // 如果idea是科学版,那么这里注入的注解使用 @Autowired 可能会报错
    // 将 UserMapper 注入进来,对它的相关方法进行测试
    @Resource
    private UserMapper userMapper;

    // 测试代码
    @Test
    void getUserById() {
          
   
        UserInfo userInfo = userMapper.getUserById(1);
        System.out.println(userInfo);
    }
}

3. 执行测试

  1. 开始执行
  2. 运行结果

(四)断言说明与添加

  百度百科:断言(assertion)是一种在程序中的一阶逻辑(如:一个结果为真或假的逻辑判断式),目的为了表示与验证软件开发者预期的结果——当程序执行到断言的位置时,对应的断言应该为真。若断言不为真时,程序会中止执行,并给出错误信息   断言所使用的类是 Assertions,如果断言失败,则后面的代码都不会执行

  1. 常用的断言方法
方法 说明 assertEquals 判断两个对象或两个基本类型是否相等 assertNotEquals 判断两个对象或两个基本类型是否不相等 assertSame 判断两个对象引用是否指向同一对象 assertNotSame 判断两个对象引用是否指向不同对象 assertTrue 判断给定的布尔值是否为true assertFalse 判断给定的布尔值是否为false assertNull 判断给定的对象引用是否为null assertNotNull 判断给定的对象引用是否不为null
  1. 使用断言对测试结果进行判断 代码示例:
// 测试代码
@Test
void getUserById() {
          
   
    UserInfo userInfo = userMapper.getUserById(1);
    // System.out.println(userInfo);
    // 测试查询结果是否不为 null
    Assertions.assertNotNull(userInfo);
}

执行结果: 如果方法写成 assertNull,那么结果就会报错:

四、sql 执行回滚设置

  很多时候,我们只是想进行测试,但是不愿意数据库中的数据也被修改,才是我们就要设置单元测试的回滚操作   核心:给测试类或测试类的方法上加上 @Transactional 注解,该注解的本意只是开启事务,并提交事务,但是加在测试类的时候,它又增加了一个功能,就是最后执行完毕之后回滚事务

代码示例:

@Test
@Transactional
void updateNameById() {
          
   
    int result = userMapper.updateNameById(2, "wangwu");
    Assertions.assertEquals(1, result);
}
经验分享 程序员 微信小程序 职场和发展