|
@@ -0,0 +1,180 @@
|
|
|
+package com.citu.module.menduner.system.service.user;
|
|
|
+
|
|
|
+
|
|
|
+import com.citu.framework.common.pojo.PageResult;
|
|
|
+import com.citu.framework.test.core.ut.BaseDbUnitTest;
|
|
|
+import com.citu.module.menduner.system.controller.base.user.auth.UserAuthPageReqVO;
|
|
|
+import com.citu.module.menduner.system.controller.base.user.auth.UserAuthSaveReqVO;
|
|
|
+import com.citu.module.menduner.system.dal.dataobject.user.UserAuthDO;
|
|
|
+import com.citu.module.menduner.system.dal.mysql.user.UserAuthMapper;
|
|
|
+import org.junit.jupiter.api.Disabled;
|
|
|
+import org.junit.jupiter.api.Test;
|
|
|
+import org.springframework.context.annotation.Import;
|
|
|
+
|
|
|
+import javax.annotation.Resource;
|
|
|
+
|
|
|
+import static com.citu.framework.common.util.date.LocalDateTimeUtils.buildBetweenTime;
|
|
|
+import static com.citu.framework.common.util.object.ObjectUtils.cloneIgnoreId;
|
|
|
+import static com.citu.framework.test.core.util.AssertUtils.assertPojoEquals;
|
|
|
+import static com.citu.framework.test.core.util.AssertUtils.assertServiceException;
|
|
|
+import static com.citu.framework.test.core.util.RandomUtils.randomLongId;
|
|
|
+import static com.citu.framework.test.core.util.RandomUtils.randomPojo;
|
|
|
+import static com.citu.module.menduner.system.enums.ErrorCodeConstants.USER_AUTH_NOT_EXISTS;
|
|
|
+import static org.junit.jupiter.api.Assertions.*;
|
|
|
+
|
|
|
+/**
|
|
|
+ * {@link UserAuthServiceImpl} 的单元测试类
|
|
|
+ *
|
|
|
+ * @author Rayson
|
|
|
+ */
|
|
|
+@Import(UserAuthServiceImpl.class)
|
|
|
+public class UserAuthServiceImplTest extends BaseDbUnitTest {
|
|
|
+
|
|
|
+ @Resource
|
|
|
+ private UserAuthServiceImpl userAuthService;
|
|
|
+
|
|
|
+ @Resource
|
|
|
+ private UserAuthMapper userAuthMapper;
|
|
|
+
|
|
|
+ @Test
|
|
|
+ public void testCreateUserAuth_success() {
|
|
|
+ // 准备参数
|
|
|
+ UserAuthSaveReqVO createReqVO = randomPojo(UserAuthSaveReqVO.class).setId(null);
|
|
|
+
|
|
|
+ // 调用
|
|
|
+ Long userAuthId = userAuthService.createUserAuth(createReqVO);
|
|
|
+ // 断言
|
|
|
+ assertNotNull(userAuthId);
|
|
|
+ // 校验记录的属性是否正确
|
|
|
+ UserAuthDO userAuth = userAuthMapper.selectById(userAuthId);
|
|
|
+ assertPojoEquals(createReqVO, userAuth, "id");
|
|
|
+ }
|
|
|
+
|
|
|
+ @Test
|
|
|
+ public void testUpdateUserAuth_success() {
|
|
|
+ // mock 数据
|
|
|
+ UserAuthDO dbUserAuth = randomPojo(UserAuthDO.class);
|
|
|
+ userAuthMapper.insert(dbUserAuth);// @Sql: 先插入出一条存在的数据
|
|
|
+ // 准备参数
|
|
|
+ UserAuthSaveReqVO updateReqVO = randomPojo(UserAuthSaveReqVO.class, o -> {
|
|
|
+ o.setId(dbUserAuth.getId()); // 设置更新的 ID
|
|
|
+ });
|
|
|
+
|
|
|
+ // 调用
|
|
|
+ userAuthService.updateUserAuth(updateReqVO);
|
|
|
+ // 校验是否更新正确
|
|
|
+ UserAuthDO userAuth = userAuthMapper.selectById(updateReqVO.getId()); // 获取最新的
|
|
|
+ assertPojoEquals(updateReqVO, userAuth);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Test
|
|
|
+ public void testUpdateUserAuth_notExists() {
|
|
|
+ // 准备参数
|
|
|
+ UserAuthSaveReqVO updateReqVO = randomPojo(UserAuthSaveReqVO.class);
|
|
|
+
|
|
|
+ // 调用, 并断言异常
|
|
|
+ assertServiceException(() -> userAuthService.updateUserAuth(updateReqVO), USER_AUTH_NOT_EXISTS);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Test
|
|
|
+ public void testDeleteUserAuth_success() {
|
|
|
+ // mock 数据
|
|
|
+ UserAuthDO dbUserAuth = randomPojo(UserAuthDO.class);
|
|
|
+ userAuthMapper.insert(dbUserAuth);// @Sql: 先插入出一条存在的数据
|
|
|
+ // 准备参数
|
|
|
+ Long id = dbUserAuth.getId();
|
|
|
+
|
|
|
+ // 调用
|
|
|
+ userAuthService.deleteUserAuth(id);
|
|
|
+ // 校验数据不存在了
|
|
|
+ assertNull(userAuthMapper.selectById(id));
|
|
|
+ }
|
|
|
+
|
|
|
+ @Test
|
|
|
+ public void testDeleteUserAuth_notExists() {
|
|
|
+ // 准备参数
|
|
|
+ Long id = randomLongId();
|
|
|
+
|
|
|
+ // 调用, 并断言异常
|
|
|
+ assertServiceException(() -> userAuthService.deleteUserAuth(id), USER_AUTH_NOT_EXISTS);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Test
|
|
|
+ @Disabled // TODO 请修改 null 为需要的值,然后删除 @Disabled 注解
|
|
|
+ public void testGetUserAuthPage() {
|
|
|
+ // mock 数据
|
|
|
+ UserAuthDO dbUserAuth = randomPojo(UserAuthDO.class, o -> { // 等会查询到
|
|
|
+ o.setUserId(null);
|
|
|
+ o.setFrontUrl(null);
|
|
|
+ o.setBackUrl(null);
|
|
|
+ o.setName(null);
|
|
|
+ o.setGender(null);
|
|
|
+ o.setEthnicity(null);
|
|
|
+ o.setBirthDate(null);
|
|
|
+ o.setAddress(null);
|
|
|
+ o.setIdNumber(null);
|
|
|
+ o.setIssuingAuthority(null);
|
|
|
+ o.setIssueDate(null);
|
|
|
+ o.setExpiryDate(null);
|
|
|
+ o.setStatus(null);
|
|
|
+ o.setReason(null);
|
|
|
+ o.setCreateTime(null);
|
|
|
+ });
|
|
|
+ userAuthMapper.insert(dbUserAuth);
|
|
|
+ // 测试 userId 不匹配
|
|
|
+ userAuthMapper.insert(cloneIgnoreId(dbUserAuth, o -> o.setUserId(null)));
|
|
|
+ // 测试 frontUrl 不匹配
|
|
|
+ userAuthMapper.insert(cloneIgnoreId(dbUserAuth, o -> o.setFrontUrl(null)));
|
|
|
+ // 测试 backUrl 不匹配
|
|
|
+ userAuthMapper.insert(cloneIgnoreId(dbUserAuth, o -> o.setBackUrl(null)));
|
|
|
+ // 测试 name 不匹配
|
|
|
+ userAuthMapper.insert(cloneIgnoreId(dbUserAuth, o -> o.setName(null)));
|
|
|
+ // 测试 gender 不匹配
|
|
|
+ userAuthMapper.insert(cloneIgnoreId(dbUserAuth, o -> o.setGender(null)));
|
|
|
+ // 测试 ethnicity 不匹配
|
|
|
+ userAuthMapper.insert(cloneIgnoreId(dbUserAuth, o -> o.setEthnicity(null)));
|
|
|
+ // 测试 birthDate 不匹配
|
|
|
+ userAuthMapper.insert(cloneIgnoreId(dbUserAuth, o -> o.setBirthDate(null)));
|
|
|
+ // 测试 address 不匹配
|
|
|
+ userAuthMapper.insert(cloneIgnoreId(dbUserAuth, o -> o.setAddress(null)));
|
|
|
+ // 测试 idNumber 不匹配
|
|
|
+ userAuthMapper.insert(cloneIgnoreId(dbUserAuth, o -> o.setIdNumber(null)));
|
|
|
+ // 测试 issuingAuthority 不匹配
|
|
|
+ userAuthMapper.insert(cloneIgnoreId(dbUserAuth, o -> o.setIssuingAuthority(null)));
|
|
|
+ // 测试 issueDate 不匹配
|
|
|
+ userAuthMapper.insert(cloneIgnoreId(dbUserAuth, o -> o.setIssueDate(null)));
|
|
|
+ // 测试 expiryDate 不匹配
|
|
|
+ userAuthMapper.insert(cloneIgnoreId(dbUserAuth, o -> o.setExpiryDate(null)));
|
|
|
+ // 测试 status 不匹配
|
|
|
+ userAuthMapper.insert(cloneIgnoreId(dbUserAuth, o -> o.setStatus(null)));
|
|
|
+ // 测试 reason 不匹配
|
|
|
+ userAuthMapper.insert(cloneIgnoreId(dbUserAuth, o -> o.setReason(null)));
|
|
|
+ // 测试 createTime 不匹配
|
|
|
+ userAuthMapper.insert(cloneIgnoreId(dbUserAuth, o -> o.setCreateTime(null)));
|
|
|
+ // 准备参数
|
|
|
+ UserAuthPageReqVO reqVO = new UserAuthPageReqVO();
|
|
|
+ reqVO.setUserId(null);
|
|
|
+ reqVO.setFrontUrl(null);
|
|
|
+ reqVO.setBackUrl(null);
|
|
|
+ reqVO.setName(null);
|
|
|
+ reqVO.setGender(null);
|
|
|
+ reqVO.setEthnicity(null);
|
|
|
+ reqVO.setBirthDate(buildBetweenTime(2023, 2, 1, 2023, 2, 28));
|
|
|
+ reqVO.setAddress(null);
|
|
|
+ reqVO.setIdNumber(null);
|
|
|
+ reqVO.setIssuingAuthority(null);
|
|
|
+ reqVO.setIssueDate(buildBetweenTime(2023, 2, 1, 2023, 2, 28));
|
|
|
+ reqVO.setExpiryDate(buildBetweenTime(2023, 2, 1, 2023, 2, 28));
|
|
|
+ reqVO.setStatus(null);
|
|
|
+ reqVO.setReason(null);
|
|
|
+ reqVO.setCreateTime(buildBetweenTime(2023, 2, 1, 2023, 2, 28));
|
|
|
+
|
|
|
+ // 调用
|
|
|
+ PageResult<UserAuthDO> pageResult = userAuthService.getUserAuthPage(reqVO);
|
|
|
+ // 断言
|
|
|
+ assertEquals(1, pageResult.getTotal());
|
|
|
+ assertEquals(1, pageResult.getList().size());
|
|
|
+ assertPojoEquals(dbUserAuth, pageResult.getList().get(0));
|
|
|
+ }
|
|
|
+
|
|
|
+}
|