用户注册Service单元测试

103 阅读1分钟

本节视频教程链接

前面,我们开发好了用户注册的Service服务接口,这一节我们对其进行单元测试,这里我们会测试几种场景,把各种情况都覆盖到。

创建Service单元测试

按组合键Alt+Enter创建单元测试,生成测试类后,我们稍微修改下,注入要测试的UserService接口,写一个空的测试方法:

package com.xiaojuan.boot.service.impl;

import ...

import static org.junit.jupiter.api.Assertions.*;

@Transactional // 确保每个单元测试后数据会回滚,实现单元测试数据的隔离
@SpringBootTest
class UserServiceImplTest {
    
    @Resource
    private UserService userService;
    
    @Test
    public void testRegisterSuccess() {
        assertNotNull(userService);
    }
    
}

先跑下看,是不是绿条, ok!

image.png

测试成功用例

为了方便使用构造器,我们在UserRegisterDTO上加两个注解:

package com.xiaojuan.boot.dto;

import ...

@AllArgsConstructor
@NoArgsConstructor
@Data
public class UserRegisterDTO {
    ...
}

再看我们的测试用例:

@Test
public void testRegisterSuccess() {
    userService.register(new UserRegisterDTO("zhangsan", "123"));
}

非常顺利,一路绿灯!

image.png

从控制台打印的sql,就可以看出执行的流程了:

image.png

这里生成了我们想要的密码加密串。

测试失败用例

失败有两种校验不通过的情况,都是以异常的形式抛出来的。要断言异常,可以引入一个测试依赖:

dependencies {
    ...
    testImplementation 'org.assertj:assertj-core:3.24.2'
    ...
}

现在我们快速写出失败的用例,断言异常的套路类似:

@Test
public void testMissingUsername() {
    assertThatExceptionOfType(IllegalArgumentException.class).isThrownBy(() -> {
        userService.register(new UserRegisterDTO(null, "123"));
    }).withMessage("用户名不能为空");
}

@Test
public void testExistsUsername() {
    // 先注册成功一个zhangsan用户
    userService.register(new UserRegisterDTO("zhangsan", "123"));

    assertThatExceptionOfType(BusinessException.class).isThrownBy(() -> {
        // 再注册一个username一样的用户就会报错
        userService.register(new UserRegisterDTO("zhangsan", "666"));
    }).withMessage("用户名已存在");
}

再来测试下,还是一路绿条,ok!我们的开发成果没任何毛病!

image.png