|
@@ -0,0 +1,138 @@
|
|
|
+package cn.iocoder.yudao.module.work.service.totalscore;
|
|
|
+
|
|
|
+import org.junit.jupiter.api.Disabled;
|
|
|
+import org.junit.jupiter.api.Test;
|
|
|
+import org.springframework.boot.test.mock.mockito.MockBean;
|
|
|
+
|
|
|
+import jakarta.annotation.Resource;
|
|
|
+
|
|
|
+import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest;
|
|
|
+
|
|
|
+import cn.iocoder.yudao.module.work.controller.admin.totalscore.vo.*;
|
|
|
+import cn.iocoder.yudao.module.work.dal.dataobject.totalscore.TotalScoreDO;
|
|
|
+import cn.iocoder.yudao.module.work.dal.mysql.totalscore.TotalScoreMapper;
|
|
|
+import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
|
|
+
|
|
|
+import jakarta.annotation.Resource;
|
|
|
+import org.springframework.context.annotation.Import;
|
|
|
+import java.util.*;
|
|
|
+import java.time.LocalDateTime;
|
|
|
+
|
|
|
+import static cn.hutool.core.util.RandomUtil.*;
|
|
|
+import static cn.iocoder.yudao.module.work.enums.ErrorCodeConstants.*;
|
|
|
+import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.*;
|
|
|
+import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.*;
|
|
|
+import static cn.iocoder.yudao.framework.common.util.date.LocalDateTimeUtils.*;
|
|
|
+import static cn.iocoder.yudao.framework.common.util.object.ObjectUtils.*;
|
|
|
+import static cn.iocoder.yudao.framework.common.util.date.DateUtils.*;
|
|
|
+import static org.junit.jupiter.api.Assertions.*;
|
|
|
+import static org.mockito.Mockito.*;
|
|
|
+
|
|
|
+/**
|
|
|
+ * {@link TotalScoreServiceImpl} 的单元测试类
|
|
|
+ *
|
|
|
+ * @author 管理员
|
|
|
+ */
|
|
|
+@Import(TotalScoreServiceImpl.class)
|
|
|
+public class TotalScoreServiceImplTest extends BaseDbUnitTest {
|
|
|
+
|
|
|
+ @Resource
|
|
|
+ private TotalScoreServiceImpl totalScoreService;
|
|
|
+
|
|
|
+ @Resource
|
|
|
+ private TotalScoreMapper totalScoreMapper;
|
|
|
+
|
|
|
+ @Test
|
|
|
+ public void testCreateTotalScore_success() {
|
|
|
+ // 准备参数
|
|
|
+ TotalScoreSaveReqVO createReqVO = randomPojo(TotalScoreSaveReqVO.class).setId(null);
|
|
|
+
|
|
|
+ // 调用
|
|
|
+ Integer totalScoreId = totalScoreService.createTotalScore(createReqVO);
|
|
|
+ // 断言
|
|
|
+ assertNotNull(totalScoreId);
|
|
|
+ // 校验记录的属性是否正确
|
|
|
+ TotalScoreDO totalScore = totalScoreMapper.selectById(totalScoreId);
|
|
|
+ assertPojoEquals(createReqVO, totalScore, "id");
|
|
|
+ }
|
|
|
+
|
|
|
+ @Test
|
|
|
+ public void testUpdateTotalScore_success() {
|
|
|
+ // mock 数据
|
|
|
+ TotalScoreDO dbTotalScore = randomPojo(TotalScoreDO.class);
|
|
|
+ totalScoreMapper.insert(dbTotalScore);// @Sql: 先插入出一条存在的数据
|
|
|
+ // 准备参数
|
|
|
+ TotalScoreSaveReqVO updateReqVO = randomPojo(TotalScoreSaveReqVO.class, o -> {
|
|
|
+ o.setId(dbTotalScore.getId()); // 设置更新的 ID
|
|
|
+ });
|
|
|
+
|
|
|
+ // 调用
|
|
|
+ totalScoreService.updateTotalScore(updateReqVO);
|
|
|
+ // 校验是否更新正确
|
|
|
+ TotalScoreDO totalScore = totalScoreMapper.selectById(updateReqVO.getId()); // 获取最新的
|
|
|
+ assertPojoEquals(updateReqVO, totalScore);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Test
|
|
|
+ public void testUpdateTotalScore_notExists() {
|
|
|
+ // 准备参数
|
|
|
+ TotalScoreSaveReqVO updateReqVO = randomPojo(TotalScoreSaveReqVO.class);
|
|
|
+
|
|
|
+ // 调用, 并断言异常
|
|
|
+ assertServiceException(() -> totalScoreService.updateTotalScore(updateReqVO), TOTAL_SCORE_NOT_EXISTS);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Test
|
|
|
+ public void testDeleteTotalScore_success() {
|
|
|
+ // mock 数据
|
|
|
+ TotalScoreDO dbTotalScore = randomPojo(TotalScoreDO.class);
|
|
|
+ totalScoreMapper.insert(dbTotalScore);// @Sql: 先插入出一条存在的数据
|
|
|
+ // 准备参数
|
|
|
+ Integer id = dbTotalScore.getId();
|
|
|
+
|
|
|
+ // 调用
|
|
|
+ totalScoreService.deleteTotalScore(id);
|
|
|
+ // 校验数据不存在了
|
|
|
+ assertNull(totalScoreMapper.selectById(id));
|
|
|
+ }
|
|
|
+
|
|
|
+ @Test
|
|
|
+ public void testDeleteTotalScore_notExists() {
|
|
|
+ // 准备参数
|
|
|
+ Integer id = randomIntegerId();
|
|
|
+
|
|
|
+ // 调用, 并断言异常
|
|
|
+ assertServiceException(() -> totalScoreService.deleteTotalScore(id), TOTAL_SCORE_NOT_EXISTS);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Test
|
|
|
+ @Disabled // TODO 请修改 null 为需要的值,然后删除 @Disabled 注解
|
|
|
+ public void testGetTotalScorePage() {
|
|
|
+ // mock 数据
|
|
|
+ TotalScoreDO dbTotalScore = randomPojo(TotalScoreDO.class, o -> { // 等会查询到
|
|
|
+ o.setWorkName(null);
|
|
|
+ o.setOverallRating(null);
|
|
|
+ o.setCreateTime(null);
|
|
|
+ });
|
|
|
+ totalScoreMapper.insert(dbTotalScore);
|
|
|
+ // 测试 workName 不匹配
|
|
|
+ totalScoreMapper.insert(cloneIgnoreId(dbTotalScore, o -> o.setWorkName(null)));
|
|
|
+ // 测试 overallRating 不匹配
|
|
|
+ totalScoreMapper.insert(cloneIgnoreId(dbTotalScore, o -> o.setOverallRating(null)));
|
|
|
+ // 测试 createTime 不匹配
|
|
|
+ totalScoreMapper.insert(cloneIgnoreId(dbTotalScore, o -> o.setCreateTime(null)));
|
|
|
+ // 准备参数
|
|
|
+ TotalScorePageReqVO reqVO = new TotalScorePageReqVO();
|
|
|
+ reqVO.setWorkName(null);
|
|
|
+ reqVO.setOverallRating(null);
|
|
|
+ reqVO.setCreateTime(buildBetweenTime(2023, 2, 1, 2023, 2, 28));
|
|
|
+
|
|
|
+ // 调用
|
|
|
+ PageResult<TotalScoreDO> pageResult = totalScoreService.getTotalScorePage(reqVO);
|
|
|
+ // 断言
|
|
|
+ assertEquals(1, pageResult.getTotal());
|
|
|
+ assertEquals(1, pageResult.getList().size());
|
|
|
+ assertPojoEquals(dbTotalScore, pageResult.getList().get(0));
|
|
|
+ }
|
|
|
+
|
|
|
+}
|