|
|
|
@ -2,7 +2,6 @@ package cn.iocoder.yudao.module.infra.service.config;
|
|
|
|
|
|
|
|
|
|
|
|
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
|
|
|
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
|
|
|
import cn.iocoder.yudao.framework.common.util.collection.ArrayUtils;
|
|
|
|
import cn.iocoder.yudao.framework.common.util.collection.ArrayUtils;
|
|
|
|
import cn.iocoder.yudao.framework.common.util.object.ObjectUtils;
|
|
|
|
|
|
|
|
import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest;
|
|
|
|
import cn.iocoder.yudao.framework.test.core.ut.BaseDbUnitTest;
|
|
|
|
import cn.iocoder.yudao.framework.test.core.util.RandomUtils;
|
|
|
|
import cn.iocoder.yudao.framework.test.core.util.RandomUtils;
|
|
|
|
import cn.iocoder.yudao.module.infra.controller.admin.config.vo.ConfigCreateReqVO;
|
|
|
|
import cn.iocoder.yudao.module.infra.controller.admin.config.vo.ConfigCreateReqVO;
|
|
|
|
@ -12,24 +11,22 @@ import cn.iocoder.yudao.module.infra.controller.admin.config.vo.ConfigUpdateReqV
|
|
|
|
import cn.iocoder.yudao.module.infra.dal.dataobject.config.ConfigDO;
|
|
|
|
import cn.iocoder.yudao.module.infra.dal.dataobject.config.ConfigDO;
|
|
|
|
import cn.iocoder.yudao.module.infra.dal.mysql.config.ConfigMapper;
|
|
|
|
import cn.iocoder.yudao.module.infra.dal.mysql.config.ConfigMapper;
|
|
|
|
import cn.iocoder.yudao.module.infra.enums.config.ConfigTypeEnum;
|
|
|
|
import cn.iocoder.yudao.module.infra.enums.config.ConfigTypeEnum;
|
|
|
|
import org.junit.jupiter.api.Assertions;
|
|
|
|
|
|
|
|
import org.junit.jupiter.api.Test;
|
|
|
|
import org.junit.jupiter.api.Test;
|
|
|
|
import org.springframework.context.annotation.Import;
|
|
|
|
import org.springframework.context.annotation.Import;
|
|
|
|
|
|
|
|
|
|
|
|
import javax.annotation.Resource;
|
|
|
|
import javax.annotation.Resource;
|
|
|
|
import java.time.LocalDateTime;
|
|
|
|
|
|
|
|
import java.util.List;
|
|
|
|
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.yudao.framework.common.util.date.DateUtils.buildLocalDateTime;
|
|
|
|
import static cn.iocoder.yudao.framework.common.util.date.LocalDateTimeUtils.buildBetweenTime;
|
|
|
|
|
|
|
|
import static cn.iocoder.yudao.framework.common.util.date.LocalDateTimeUtils.buildTime;
|
|
|
|
|
|
|
|
import static cn.iocoder.yudao.framework.common.util.object.ObjectUtils.cloneIgnoreId;
|
|
|
|
import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.assertPojoEquals;
|
|
|
|
import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.assertPojoEquals;
|
|
|
|
import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.assertServiceException;
|
|
|
|
import static cn.iocoder.yudao.framework.test.core.util.AssertUtils.assertServiceException;
|
|
|
|
import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.*;
|
|
|
|
import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.*;
|
|
|
|
import static cn.iocoder.yudao.module.infra.enums.ErrorCodeConstants.*;
|
|
|
|
import static cn.iocoder.yudao.module.infra.enums.ErrorCodeConstants.*;
|
|
|
|
import static org.junit.jupiter.api.Assertions.*;
|
|
|
|
import static org.junit.jupiter.api.Assertions.*;
|
|
|
|
import static org.mockito.Mockito.times;
|
|
|
|
|
|
|
|
import static org.mockito.Mockito.verify;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Import(ConfigServiceImpl.class)
|
|
|
|
@Import(ConfigServiceImpl.class)
|
|
|
|
public class ConfigServiceTest extends BaseDbUnitTest {
|
|
|
|
public class ConfigServiceTest extends BaseDbUnitTest {
|
|
|
|
@ -52,7 +49,7 @@ public class ConfigServiceTest extends BaseDbUnitTest {
|
|
|
|
// 校验记录的属性是否正确
|
|
|
|
// 校验记录的属性是否正确
|
|
|
|
ConfigDO config = configMapper.selectById(configId);
|
|
|
|
ConfigDO config = configMapper.selectById(configId);
|
|
|
|
assertPojoEquals(reqVO, config);
|
|
|
|
assertPojoEquals(reqVO, config);
|
|
|
|
Assertions.assertEquals(ConfigTypeEnum.CUSTOM.getType(), config.getType());
|
|
|
|
assertEquals(ConfigTypeEnum.CUSTOM.getType(), config.getType());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
@ -103,40 +100,40 @@ public class ConfigServiceTest extends BaseDbUnitTest {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
public void testCheckConfigExists_success() {
|
|
|
|
public void testValidateConfigExists_success() {
|
|
|
|
// mock 数据
|
|
|
|
// mock 数据
|
|
|
|
ConfigDO dbConfigDO = randomConfigDO();
|
|
|
|
ConfigDO dbConfigDO = randomConfigDO();
|
|
|
|
configMapper.insert(dbConfigDO);// @Sql: 先插入出一条存在的数据
|
|
|
|
configMapper.insert(dbConfigDO);// @Sql: 先插入出一条存在的数据
|
|
|
|
|
|
|
|
|
|
|
|
// 调用成功
|
|
|
|
// 调用成功
|
|
|
|
configService.checkConfigExists(dbConfigDO.getId());
|
|
|
|
configService.validateConfigExists(dbConfigDO.getId());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
public void testCheckConfigExist_notExists() {
|
|
|
|
public void testValidateConfigExist_notExists() {
|
|
|
|
assertServiceException(() -> configService.checkConfigExists(randomLongId()), CONFIG_NOT_EXISTS);
|
|
|
|
assertServiceException(() -> configService.validateConfigExists(randomLongId()), CONFIG_NOT_EXISTS);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
public void testCheckConfigKeyUnique_success() {
|
|
|
|
public void testValidateConfigKeyUnique_success() {
|
|
|
|
// 调用,成功
|
|
|
|
// 调用,成功
|
|
|
|
configService.checkConfigKeyUnique(randomLongId(), randomString());
|
|
|
|
configService.validateConfigKeyUnique(randomLongId(), randomString());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
public void testCheckConfigKeyUnique_keyDuplicateForCreate() {
|
|
|
|
public void testValidateConfigKeyUnique_keyDuplicateForCreate() {
|
|
|
|
// 准备参数
|
|
|
|
// 准备参数
|
|
|
|
String key = randomString();
|
|
|
|
String key = randomString();
|
|
|
|
// mock 数据
|
|
|
|
// mock 数据
|
|
|
|
configMapper.insert(randomConfigDO(o -> o.setConfigKey(key)));
|
|
|
|
configMapper.insert(randomConfigDO(o -> o.setConfigKey(key)));
|
|
|
|
|
|
|
|
|
|
|
|
// 调用,校验异常
|
|
|
|
// 调用,校验异常
|
|
|
|
assertServiceException(() -> configService.checkConfigKeyUnique(null, key),
|
|
|
|
assertServiceException(() -> configService.validateConfigKeyUnique(null, key),
|
|
|
|
CONFIG_KEY_DUPLICATE);
|
|
|
|
CONFIG_KEY_DUPLICATE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
public void testCheckConfigKeyUnique_keyDuplicateForUpdate() {
|
|
|
|
public void testValidateConfigKeyUnique_keyDuplicateForUpdate() {
|
|
|
|
// 准备参数
|
|
|
|
// 准备参数
|
|
|
|
Long id = randomLongId();
|
|
|
|
Long id = randomLongId();
|
|
|
|
String key = randomString();
|
|
|
|
String key = randomString();
|
|
|
|
@ -144,7 +141,7 @@ public class ConfigServiceTest extends BaseDbUnitTest {
|
|
|
|
configMapper.insert(randomConfigDO(o -> o.setConfigKey(key)));
|
|
|
|
configMapper.insert(randomConfigDO(o -> o.setConfigKey(key)));
|
|
|
|
|
|
|
|
|
|
|
|
// 调用,校验异常
|
|
|
|
// 调用,校验异常
|
|
|
|
assertServiceException(() -> configService.checkConfigKeyUnique(id, key),
|
|
|
|
assertServiceException(() -> configService.validateConfigKeyUnique(id, key),
|
|
|
|
CONFIG_KEY_DUPLICATE);
|
|
|
|
CONFIG_KEY_DUPLICATE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@ -155,23 +152,23 @@ public class ConfigServiceTest extends BaseDbUnitTest {
|
|
|
|
o.setName("芋艿");
|
|
|
|
o.setName("芋艿");
|
|
|
|
o.setConfigKey("yunai");
|
|
|
|
o.setConfigKey("yunai");
|
|
|
|
o.setType(ConfigTypeEnum.SYSTEM.getType());
|
|
|
|
o.setType(ConfigTypeEnum.SYSTEM.getType());
|
|
|
|
o.setCreateTime(buildLocalDateTime(2021, 2, 1));
|
|
|
|
o.setCreateTime(buildTime(2021, 2, 1));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
configMapper.insert(dbConfig);
|
|
|
|
configMapper.insert(dbConfig);
|
|
|
|
// 测试 name 不匹配
|
|
|
|
// 测试 name 不匹配
|
|
|
|
configMapper.insert(ObjectUtils.cloneIgnoreId(dbConfig, o -> o.setName("土豆")));
|
|
|
|
configMapper.insert(cloneIgnoreId(dbConfig, o -> o.setName("土豆")));
|
|
|
|
// 测试 key 不匹配
|
|
|
|
// 测试 key 不匹配
|
|
|
|
configMapper.insert(ObjectUtils.cloneIgnoreId(dbConfig, o -> o.setConfigKey("tudou")));
|
|
|
|
configMapper.insert(cloneIgnoreId(dbConfig, o -> o.setConfigKey("tudou")));
|
|
|
|
// 测试 type 不匹配
|
|
|
|
// 测试 type 不匹配
|
|
|
|
configMapper.insert(ObjectUtils.cloneIgnoreId(dbConfig, o -> o.setType(ConfigTypeEnum.CUSTOM.getType())));
|
|
|
|
configMapper.insert(cloneIgnoreId(dbConfig, o -> o.setType(ConfigTypeEnum.CUSTOM.getType())));
|
|
|
|
// 测试 createTime 不匹配
|
|
|
|
// 测试 createTime 不匹配
|
|
|
|
configMapper.insert(ObjectUtils.cloneIgnoreId(dbConfig, o -> o.setCreateTime(buildLocalDateTime(2021, 1, 1))));
|
|
|
|
configMapper.insert(cloneIgnoreId(dbConfig, o -> o.setCreateTime(buildTime(2021, 1, 1))));
|
|
|
|
// 准备参数
|
|
|
|
// 准备参数
|
|
|
|
ConfigPageReqVO reqVO = new ConfigPageReqVO();
|
|
|
|
ConfigPageReqVO reqVO = new ConfigPageReqVO();
|
|
|
|
reqVO.setName("艿");
|
|
|
|
reqVO.setName("艿");
|
|
|
|
reqVO.setKey("nai");
|
|
|
|
reqVO.setKey("nai");
|
|
|
|
reqVO.setType(ConfigTypeEnum.SYSTEM.getType());
|
|
|
|
reqVO.setType(ConfigTypeEnum.SYSTEM.getType());
|
|
|
|
reqVO.setCreateTime((new LocalDateTime[]{buildLocalDateTime(2021, 1, 15),buildLocalDateTime(2021, 2, 15)}));
|
|
|
|
reqVO.setCreateTime(buildBetweenTime(2021, 1, 15, 2021, 2, 15));
|
|
|
|
|
|
|
|
|
|
|
|
// 调用
|
|
|
|
// 调用
|
|
|
|
PageResult<ConfigDO> pageResult = configService.getConfigPage(reqVO);
|
|
|
|
PageResult<ConfigDO> pageResult = configService.getConfigPage(reqVO);
|
|
|
|
@ -188,23 +185,23 @@ public class ConfigServiceTest extends BaseDbUnitTest {
|
|
|
|
o.setName("芋艿");
|
|
|
|
o.setName("芋艿");
|
|
|
|
o.setConfigKey("yunai");
|
|
|
|
o.setConfigKey("yunai");
|
|
|
|
o.setType(ConfigTypeEnum.SYSTEM.getType());
|
|
|
|
o.setType(ConfigTypeEnum.SYSTEM.getType());
|
|
|
|
o.setCreateTime(buildLocalDateTime(2021, 2, 1));
|
|
|
|
o.setCreateTime(buildTime(2021, 2, 1));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
configMapper.insert(dbConfig);
|
|
|
|
configMapper.insert(dbConfig);
|
|
|
|
// 测试 name 不匹配
|
|
|
|
// 测试 name 不匹配
|
|
|
|
configMapper.insert(ObjectUtils.cloneIgnoreId(dbConfig, o -> o.setName("土豆")));
|
|
|
|
configMapper.insert(cloneIgnoreId(dbConfig, o -> o.setName("土豆")));
|
|
|
|
// 测试 key 不匹配
|
|
|
|
// 测试 key 不匹配
|
|
|
|
configMapper.insert(ObjectUtils.cloneIgnoreId(dbConfig, o -> o.setConfigKey("tudou")));
|
|
|
|
configMapper.insert(cloneIgnoreId(dbConfig, o -> o.setConfigKey("tudou")));
|
|
|
|
// 测试 type 不匹配
|
|
|
|
// 测试 type 不匹配
|
|
|
|
configMapper.insert(ObjectUtils.cloneIgnoreId(dbConfig, o -> o.setType(ConfigTypeEnum.CUSTOM.getType())));
|
|
|
|
configMapper.insert(cloneIgnoreId(dbConfig, o -> o.setType(ConfigTypeEnum.CUSTOM.getType())));
|
|
|
|
// 测试 createTime 不匹配
|
|
|
|
// 测试 createTime 不匹配
|
|
|
|
configMapper.insert(ObjectUtils.cloneIgnoreId(dbConfig, o -> o.setCreateTime(buildLocalDateTime(2021, 1, 1))));
|
|
|
|
configMapper.insert(cloneIgnoreId(dbConfig, o -> o.setCreateTime(buildTime(2021, 1, 1))));
|
|
|
|
// 准备参数
|
|
|
|
// 准备参数
|
|
|
|
ConfigExportReqVO reqVO = new ConfigExportReqVO();
|
|
|
|
ConfigExportReqVO reqVO = new ConfigExportReqVO();
|
|
|
|
reqVO.setName("艿");
|
|
|
|
reqVO.setName("艿");
|
|
|
|
reqVO.setKey("nai");
|
|
|
|
reqVO.setKey("nai");
|
|
|
|
reqVO.setType(ConfigTypeEnum.SYSTEM.getType());
|
|
|
|
reqVO.setType(ConfigTypeEnum.SYSTEM.getType());
|
|
|
|
reqVO.setCreateTime((new LocalDateTime[]{buildLocalDateTime(2021, 1, 15),buildLocalDateTime(2021, 2, 15)}));
|
|
|
|
reqVO.setCreateTime(buildBetweenTime(2021, 1, 15, 2021, 2, 15));
|
|
|
|
|
|
|
|
|
|
|
|
// 调用
|
|
|
|
// 调用
|
|
|
|
List<ConfigDO> list = configService.getConfigList(reqVO);
|
|
|
|
List<ConfigDO> list = configService.getConfigList(reqVO);
|
|
|
|
@ -213,6 +210,21 @@ public class ConfigServiceTest extends BaseDbUnitTest {
|
|
|
|
assertPojoEquals(dbConfig, list.get(0));
|
|
|
|
assertPojoEquals(dbConfig, list.get(0));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
|
|
|
public void testGetConfig() {
|
|
|
|
|
|
|
|
// mock 数据
|
|
|
|
|
|
|
|
ConfigDO dbConfig = randomConfigDO();
|
|
|
|
|
|
|
|
configMapper.insert(dbConfig);// @Sql: 先插入出一条存在的数据
|
|
|
|
|
|
|
|
// 准备参数
|
|
|
|
|
|
|
|
Long id = dbConfig.getId();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 调用
|
|
|
|
|
|
|
|
ConfigDO config = configService.getConfig(id);
|
|
|
|
|
|
|
|
// 断言
|
|
|
|
|
|
|
|
assertNotNull(config);
|
|
|
|
|
|
|
|
assertPojoEquals(dbConfig, config);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@Test
|
|
|
|
public void testGetConfigByKey() {
|
|
|
|
public void testGetConfigByKey() {
|
|
|
|
// mock 数据
|
|
|
|
// mock 数据
|
|
|
|
|