BPM Form 表单的完善
parent
69a6aa251b
commit
930c5ec490
@ -1,34 +0,0 @@
|
|||||||
package cn.iocoder.yudao.adminserver.modules.bpm.controller.form.vo;
|
|
||||||
|
|
||||||
import com.alibaba.excel.annotation.ExcelProperty;
|
|
||||||
import lombok.Data;
|
|
||||||
|
|
||||||
import java.util.Date;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 动态表单 Excel VO
|
|
||||||
*
|
|
||||||
* @author 芋艿
|
|
||||||
*/
|
|
||||||
@Data
|
|
||||||
public class BpmFormExcelVO {
|
|
||||||
|
|
||||||
@ExcelProperty("表单编号")
|
|
||||||
private Long id;
|
|
||||||
|
|
||||||
@ExcelProperty("表单名称")
|
|
||||||
private String name;
|
|
||||||
|
|
||||||
@ExcelProperty("商户状态")
|
|
||||||
private Integer status;
|
|
||||||
|
|
||||||
@ExcelProperty("表单JSON")
|
|
||||||
private String formJson;
|
|
||||||
|
|
||||||
@ExcelProperty("备注")
|
|
||||||
private String remark;
|
|
||||||
|
|
||||||
@ExcelProperty("创建时间")
|
|
||||||
private Date createTime;
|
|
||||||
|
|
||||||
}
|
|
||||||
@ -1,14 +0,0 @@
|
|||||||
package cn.iocoder.yudao.adminserver.modules.bpm.controller.form.vo;
|
|
||||||
|
|
||||||
import io.swagger.annotations.ApiModel;
|
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
|
||||||
import lombok.Data;
|
|
||||||
|
|
||||||
@ApiModel(value = "动态表单 Excel 导出 Request VO", description = "参数和 BpmFormPageReqVO 是一致的")
|
|
||||||
@Data
|
|
||||||
public class BpmFormExportReqVO {
|
|
||||||
|
|
||||||
@ApiModelProperty(value = "表单名称")
|
|
||||||
private String name;
|
|
||||||
|
|
||||||
}
|
|
||||||
@ -0,0 +1,122 @@
|
|||||||
|
package cn.iocoder.yudao.adminserver.modules.bpm.service.form;
|
||||||
|
|
||||||
|
import cn.iocoder.yudao.adminserver.BaseDbUnitTest;
|
||||||
|
import cn.iocoder.yudao.adminserver.modules.bpm.controller.form.vo.BpmFormCreateReqVO;
|
||||||
|
import cn.iocoder.yudao.adminserver.modules.bpm.controller.form.vo.BpmFormPageReqVO;
|
||||||
|
import cn.iocoder.yudao.adminserver.modules.bpm.controller.form.vo.BpmFormUpdateReqVO;
|
||||||
|
import cn.iocoder.yudao.adminserver.modules.bpm.dal.dataobject.form.BpmFormDO;
|
||||||
|
import cn.iocoder.yudao.adminserver.modules.bpm.dal.mysql.form.BpmFormMapper;
|
||||||
|
import cn.iocoder.yudao.adminserver.modules.bpm.service.form.impl.BpmFormServiceImpl;
|
||||||
|
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.springframework.context.annotation.Import;
|
||||||
|
|
||||||
|
import javax.annotation.Resource;
|
||||||
|
|
||||||
|
import static cn.iocoder.yudao.adminserver.modules.bpm.enums.BpmErrorCodeConstants.BPM_FORM_NOT_EXISTS;
|
||||||
|
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.assertServiceException;
|
||||||
|
import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.randomLongId;
|
||||||
|
import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.randomPojo;
|
||||||
|
import static org.junit.jupiter.api.Assertions.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@link BpmFormServiceImpl} 的单元测试类
|
||||||
|
*
|
||||||
|
* @author 芋道源码
|
||||||
|
*/
|
||||||
|
@Import(BpmFormServiceImpl.class)
|
||||||
|
public class BpmFormServiceTest extends BaseDbUnitTest {
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private BpmFormServiceImpl formService;
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private BpmFormMapper formMapper;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testCreateForm_success() {
|
||||||
|
// 准备参数
|
||||||
|
BpmFormCreateReqVO reqVO = randomPojo(BpmFormCreateReqVO.class);
|
||||||
|
|
||||||
|
// 调用
|
||||||
|
Long formId = formService.createForm(reqVO);
|
||||||
|
// 断言
|
||||||
|
assertNotNull(formId);
|
||||||
|
// 校验记录的属性是否正确
|
||||||
|
BpmFormDO form = formMapper.selectById(formId);
|
||||||
|
assertPojoEquals(reqVO, form);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testUpdateForm_success() {
|
||||||
|
// mock 数据
|
||||||
|
BpmFormDO dbForm = randomPojo(BpmFormDO.class);
|
||||||
|
formMapper.insert(dbForm);// @Sql: 先插入出一条存在的数据
|
||||||
|
// 准备参数
|
||||||
|
BpmFormUpdateReqVO reqVO = randomPojo(BpmFormUpdateReqVO.class, o -> {
|
||||||
|
o.setId(dbForm.getId()); // 设置更新的 ID
|
||||||
|
});
|
||||||
|
|
||||||
|
// 调用
|
||||||
|
formService.updateForm(reqVO);
|
||||||
|
// 校验是否更新正确
|
||||||
|
BpmFormDO form = formMapper.selectById(reqVO.getId()); // 获取最新的
|
||||||
|
assertPojoEquals(reqVO, form);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testUpdateForm_notExists() {
|
||||||
|
// 准备参数
|
||||||
|
BpmFormUpdateReqVO reqVO = randomPojo(BpmFormUpdateReqVO.class);
|
||||||
|
|
||||||
|
// 调用, 并断言异常
|
||||||
|
assertServiceException(() -> formService.updateForm(reqVO), BPM_FORM_NOT_EXISTS);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testDeleteForm_success() {
|
||||||
|
// mock 数据
|
||||||
|
BpmFormDO dbForm = randomPojo(BpmFormDO.class);
|
||||||
|
formMapper.insert(dbForm);// @Sql: 先插入出一条存在的数据
|
||||||
|
// 准备参数
|
||||||
|
Long id = dbForm.getId();
|
||||||
|
|
||||||
|
// 调用
|
||||||
|
formService.deleteForm(id);
|
||||||
|
// 校验数据不存在了
|
||||||
|
assertNull(formMapper.selectById(id));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testDeleteForm_notExists() {
|
||||||
|
// 准备参数
|
||||||
|
Long id = randomLongId();
|
||||||
|
|
||||||
|
// 调用, 并断言异常
|
||||||
|
assertServiceException(() -> formService.deleteForm(id), BPM_FORM_NOT_EXISTS);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetFormPage() {
|
||||||
|
// mock 数据
|
||||||
|
BpmFormDO dbForm = randomPojo(BpmFormDO.class, o -> { // 等会查询到
|
||||||
|
o.setName("芋道源码");
|
||||||
|
});
|
||||||
|
formMapper.insert(dbForm);
|
||||||
|
// 测试 name 不匹配
|
||||||
|
formMapper.insert(cloneIgnoreId(dbForm, o -> o.setName("源码")));
|
||||||
|
// 准备参数
|
||||||
|
BpmFormPageReqVO reqVO = new BpmFormPageReqVO();
|
||||||
|
reqVO.setName("芋道");
|
||||||
|
|
||||||
|
// 调用
|
||||||
|
PageResult<BpmFormDO> pageResult = formService.getFormPage(reqVO);
|
||||||
|
// 断言
|
||||||
|
assertEquals(1, pageResult.getTotal());
|
||||||
|
assertEquals(1, pageResult.getList().size());
|
||||||
|
assertPojoEquals(dbForm, pageResult.getList().get(0));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@ -0,0 +1 @@
|
|||||||
|
package cn.iocoder.yudao.adminserver.modules.bpm.service;
|
||||||
@ -1,29 +1,29 @@
|
|||||||
export default [
|
export default [
|
||||||
{
|
{
|
||||||
// layout: 'colFormItem',
|
layout: 'colFormItem',
|
||||||
// tagIcon: 'input',
|
tagIcon: 'input',
|
||||||
// label: '手机号',
|
label: '手机号',
|
||||||
// vModel: 'mobile',
|
vModel: 'mobile',
|
||||||
// formId: 6,
|
formId: 6,
|
||||||
// tag: 'el-input',
|
tag: 'el-input',
|
||||||
// placeholder: '请输入手机号',
|
placeholder: '请输入手机号',
|
||||||
// defaultValue: '',
|
defaultValue: '',
|
||||||
// span: 24,
|
span: 24,
|
||||||
// style: { width: '100%' },
|
style: { width: '100%' },
|
||||||
// clearable: true,
|
clearable: true,
|
||||||
// prepend: '',
|
prepend: '',
|
||||||
// append: '',
|
append: '',
|
||||||
// 'prefix-icon': 'el-icon-mobile',
|
'prefix-icon': 'el-icon-mobile',
|
||||||
// 'suffix-icon': '',
|
'suffix-icon': '',
|
||||||
// maxlength: 11,
|
maxlength: 11,
|
||||||
// 'show-word-limit': true,
|
'show-word-limit': true,
|
||||||
// readonly: false,
|
readonly: false,
|
||||||
// disabled: false,
|
disabled: false,
|
||||||
// required: true,
|
required: true,
|
||||||
// changeTag: true,
|
changeTag: true,
|
||||||
// regList: [{
|
regList: [{
|
||||||
// pattern: '/^1(3|4|5|7|8|9)\\d{9}$/',
|
pattern: '/^1(3|4|5|7|8|9)\\d{9}$/',
|
||||||
// message: '手机号格式错误'
|
message: '手机号格式错误'
|
||||||
// }]
|
}]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|||||||
Loading…
Reference in New Issue