mirror of
https://gitee.com/huangge1199_admin/vue-pro.git
synced 2024-11-26 09:11:52 +08:00
短信模板的单元测试
This commit is contained in:
parent
fbbcd2717a
commit
4a40771057
@ -82,8 +82,15 @@ public class SysSmsTemplateServiceImpl implements SysSmsTemplateService {
|
|||||||
public void updateSmsTemplate(SysSmsTemplateUpdateReqVO updateReqVO) {
|
public void updateSmsTemplate(SysSmsTemplateUpdateReqVO updateReqVO) {
|
||||||
// 校验存在
|
// 校验存在
|
||||||
this.validateSmsTemplateExists(updateReqVO.getId());
|
this.validateSmsTemplateExists(updateReqVO.getId());
|
||||||
|
// 校验短信渠道
|
||||||
|
SysSmsChannelDO channelDO = checkSmsChannel(updateReqVO.getChannelId());
|
||||||
|
// 校验短信编码是否重复
|
||||||
|
checkSmsTemplateCodeDuplicate(updateReqVO.getId(), updateReqVO.getCode());
|
||||||
|
|
||||||
// 更新
|
// 更新
|
||||||
SysSmsTemplateDO updateObj = SysSmsTemplateConvert.INSTANCE.convert(updateReqVO);
|
SysSmsTemplateDO updateObj = SysSmsTemplateConvert.INSTANCE.convert(updateReqVO);
|
||||||
|
updateObj.setParams(parseTemplateContentParams(updateObj.getContent()));
|
||||||
|
updateObj.setChannelCode(channelDO.getCode());
|
||||||
smsTemplateMapper.updateById(updateObj);
|
smsTemplateMapper.updateById(updateObj);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -121,7 +128,8 @@ public class SysSmsTemplateServiceImpl implements SysSmsTemplateService {
|
|||||||
return smsTemplateMapper.selectList(exportReqVO);
|
return smsTemplateMapper.selectList(exportReqVO);
|
||||||
}
|
}
|
||||||
|
|
||||||
private SysSmsChannelDO checkSmsChannel(Long channelId) {
|
@VisibleForTesting
|
||||||
|
public SysSmsChannelDO checkSmsChannel(Long channelId) {
|
||||||
SysSmsChannelDO channelDO = smsChannelService.getSmsChannel(channelId);
|
SysSmsChannelDO channelDO = smsChannelService.getSmsChannel(channelId);
|
||||||
if (channelDO == null) {
|
if (channelDO == null) {
|
||||||
throw exception(SMS_CHANNEL_NOT_EXISTS);
|
throw exception(SMS_CHANNEL_NOT_EXISTS);
|
||||||
@ -132,7 +140,8 @@ public class SysSmsTemplateServiceImpl implements SysSmsTemplateService {
|
|||||||
return channelDO;
|
return channelDO;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void checkSmsTemplateCodeDuplicate(Long id, String code) {
|
@VisibleForTesting
|
||||||
|
public void checkSmsTemplateCodeDuplicate(Long id, String code) {
|
||||||
SysSmsTemplateDO template = smsTemplateMapper.selectByCode(code);
|
SysSmsTemplateDO template = smsTemplateMapper.selectByCode(code);
|
||||||
if (template == null) {
|
if (template == null) {
|
||||||
return;
|
return;
|
||||||
|
@ -12,7 +12,6 @@ import cn.iocoder.dashboard.modules.system.enums.permission.MenuTypeEnum;
|
|||||||
import cn.iocoder.dashboard.modules.system.mq.producer.permission.SysMenuProducer;
|
import cn.iocoder.dashboard.modules.system.mq.producer.permission.SysMenuProducer;
|
||||||
import cn.iocoder.dashboard.modules.system.service.permission.impl.SysMenuServiceImpl;
|
import cn.iocoder.dashboard.modules.system.service.permission.impl.SysMenuServiceImpl;
|
||||||
import cn.iocoder.dashboard.util.AopTargetUtils;
|
import cn.iocoder.dashboard.util.AopTargetUtils;
|
||||||
import cn.iocoder.dashboard.util.AssertUtils;
|
|
||||||
import cn.iocoder.dashboard.util.RandomUtils;
|
import cn.iocoder.dashboard.util.RandomUtils;
|
||||||
import cn.iocoder.dashboard.util.object.ObjectUtils;
|
import cn.iocoder.dashboard.util.object.ObjectUtils;
|
||||||
import com.google.common.collect.Multimap;
|
import com.google.common.collect.Multimap;
|
||||||
@ -22,7 +21,6 @@ import org.springframework.boot.test.mock.mockito.MockBean;
|
|||||||
import org.springframework.context.annotation.Import;
|
import org.springframework.context.annotation.Import;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
|
||||||
import static cn.iocoder.dashboard.modules.system.enums.SysErrorCodeConstants.*;
|
import static cn.iocoder.dashboard.modules.system.enums.SysErrorCodeConstants.*;
|
||||||
@ -273,10 +271,10 @@ public class SysMenuServiceTest extends BaseDbUnitTest {
|
|||||||
menuDO = createMenuDO(4L, MenuTypeEnum.MENU, "name", 0L, 2);
|
menuDO = createMenuDO(4L, MenuTypeEnum.MENU, "name", 0L, 2);
|
||||||
mockCacheMap.put(menuDO.getId(), menuDO);
|
mockCacheMap.put(menuDO.getId(), menuDO);
|
||||||
|
|
||||||
List<SysMenuDO> menuDOS = sysMenuService.listMenusFromCache(Arrays.asList(1L),
|
List<SysMenuDO> menuDOS = sysMenuService.listMenusFromCache(Collections.singletonList(1L),
|
||||||
Arrays.asList(MenuTypeEnum.MENU.getType()), Arrays.asList(1));
|
Collections.singletonList(MenuTypeEnum.MENU.getType()), Collections.singletonList(1));
|
||||||
Assert.isTrue(menuDOS.size() == idMenuMap.size());
|
Assert.isTrue(menuDOS.size() == idMenuMap.size());
|
||||||
menuDOS.stream().forEach(menu -> assertPojoEquals(idMenuMap.get(menu.getId()), menu));
|
menuDOS.forEach(menu -> assertPojoEquals(idMenuMap.get(menu.getId()), menu));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@ -354,14 +352,13 @@ public class SysMenuServiceTest extends BaseDbUnitTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private SysMenuDO createMenuDO(Long id, MenuTypeEnum typeEnum, String menuName, Long parentId, Integer status) {
|
private SysMenuDO createMenuDO(Long id, MenuTypeEnum typeEnum, String menuName, Long parentId, Integer status) {
|
||||||
SysMenuDO sonMenuDO = RandomUtils.randomPojo(SysMenuDO.class, o -> {
|
return RandomUtils.randomPojo(SysMenuDO.class, o -> {
|
||||||
o.setId(id);
|
o.setId(id);
|
||||||
o.setParentId(parentId);
|
o.setParentId(parentId);
|
||||||
o.setType(typeEnum.getType());
|
o.setType(typeEnum.getType());
|
||||||
o.setStatus(status);
|
o.setStatus(status);
|
||||||
o.setName(menuName);
|
o.setName(menuName);
|
||||||
});
|
});
|
||||||
return sonMenuDO;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -3,10 +3,7 @@ package cn.iocoder.dashboard.modules.system.service.sms;
|
|||||||
import cn.iocoder.dashboard.BaseDbUnitTest;
|
import cn.iocoder.dashboard.BaseDbUnitTest;
|
||||||
import cn.iocoder.dashboard.common.enums.CommonStatusEnum;
|
import cn.iocoder.dashboard.common.enums.CommonStatusEnum;
|
||||||
import cn.iocoder.dashboard.common.pojo.PageResult;
|
import cn.iocoder.dashboard.common.pojo.PageResult;
|
||||||
import cn.iocoder.dashboard.modules.system.controller.sms.vo.template.SysSmsTemplateCreateReqVO;
|
import cn.iocoder.dashboard.modules.system.controller.sms.vo.template.*;
|
||||||
import cn.iocoder.dashboard.modules.system.controller.sms.vo.template.SysSmsTemplateExportReqVO;
|
|
||||||
import cn.iocoder.dashboard.modules.system.controller.sms.vo.template.SysSmsTemplatePageReqVO;
|
|
||||||
import cn.iocoder.dashboard.modules.system.controller.sms.vo.template.SysSmsTemplateUpdateReqVO;
|
|
||||||
import cn.iocoder.dashboard.modules.system.dal.dataobject.sms.SysSmsChannelDO;
|
import cn.iocoder.dashboard.modules.system.dal.dataobject.sms.SysSmsChannelDO;
|
||||||
import cn.iocoder.dashboard.modules.system.dal.dataobject.sms.SysSmsTemplateDO;
|
import cn.iocoder.dashboard.modules.system.dal.dataobject.sms.SysSmsTemplateDO;
|
||||||
import cn.iocoder.dashboard.modules.system.dal.mysql.sms.SysSmsTemplateMapper;
|
import cn.iocoder.dashboard.modules.system.dal.mysql.sms.SysSmsTemplateMapper;
|
||||||
@ -24,11 +21,11 @@ import java.util.List;
|
|||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
|
|
||||||
import static cn.hutool.core.util.RandomUtil.randomEle;
|
import static cn.hutool.core.util.RandomUtil.randomEle;
|
||||||
import static cn.iocoder.dashboard.modules.system.enums.SysErrorCodeConstants.SMS_TEMPLATE_NOT_EXISTS;
|
import static cn.iocoder.dashboard.modules.system.enums.SysErrorCodeConstants.*;
|
||||||
import static cn.iocoder.dashboard.util.AssertUtils.assertPojoEquals;
|
import static cn.iocoder.dashboard.util.AssertUtils.assertPojoEquals;
|
||||||
import static cn.iocoder.dashboard.util.AssertUtils.assertServiceException;
|
import static cn.iocoder.dashboard.util.AssertUtils.assertServiceException;
|
||||||
import static cn.iocoder.dashboard.util.RandomUtils.randomLongId;
|
import static cn.iocoder.dashboard.util.RandomUtils.*;
|
||||||
import static cn.iocoder.dashboard.util.RandomUtils.randomPojo;
|
import static cn.iocoder.dashboard.util.date.DateUtils.buildTime;
|
||||||
import static org.junit.jupiter.api.Assertions.*;
|
import static org.junit.jupiter.api.Assertions.*;
|
||||||
import static org.mockito.ArgumentMatchers.eq;
|
import static org.mockito.ArgumentMatchers.eq;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
@ -91,18 +88,29 @@ public class SysSmsTemplateServiceTest extends BaseDbUnitTest {
|
|||||||
@Test
|
@Test
|
||||||
public void testUpdateSmsTemplate_success() {
|
public void testUpdateSmsTemplate_success() {
|
||||||
// mock 数据
|
// mock 数据
|
||||||
SysSmsTemplateDO dbSmsTemplate = randomPojo(SysSmsTemplateDO.class);
|
SysSmsTemplateDO dbSmsTemplate = randomSmsTemplateDO();
|
||||||
smsTemplateMapper.insert(dbSmsTemplate);// @Sql: 先插入出一条存在的数据
|
smsTemplateMapper.insert(dbSmsTemplate);// @Sql: 先插入出一条存在的数据
|
||||||
// 准备参数
|
// 准备参数
|
||||||
SysSmsTemplateUpdateReqVO reqVO = randomPojo(SysSmsTemplateUpdateReqVO.class, o -> {
|
SysSmsTemplateUpdateReqVO reqVO = randomPojo(SysSmsTemplateUpdateReqVO.class, o -> {
|
||||||
o.setId(dbSmsTemplate.getId()); // 设置更新的 ID
|
o.setId(dbSmsTemplate.getId()); // 设置更新的 ID
|
||||||
|
o.setContent("正在进行登录操作{operation},您的验证码是{code}");
|
||||||
|
o.setStatus(randomEle(CommonStatusEnum.values()).getStatus()); // 保证 status 的范围
|
||||||
|
o.setType(randomEle(SysSmsTemplateTypeEnum.values()).getType()); // 保证 type 的泛微
|
||||||
});
|
});
|
||||||
|
// mock 方法
|
||||||
|
SysSmsChannelDO channelDO = randomPojo(SysSmsChannelDO.class, o -> {
|
||||||
|
o.setId(reqVO.getChannelId());
|
||||||
|
o.setStatus(CommonStatusEnum.ENABLE.getStatus()); // 保证 status 开启,创建必须处于这个状态
|
||||||
|
});
|
||||||
|
when(smsChannelService.getSmsChannel(eq(channelDO.getId()))).thenReturn(channelDO);
|
||||||
|
|
||||||
// 调用
|
// 调用
|
||||||
smsTemplateService.updateSmsTemplate(reqVO);
|
smsTemplateService.updateSmsTemplate(reqVO);
|
||||||
// 校验是否更新正确
|
// 校验是否更新正确
|
||||||
SysSmsTemplateDO smsTemplate = smsTemplateMapper.selectById(reqVO.getId()); // 获取最新的
|
SysSmsTemplateDO smsTemplate = smsTemplateMapper.selectById(reqVO.getId()); // 获取最新的
|
||||||
assertPojoEquals(reqVO, smsTemplate);
|
assertPojoEquals(reqVO, smsTemplate);
|
||||||
|
assertEquals(Lists.newArrayList("operation", "code"), smsTemplate.getParams());
|
||||||
|
assertEquals(channelDO.getCode(), smsTemplate.getChannelCode());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@ -137,43 +145,43 @@ public class SysSmsTemplateServiceTest extends BaseDbUnitTest {
|
|||||||
assertServiceException(() -> smsTemplateService.deleteSmsTemplate(id), SMS_TEMPLATE_NOT_EXISTS);
|
assertServiceException(() -> smsTemplateService.deleteSmsTemplate(id), SMS_TEMPLATE_NOT_EXISTS);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test // TODO 请修改 null 为需要的值
|
@Test
|
||||||
public void testGetSmsTemplatePage() {
|
public void testGetSmsTemplatePage() {
|
||||||
// mock 数据
|
// mock 数据
|
||||||
SysSmsTemplateDO dbSmsTemplate = randomPojo(SysSmsTemplateDO.class, o -> { // 等会查询到
|
SysSmsTemplateDO dbSmsTemplate = randomPojo(SysSmsTemplateDO.class, o -> { // 等会查询到
|
||||||
o.setType(null);
|
o.setType(SysSmsTemplateTypeEnum.PROMOTION.getType());
|
||||||
o.setStatus(null);
|
o.setStatus(CommonStatusEnum.ENABLE.getStatus());
|
||||||
o.setCode(null);
|
o.setCode("yudaoyuanma");
|
||||||
o.setContent(null);
|
o.setContent("芋道源码");
|
||||||
o.setApiTemplateId(null);
|
o.setApiTemplateId("yunai");
|
||||||
o.setChannelId(null);
|
o.setChannelId(1L);
|
||||||
o.setCreateTime(null);
|
o.setCreateTime(buildTime(2021, 11, 11));
|
||||||
});
|
});
|
||||||
smsTemplateMapper.insert(dbSmsTemplate);
|
smsTemplateMapper.insert(dbSmsTemplate);
|
||||||
// 测试 type 不匹配
|
// 测试 type 不匹配
|
||||||
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setType(null)));
|
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setType(SysSmsTemplateTypeEnum.VERIFICATION_CODE.getType())));
|
||||||
// 测试 status 不匹配
|
// 测试 status 不匹配
|
||||||
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setStatus(null)));
|
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setStatus(CommonStatusEnum.DISABLE.getStatus())));
|
||||||
// 测试 code 不匹配
|
// 测试 code 不匹配
|
||||||
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setCode(null)));
|
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setCode("yuanma")));
|
||||||
// 测试 content 不匹配
|
// 测试 content 不匹配
|
||||||
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setContent(null)));
|
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setContent("源码")));
|
||||||
// 测试 apiTemplateId 不匹配
|
// 测试 apiTemplateId 不匹配
|
||||||
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setApiTemplateId(null)));
|
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setApiTemplateId("nai")));
|
||||||
// 测试 channelId 不匹配
|
// 测试 channelId 不匹配
|
||||||
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setChannelId(null)));
|
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setChannelId(2L)));
|
||||||
// 测试 createTime 不匹配
|
// 测试 createTime 不匹配
|
||||||
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setCreateTime(null)));
|
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setCreateTime(buildTime(2021, 12, 12))));
|
||||||
// 准备参数
|
// 准备参数
|
||||||
SysSmsTemplatePageReqVO reqVO = new SysSmsTemplatePageReqVO();
|
SysSmsTemplatePageReqVO reqVO = new SysSmsTemplatePageReqVO();
|
||||||
reqVO.setType(null);
|
reqVO.setType(SysSmsTemplateTypeEnum.PROMOTION.getType());
|
||||||
reqVO.setStatus(null);
|
reqVO.setStatus(CommonStatusEnum.ENABLE.getStatus());
|
||||||
reqVO.setCode(null);
|
reqVO.setCode("yudao");
|
||||||
reqVO.setContent(null);
|
reqVO.setContent("芋道");
|
||||||
reqVO.setApiTemplateId(null);
|
reqVO.setApiTemplateId("yu");
|
||||||
reqVO.setChannelId(null);
|
reqVO.setChannelId(1L);
|
||||||
reqVO.setBeginCreateTime(null);
|
reqVO.setBeginCreateTime(buildTime(2021, 11, 1));
|
||||||
reqVO.setEndCreateTime(null);
|
reqVO.setEndCreateTime(buildTime(2021, 12, 1));
|
||||||
|
|
||||||
// 调用
|
// 调用
|
||||||
PageResult<SysSmsTemplateDO> pageResult = smsTemplateService.getSmsTemplatePage(reqVO);
|
PageResult<SysSmsTemplateDO> pageResult = smsTemplateService.getSmsTemplatePage(reqVO);
|
||||||
@ -183,43 +191,43 @@ public class SysSmsTemplateServiceTest extends BaseDbUnitTest {
|
|||||||
assertPojoEquals(dbSmsTemplate, pageResult.getList().get(0));
|
assertPojoEquals(dbSmsTemplate, pageResult.getList().get(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test // TODO 请修改 null 为需要的值
|
@Test
|
||||||
public void testGetSmsTemplateList() {
|
public void testGetSmsTemplateList() {
|
||||||
// mock 数据
|
// mock 数据
|
||||||
SysSmsTemplateDO dbSmsTemplate = randomPojo(SysSmsTemplateDO.class, o -> { // 等会查询到
|
SysSmsTemplateDO dbSmsTemplate = randomPojo(SysSmsTemplateDO.class, o -> { // 等会查询到
|
||||||
o.setType(null);
|
o.setType(SysSmsTemplateTypeEnum.PROMOTION.getType());
|
||||||
o.setStatus(null);
|
o.setStatus(CommonStatusEnum.ENABLE.getStatus());
|
||||||
o.setCode(null);
|
o.setCode("yudaoyuanma");
|
||||||
o.setContent(null);
|
o.setContent("芋道源码");
|
||||||
o.setApiTemplateId(null);
|
o.setApiTemplateId("yunai");
|
||||||
o.setChannelId(null);
|
o.setChannelId(1L);
|
||||||
o.setCreateTime(null);
|
o.setCreateTime(buildTime(2021, 11, 11));
|
||||||
});
|
});
|
||||||
smsTemplateMapper.insert(dbSmsTemplate);
|
smsTemplateMapper.insert(dbSmsTemplate);
|
||||||
// 测试 type 不匹配
|
// 测试 type 不匹配
|
||||||
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setType(null)));
|
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setType(SysSmsTemplateTypeEnum.VERIFICATION_CODE.getType())));
|
||||||
// 测试 status 不匹配
|
// 测试 status 不匹配
|
||||||
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setStatus(null)));
|
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setStatus(CommonStatusEnum.DISABLE.getStatus())));
|
||||||
// 测试 code 不匹配
|
// 测试 code 不匹配
|
||||||
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setCode(null)));
|
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setCode("yuanma")));
|
||||||
// 测试 content 不匹配
|
// 测试 content 不匹配
|
||||||
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setContent(null)));
|
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setContent("源码")));
|
||||||
// 测试 apiTemplateId 不匹配
|
// 测试 apiTemplateId 不匹配
|
||||||
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setApiTemplateId(null)));
|
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setApiTemplateId("nai")));
|
||||||
// 测试 channelId 不匹配
|
// 测试 channelId 不匹配
|
||||||
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setChannelId(null)));
|
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setChannelId(2L)));
|
||||||
// 测试 createTime 不匹配
|
// 测试 createTime 不匹配
|
||||||
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setCreateTime(null)));
|
smsTemplateMapper.insert(ObjectUtils.clone(dbSmsTemplate, o -> o.setCreateTime(buildTime(2021, 12, 12))));
|
||||||
// 准备参数
|
// 准备参数
|
||||||
SysSmsTemplateExportReqVO reqVO = new SysSmsTemplateExportReqVO();
|
SysSmsTemplateExportReqVO reqVO = new SysSmsTemplateExportReqVO();
|
||||||
reqVO.setType(null);
|
reqVO.setType(SysSmsTemplateTypeEnum.PROMOTION.getType());
|
||||||
reqVO.setStatus(null);
|
reqVO.setStatus(CommonStatusEnum.ENABLE.getStatus());
|
||||||
reqVO.setCode(null);
|
reqVO.setCode("yudao");
|
||||||
reqVO.setContent(null);
|
reqVO.setContent("芋道");
|
||||||
reqVO.setApiTemplateId(null);
|
reqVO.setApiTemplateId("yu");
|
||||||
reqVO.setChannelId(null);
|
reqVO.setChannelId(1L);
|
||||||
reqVO.setBeginCreateTime(null);
|
reqVO.setBeginCreateTime(buildTime(2021, 11, 1));
|
||||||
reqVO.setEndCreateTime(null);
|
reqVO.setEndCreateTime(buildTime(2021, 12, 1));
|
||||||
|
|
||||||
// 调用
|
// 调用
|
||||||
List<SysSmsTemplateDO> list = smsTemplateService.getSmsTemplateList(reqVO);
|
List<SysSmsTemplateDO> list = smsTemplateService.getSmsTemplateList(reqVO);
|
||||||
@ -228,6 +236,82 @@ public class SysSmsTemplateServiceTest extends BaseDbUnitTest {
|
|||||||
assertPojoEquals(dbSmsTemplate, list.get(0));
|
assertPojoEquals(dbSmsTemplate, list.get(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testCheckSmsChannel_success() {
|
||||||
|
// 准备参数
|
||||||
|
Long channelId = randomLongId();
|
||||||
|
// mock 方法
|
||||||
|
SysSmsChannelDO channelDO = randomPojo(SysSmsChannelDO.class, o -> {
|
||||||
|
o.setId(channelId);
|
||||||
|
o.setStatus(CommonStatusEnum.ENABLE.getStatus()); // 保证 status 开启,创建必须处于这个状态
|
||||||
|
});
|
||||||
|
when(smsChannelService.getSmsChannel(eq(channelId))).thenReturn(channelDO);
|
||||||
|
|
||||||
|
// 调用
|
||||||
|
SysSmsChannelDO returnChannelDO = smsTemplateService.checkSmsChannel(channelId);
|
||||||
|
// 断言
|
||||||
|
assertPojoEquals(returnChannelDO, channelDO);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testCheckSmsChannel_notExists() {
|
||||||
|
// 准备参数
|
||||||
|
Long channelId = randomLongId();
|
||||||
|
|
||||||
|
// 调用,校验异常
|
||||||
|
assertServiceException(() -> smsTemplateService.checkSmsChannel(channelId),
|
||||||
|
SMS_CHANNEL_NOT_EXISTS);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testCheckSmsChannel_disable() {
|
||||||
|
// 准备参数
|
||||||
|
Long channelId = randomLongId();
|
||||||
|
// mock 方法
|
||||||
|
SysSmsChannelDO channelDO = randomPojo(SysSmsChannelDO.class, o -> {
|
||||||
|
o.setId(channelId);
|
||||||
|
o.setStatus(CommonStatusEnum.DISABLE.getStatus()); // 保证 status 禁用,触发失败
|
||||||
|
});
|
||||||
|
when(smsChannelService.getSmsChannel(eq(channelId))).thenReturn(channelDO);
|
||||||
|
|
||||||
|
// 调用,校验异常
|
||||||
|
assertServiceException(() -> smsTemplateService.checkSmsChannel(channelId),
|
||||||
|
SMS_CHANNEL_DISABLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testCheckDictDataValueUnique_success() {
|
||||||
|
// 调用,成功
|
||||||
|
smsTemplateService.checkSmsTemplateCodeDuplicate(randomLongId(), randomString());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testCheckDictDataValueUnique_valueDuplicateForCreate() {
|
||||||
|
// 准备参数
|
||||||
|
String code = randomString();
|
||||||
|
// mock 数据
|
||||||
|
smsTemplateMapper.insert(randomSmsTemplateDO(o -> o.setCode(code)));
|
||||||
|
|
||||||
|
// 调用,校验异常
|
||||||
|
assertServiceException(() -> smsTemplateService.checkSmsTemplateCodeDuplicate(null, code),
|
||||||
|
SMS_TEMPLATE_CODE_DUPLICATE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testCheckDictDataValueUnique_valueDuplicateForUpdate() {
|
||||||
|
// 准备参数
|
||||||
|
Long id = randomLongId();
|
||||||
|
String code = randomString();
|
||||||
|
// mock 数据
|
||||||
|
smsTemplateMapper.insert(randomSmsTemplateDO(o -> o.setCode(code)));
|
||||||
|
|
||||||
|
// 调用,校验异常
|
||||||
|
assertServiceException(() -> smsTemplateService.checkSmsTemplateCodeDuplicate(id, code),
|
||||||
|
SMS_TEMPLATE_CODE_DUPLICATE);
|
||||||
|
}
|
||||||
|
|
||||||
|
// ========== 随机对象 ==========
|
||||||
|
|
||||||
@SafeVarargs
|
@SafeVarargs
|
||||||
private static SysSmsTemplateDO randomSmsTemplateDO(Consumer<SysSmsTemplateDO>... consumers) {
|
private static SysSmsTemplateDO randomSmsTemplateDO(Consumer<SysSmsTemplateDO>... consumers) {
|
||||||
Consumer<SysSmsTemplateDO> consumer = (o) -> {
|
Consumer<SysSmsTemplateDO> consumer = (o) -> {
|
||||||
|
@ -20,3 +20,4 @@ DELETE FROM "sys_login_log";
|
|||||||
DELETE FROM "sys_operate_log";
|
DELETE FROM "sys_operate_log";
|
||||||
DELETE FROM "sys_user";
|
DELETE FROM "sys_user";
|
||||||
DELETE FROM "sys_sms_channel";
|
DELETE FROM "sys_sms_channel";
|
||||||
|
DELETE FROM "sys_sms_template";
|
||||||
|
Loading…
Reference in New Issue
Block a user