前面,我们开发好了用户注册的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!
测试成功用例
为了方便使用构造器,我们在UserRegisterDTO上加两个注解:
package com.xiaojuan.boot.dto;
import ...
@AllArgsConstructor
@NoArgsConstructor
@Data
public class UserRegisterDTO {
...
}
再看我们的测试用例:
@Test
public void testRegisterSuccess() {
userService.register(new UserRegisterDTO("zhangsan", "123"));
}
非常顺利,一路绿灯!
从控制台打印的sql,就可以看出执行的流程了:
这里生成了我们想要的密码加密串。
测试失败用例
失败有两种校验不通过的情况,都是以异常的形式抛出来的。要断言异常,可以引入一个测试依赖:
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!我们的开发成果没任何毛病!