|
@@ -0,0 +1,154 @@
|
|
|
+package cn.newfeifan.mall.module.distri.service.dailybill;
|
|
|
+
|
|
|
+import org.junit.jupiter.api.Disabled;
|
|
|
+import org.junit.jupiter.api.Test;
|
|
|
+import org.springframework.boot.test.mock.mockito.MockBean;
|
|
|
+
|
|
|
+import javax.annotation.Resource;
|
|
|
+
|
|
|
+import cn.newfeifan.mall.framework.test.core.ut.BaseDbUnitTest;
|
|
|
+
|
|
|
+import cn.newfeifan.mall.module.distri.controller.admin.dailybill.vo.*;
|
|
|
+import cn.newfeifan.mall.module.distri.dal.dataobject.dailybill.DailyBillDO;
|
|
|
+import cn.newfeifan.mall.module.distri.dal.mysql.dailybill.DailyBillMapper;
|
|
|
+import cn.newfeifan.mall.framework.common.pojo.PageResult;
|
|
|
+
|
|
|
+import javax.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.newfeifan.mall.module.distri.enums.ErrorCodeConstants.*;
|
|
|
+import static cn.newfeifan.mall.framework.test.core.util.AssertUtils.*;
|
|
|
+import static cn.newfeifan.mall.framework.test.core.util.RandomUtils.*;
|
|
|
+import static cn.newfeifan.mall.framework.common.util.date.LocalDateTimeUtils.*;
|
|
|
+import static cn.newfeifan.mall.framework.common.util.object.ObjectUtils.*;
|
|
|
+import static cn.newfeifan.mall.framework.common.util.date.DateUtils.*;
|
|
|
+import static org.junit.jupiter.api.Assertions.*;
|
|
|
+import static org.mockito.Mockito.*;
|
|
|
+
|
|
|
+/**
|
|
|
+ * {@link DailyBillServiceImpl} 的单元测试类
|
|
|
+ *
|
|
|
+ * @author 非繁人
|
|
|
+ */
|
|
|
+@Import(DailyBillServiceImpl.class)
|
|
|
+public class DailyBillServiceImplTest extends BaseDbUnitTest {
|
|
|
+
|
|
|
+ @Resource
|
|
|
+ private DailyBillServiceImpl dailyBillService;
|
|
|
+
|
|
|
+ @Resource
|
|
|
+ private DailyBillMapper dailyBillMapper;
|
|
|
+
|
|
|
+ @Test
|
|
|
+ public void testCreateDailyBill_success() {
|
|
|
+ // 准备参数
|
|
|
+ DailyBillSaveReqVO createReqVO = randomPojo(DailyBillSaveReqVO.class).setId(null);
|
|
|
+
|
|
|
+ // 调用
|
|
|
+ Long dailyBillId = dailyBillService.createDailyBill(createReqVO);
|
|
|
+ // 断言
|
|
|
+ assertNotNull(dailyBillId);
|
|
|
+ // 校验记录的属性是否正确
|
|
|
+ DailyBillDO dailyBill = dailyBillMapper.selectById(dailyBillId);
|
|
|
+ assertPojoEquals(createReqVO, dailyBill, "id");
|
|
|
+ }
|
|
|
+
|
|
|
+ @Test
|
|
|
+ public void testUpdateDailyBill_success() {
|
|
|
+ // mock 数据
|
|
|
+ DailyBillDO dbDailyBill = randomPojo(DailyBillDO.class);
|
|
|
+ dailyBillMapper.insert(dbDailyBill);// @Sql: 先插入出一条存在的数据
|
|
|
+ // 准备参数
|
|
|
+ DailyBillSaveReqVO updateReqVO = randomPojo(DailyBillSaveReqVO.class, o -> {
|
|
|
+ o.setId(dbDailyBill.getId()); // 设置更新的 ID
|
|
|
+ });
|
|
|
+
|
|
|
+ // 调用
|
|
|
+ dailyBillService.updateDailyBill(updateReqVO);
|
|
|
+ // 校验是否更新正确
|
|
|
+ DailyBillDO dailyBill = dailyBillMapper.selectById(updateReqVO.getId()); // 获取最新的
|
|
|
+ assertPojoEquals(updateReqVO, dailyBill);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Test
|
|
|
+ public void testUpdateDailyBill_notExists() {
|
|
|
+ // 准备参数
|
|
|
+ DailyBillSaveReqVO updateReqVO = randomPojo(DailyBillSaveReqVO.class);
|
|
|
+
|
|
|
+ // 调用, 并断言异常
|
|
|
+ assertServiceException(() -> dailyBillService.updateDailyBill(updateReqVO), DAILY_BILL_NOT_EXISTS);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Test
|
|
|
+ public void testDeleteDailyBill_success() {
|
|
|
+ // mock 数据
|
|
|
+ DailyBillDO dbDailyBill = randomPojo(DailyBillDO.class);
|
|
|
+ dailyBillMapper.insert(dbDailyBill);// @Sql: 先插入出一条存在的数据
|
|
|
+ // 准备参数
|
|
|
+ Long id = dbDailyBill.getId();
|
|
|
+
|
|
|
+ // 调用
|
|
|
+ dailyBillService.deleteDailyBill(id);
|
|
|
+ // 校验数据不存在了
|
|
|
+ assertNull(dailyBillMapper.selectById(id));
|
|
|
+ }
|
|
|
+
|
|
|
+ @Test
|
|
|
+ public void testDeleteDailyBill_notExists() {
|
|
|
+ // 准备参数
|
|
|
+ Long id = randomLongId();
|
|
|
+
|
|
|
+ // 调用, 并断言异常
|
|
|
+ assertServiceException(() -> dailyBillService.deleteDailyBill(id), DAILY_BILL_NOT_EXISTS);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Test
|
|
|
+ @Disabled // TODO 请修改 null 为需要的值,然后删除 @Disabled 注解
|
|
|
+ public void testGetDailyBillPage() {
|
|
|
+ // mock 数据
|
|
|
+ DailyBillDO dbDailyBill = randomPojo(DailyBillDO.class, o -> { // 等会查询到
|
|
|
+ o.setAmount(null);
|
|
|
+ o.setReceivedAmount(null);
|
|
|
+ o.setOrderCount(null);
|
|
|
+ o.setShopId(null);
|
|
|
+ o.setMerchantId(null);
|
|
|
+ o.setOrderIds(null);
|
|
|
+ o.setCreateTime(null);
|
|
|
+ });
|
|
|
+ dailyBillMapper.insert(dbDailyBill);
|
|
|
+ // 测试 amount 不匹配
|
|
|
+ dailyBillMapper.insert(cloneIgnoreId(dbDailyBill, o -> o.setAmount(null)));
|
|
|
+ // 测试 receivedAmount 不匹配
|
|
|
+ dailyBillMapper.insert(cloneIgnoreId(dbDailyBill, o -> o.setReceivedAmount(null)));
|
|
|
+ // 测试 orderCount 不匹配
|
|
|
+ dailyBillMapper.insert(cloneIgnoreId(dbDailyBill, o -> o.setOrderCount(null)));
|
|
|
+ // 测试 shopId 不匹配
|
|
|
+ dailyBillMapper.insert(cloneIgnoreId(dbDailyBill, o -> o.setShopId(null)));
|
|
|
+ // 测试 merchantId 不匹配
|
|
|
+ dailyBillMapper.insert(cloneIgnoreId(dbDailyBill, o -> o.setMerchantId(null)));
|
|
|
+ // 测试 orderIds 不匹配
|
|
|
+ dailyBillMapper.insert(cloneIgnoreId(dbDailyBill, o -> o.setOrderIds(null)));
|
|
|
+ // 测试 createTime 不匹配
|
|
|
+ dailyBillMapper.insert(cloneIgnoreId(dbDailyBill, o -> o.setCreateTime(null)));
|
|
|
+ // 准备参数
|
|
|
+ DailyBillPageReqVO reqVO = new DailyBillPageReqVO();
|
|
|
+ reqVO.setAmount(null);
|
|
|
+ reqVO.setReceivedAmount(null);
|
|
|
+ reqVO.setOrderCount(null);
|
|
|
+ reqVO.setShopId(null);
|
|
|
+ reqVO.setMerchantId(null);
|
|
|
+ reqVO.setOrderIds(null);
|
|
|
+ reqVO.setCreateTime(buildBetweenTime(2023, 2, 1, 2023, 2, 28));
|
|
|
+
|
|
|
+ // 调用
|
|
|
+ PageResult<DailyBillDO> pageResult = dailyBillService.getDailyBillPage(reqVO);
|
|
|
+ // 断言
|
|
|
+ assertEquals(1, pageResult.getTotal());
|
|
|
+ assertEquals(1, pageResult.getList().size());
|
|
|
+ assertPojoEquals(dbDailyBill, pageResult.getList().get(0));
|
|
|
+ }
|
|
|
+
|
|
|
+}
|