commit
3f7b71623b
@ -1,10 +0,0 @@
|
|||||||
{
|
|
||||||
"systemParams": "win32-x64-93",
|
|
||||||
"modulesFolders": [],
|
|
||||||
"flags": [],
|
|
||||||
"linkedModules": [],
|
|
||||||
"topLevelPatterns": [],
|
|
||||||
"lockfileEntries": {},
|
|
||||||
"files": [],
|
|
||||||
"artifacts": {}
|
|
||||||
}
|
|
@ -0,0 +1,81 @@
|
|||||||
|
package com.yunxi.scm.framework.excel.core.convert;
|
||||||
|
|
||||||
|
import cn.hutool.core.collection.CollUtil;
|
||||||
|
import cn.hutool.core.util.StrUtil;
|
||||||
|
import com.alibaba.excel.converters.Converter;
|
||||||
|
import com.alibaba.excel.enums.CellDataTypeEnum;
|
||||||
|
import com.alibaba.excel.metadata.GlobalConfiguration;
|
||||||
|
import com.alibaba.excel.metadata.data.ReadCellData;
|
||||||
|
import com.alibaba.excel.metadata.data.WriteCellData;
|
||||||
|
import com.alibaba.excel.metadata.property.ExcelContentProperty;
|
||||||
|
import com.yunxi.scm.framework.dict.core.util.DictFrameworkUtils;
|
||||||
|
import com.yunxi.scm.framework.excel.core.annotations.DictFormat;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
@Slf4j
|
||||||
|
public class MutilDictConvert implements Converter<List<String>> {
|
||||||
|
|
||||||
|
// 分隔符
|
||||||
|
private static final String COMMA = ",";
|
||||||
|
|
||||||
|
// 指定转化参数的Java类型
|
||||||
|
@Override
|
||||||
|
public Class<?> supportJavaTypeKey() {
|
||||||
|
return List.class;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 指定转化参数对应的单元格类型
|
||||||
|
@Override
|
||||||
|
public CellDataTypeEnum supportExcelTypeKey() {
|
||||||
|
return CellDataTypeEnum.STRING;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<String> convertToJavaData(ReadCellData readCellData, ExcelContentProperty contentProperty,
|
||||||
|
GlobalConfiguration globalConfiguration) {
|
||||||
|
// 使用字典解析
|
||||||
|
String type = getType(contentProperty);
|
||||||
|
String strings = readCellData.getStringValue();
|
||||||
|
// Class<?> fieldClazz = contentProperty.getField().getType(); // 获取被注解的字段类型
|
||||||
|
List<String> labels = StrUtil.splitTrim(strings, COMMA);
|
||||||
|
List<String> values = new ArrayList<>();
|
||||||
|
for(String label : labels) {
|
||||||
|
String value = DictFrameworkUtils.parseDictDataValue(type, label);
|
||||||
|
if (value == null) {
|
||||||
|
log.error("[convertToJavaData][type({}) 解析不掉 label({})]", type, label);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
values.add(value);
|
||||||
|
}
|
||||||
|
// return Convert.convert(fieldClazz, value); // 类型转换
|
||||||
|
return values;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public WriteCellData<String> convertToExcelData(List<String> values, ExcelContentProperty contentProperty,
|
||||||
|
GlobalConfiguration globalConfiguration) {
|
||||||
|
// 空时,返回空
|
||||||
|
if (values == null || values.isEmpty()) {
|
||||||
|
return new WriteCellData<>("");
|
||||||
|
}
|
||||||
|
// 使用字典格式化
|
||||||
|
String type = getType(contentProperty);
|
||||||
|
List<String> labels = new ArrayList<>();
|
||||||
|
for(String value : values) {
|
||||||
|
String label = DictFrameworkUtils.getDictDataLabel(type, value);
|
||||||
|
if (label == null) {
|
||||||
|
log.error("[convertToExcelData][type({}) 转换不了 label({})]", type, value);
|
||||||
|
} else {
|
||||||
|
labels.add(label);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// 生成 Excel 小表格
|
||||||
|
return new WriteCellData<>(CollUtil.join(labels, COMMA));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static String getType(ExcelContentProperty contentProperty) {
|
||||||
|
return contentProperty.getField().getAnnotation(DictFormat.class).value();
|
||||||
|
}
|
||||||
|
}
|
@ -1,18 +0,0 @@
|
|||||||
package com.yunxi.scm.module.demo.enums;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* System 字典类型的枚举类
|
|
||||||
*
|
|
||||||
* @author 芋道源码
|
|
||||||
*/
|
|
||||||
public interface DictTypeConstants {
|
|
||||||
|
|
||||||
String USER_TYPE = "user_type"; // 用户类型
|
|
||||||
String COMMON_STATUS = "common_status"; // 系统状态
|
|
||||||
|
|
||||||
String MATERIAL_STATUS = "material_status"; // 物料状态
|
|
||||||
|
|
||||||
// ========== SYSTEM 模块 ==========
|
|
||||||
String TRADE_ORDER_TYPE = "trade_order_type"; // 订单交易类型
|
|
||||||
|
|
||||||
}
|
|
@ -1,64 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
|
||||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
|
||||||
<parent>
|
|
||||||
<artifactId>yunxi-module-demo</artifactId>
|
|
||||||
<groupId>com.yunxi.scm</groupId>
|
|
||||||
<version>${revision}</version>
|
|
||||||
</parent>
|
|
||||||
<modelVersion>4.0.0</modelVersion>
|
|
||||||
<packaging>jar</packaging>
|
|
||||||
|
|
||||||
<artifactId>yunxi-module-demo-biz</artifactId>
|
|
||||||
|
|
||||||
<name>${project.artifactId}</name>
|
|
||||||
<description>
|
|
||||||
demo 模块,主要实现 XXX、YYY、ZZZ 等功能。
|
|
||||||
</description>
|
|
||||||
|
|
||||||
<!-- 新增依赖,这里引入的都是比较常用的业务组件、技术组件 -->
|
|
||||||
<dependencies>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.yunxi.scm</groupId>
|
|
||||||
<artifactId>yunxi-module-demo-api</artifactId>
|
|
||||||
<version>${revision}</version>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- 业务组件 -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.yunxi.scm</groupId>
|
|
||||||
<artifactId>yunxi-spring-boot-starter-biz-operatelog</artifactId>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- Web 相关 -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.yunxi.scm</groupId>
|
|
||||||
<artifactId>yunxi-spring-boot-starter-web</artifactId>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.yunxi.scm</groupId>
|
|
||||||
<artifactId>yunxi-spring-boot-starter-security</artifactId>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- DB 相关 -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.yunxi.scm</groupId>
|
|
||||||
<artifactId>yunxi-spring-boot-starter-mybatis</artifactId>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- Test 测试相关 -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.yunxi.scm</groupId>
|
|
||||||
<artifactId>yunxi-spring-boot-starter-test</artifactId>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- Excel 相关 -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.yunxi.scm</groupId>
|
|
||||||
<artifactId>yunxi-spring-boot-starter-excel</artifactId>
|
|
||||||
</dependency>
|
|
||||||
</dependencies>
|
|
||||||
|
|
||||||
</project>
|
|
@ -1,28 +0,0 @@
|
|||||||
package com.yunxi.scm.module.demo.controller.admin;
|
|
||||||
|
|
||||||
import com.yunxi.scm.framework.common.pojo.CommonResult;
|
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
|
||||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
|
||||||
import org.springframework.validation.annotation.Validated;
|
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
import javax.annotation.security.PermitAll;
|
|
||||||
|
|
||||||
import static com.yunxi.scm.framework.common.pojo.CommonResult.success;
|
|
||||||
|
|
||||||
@Tag(name = "管理后台 - Test")
|
|
||||||
@RestController
|
|
||||||
@RequestMapping("/demo/test")
|
|
||||||
@Validated
|
|
||||||
public class DemoTestController {
|
|
||||||
|
|
||||||
@GetMapping("/get")
|
|
||||||
@Operation(summary = "获取 test 信息")
|
|
||||||
@PermitAll // 无需认证即可访问
|
|
||||||
public CommonResult<String> get() {
|
|
||||||
return success("无需认证即可访问的后台接口");
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,99 +0,0 @@
|
|||||||
package com.yunxi.scm.module.demo.controller.admin.material;
|
|
||||||
|
|
||||||
import com.yunxi.scm.framework.common.pojo.CommonResult;
|
|
||||||
import com.yunxi.scm.framework.common.pojo.PageResult;
|
|
||||||
import com.yunxi.scm.framework.excel.core.util.ExcelUtils;
|
|
||||||
import com.yunxi.scm.framework.operatelog.core.annotations.OperateLog;
|
|
||||||
import com.yunxi.scm.module.demo.controller.admin.material.vo.*;
|
|
||||||
import com.yunxi.scm.module.demo.convert.material.MaterialConvert;
|
|
||||||
import com.yunxi.scm.module.demo.dal.dataobject.material.MaterialDO;
|
|
||||||
import com.yunxi.scm.module.demo.service.material.MaterialService;
|
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
|
||||||
import io.swagger.v3.oas.annotations.Parameter;
|
|
||||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
|
||||||
import org.springframework.validation.annotation.Validated;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
import javax.validation.Valid;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import static com.yunxi.scm.framework.common.pojo.CommonResult.success;
|
|
||||||
import static com.yunxi.scm.framework.operatelog.core.enums.OperateTypeEnum.EXPORT;
|
|
||||||
|
|
||||||
@Tag(name = "管理后台 - 物料管理")
|
|
||||||
@RestController
|
|
||||||
@RequestMapping("/demo/material")
|
|
||||||
@Validated
|
|
||||||
public class MaterialController {
|
|
||||||
|
|
||||||
@Resource
|
|
||||||
private MaterialService materialServiceDemo;
|
|
||||||
|
|
||||||
@PostMapping("/create")
|
|
||||||
@Operation(summary = "创建物料管理")
|
|
||||||
@PreAuthorize("@ss.hasPermission('demo:material:create')")
|
|
||||||
public CommonResult<Long> createMaterial(@Valid @RequestBody MaterialCreateReqVO createReqVO) {
|
|
||||||
return success(materialServiceDemo.createMaterial(createReqVO));
|
|
||||||
}
|
|
||||||
|
|
||||||
@PutMapping("/update")
|
|
||||||
@Operation(summary = "更新物料管理")
|
|
||||||
@PreAuthorize("@ss.hasPermission('demo:material:update')")
|
|
||||||
public CommonResult<Boolean> updateMaterial(@Valid @RequestBody MaterialUpdateReqVO updateReqVO) {
|
|
||||||
materialServiceDemo.updateMaterial(updateReqVO);
|
|
||||||
return success(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
@DeleteMapping("/delete")
|
|
||||||
@Operation(summary = "删除物料管理")
|
|
||||||
@Parameter(name = "id", description = "编号", required = true)
|
|
||||||
@PreAuthorize("@ss.hasPermission('demo:material:delete')")
|
|
||||||
public CommonResult<Boolean> deleteMaterial(@RequestParam("id") Long id) {
|
|
||||||
materialServiceDemo.deleteMaterial(id);
|
|
||||||
return success(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping("/get")
|
|
||||||
@Operation(summary = "获得物料管理")
|
|
||||||
@Parameter(name = "id", description = "编号", required = true, example = "1024")
|
|
||||||
@PreAuthorize("@ss.hasPermission('demo:material:query')")
|
|
||||||
public CommonResult<MaterialRespVO> getMaterial(@RequestParam("id") Long id) {
|
|
||||||
MaterialDO material = materialServiceDemo.getMaterial(id);
|
|
||||||
return success(MaterialConvert.INSTANCE.convert(material));
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping("/list")
|
|
||||||
@Operation(summary = "获得物料管理列表")
|
|
||||||
@Parameter(name = "ids", description = "编号列表", required = true, example = "1024,2048")
|
|
||||||
@PreAuthorize("@ss.hasPermission('demo:material:query')")
|
|
||||||
public CommonResult<List<MaterialRespVO>> getMaterialList(@RequestParam("ids") Collection<Long> ids) {
|
|
||||||
List<MaterialDO> list = materialServiceDemo.getMaterialList(ids);
|
|
||||||
return success(MaterialConvert.INSTANCE.convertList(list));
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping("/page")
|
|
||||||
@Operation(summary = "获得物料管理分页")
|
|
||||||
@PreAuthorize("@ss.hasPermission('demo:material:query')")
|
|
||||||
public CommonResult<PageResult<MaterialRespVO>> getMaterialPage(@Valid MaterialPageReqVO pageVO) {
|
|
||||||
PageResult<MaterialDO> pageResult = materialServiceDemo.getMaterialPage(pageVO);
|
|
||||||
return success(MaterialConvert.INSTANCE.convertPage(pageResult));
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping("/export-excel")
|
|
||||||
@Operation(summary = "导出物料管理 Excel")
|
|
||||||
@PreAuthorize("@ss.hasPermission('demo:material:export')")
|
|
||||||
@OperateLog(type = EXPORT)
|
|
||||||
public void exportMaterialExcel(@Valid MaterialExportReqVO exportReqVO,
|
|
||||||
HttpServletResponse response) throws IOException {
|
|
||||||
List<MaterialDO> list = materialServiceDemo.getMaterialList(exportReqVO);
|
|
||||||
// 导出 Excel
|
|
||||||
List<MaterialExcelVO> datas = MaterialConvert.INSTANCE.convertList02(list);
|
|
||||||
ExcelUtils.write(response, "物料管理.xls", "数据", MaterialExcelVO.class, datas);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,14 +0,0 @@
|
|||||||
package com.yunxi.scm.module.demo.controller.admin.material.vo;
|
|
||||||
|
|
||||||
import lombok.*;
|
|
||||||
import java.util.*;
|
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
|
||||||
import javax.validation.constraints.*;
|
|
||||||
|
|
||||||
@Schema(description = "管理后台 - 物料管理创建 Request VO")
|
|
||||||
@Data
|
|
||||||
@EqualsAndHashCode(callSuper = true)
|
|
||||||
@ToString(callSuper = true)
|
|
||||||
public class MaterialCreateReqVO extends MaterialBaseVO {
|
|
||||||
|
|
||||||
}
|
|
@ -1,55 +0,0 @@
|
|||||||
package com.yunxi.scm.module.demo.controller.admin.material.vo;
|
|
||||||
|
|
||||||
import com.alibaba.excel.annotation.ExcelProperty;
|
|
||||||
import com.yunxi.scm.framework.excel.core.annotations.DictFormat;
|
|
||||||
import com.yunxi.scm.framework.excel.core.convert.DictConvert;
|
|
||||||
import com.yunxi.scm.module.demo.enums.DictTypeConstants;
|
|
||||||
import lombok.Data;
|
|
||||||
|
|
||||||
import java.math.BigDecimal;
|
|
||||||
import java.time.LocalDateTime;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 物料管理 Excel VO
|
|
||||||
*
|
|
||||||
* @author ccongli
|
|
||||||
*/
|
|
||||||
@Data
|
|
||||||
public class MaterialExcelVO {
|
|
||||||
|
|
||||||
@ExcelProperty("ID")
|
|
||||||
private Long id;
|
|
||||||
|
|
||||||
@ExcelProperty("名称")
|
|
||||||
private String name;
|
|
||||||
|
|
||||||
@ExcelProperty(value = "状态", converter = DictConvert.class)
|
|
||||||
@DictFormat(DictTypeConstants.MATERIAL_STATUS)
|
|
||||||
private Byte status;
|
|
||||||
|
|
||||||
@ExcelProperty("类型")
|
|
||||||
@DictFormat(DictTypeConstants.TRADE_ORDER_TYPE)
|
|
||||||
private Byte type;
|
|
||||||
|
|
||||||
@ExcelProperty("分类")
|
|
||||||
@DictFormat(DictTypeConstants.TRADE_ORDER_TYPE)
|
|
||||||
private List<Integer> category;
|
|
||||||
|
|
||||||
@ExcelProperty("图片")
|
|
||||||
private String imgurl;
|
|
||||||
|
|
||||||
@ExcelProperty("库存数量")
|
|
||||||
private Integer stock;
|
|
||||||
|
|
||||||
@ExcelProperty("单价")
|
|
||||||
private BigDecimal price;
|
|
||||||
|
|
||||||
@ExcelProperty("备注")
|
|
||||||
private String remark;
|
|
||||||
|
|
||||||
@ExcelProperty("创建时间")
|
|
||||||
private LocalDateTime createTime;
|
|
||||||
|
|
||||||
}
|
|
@ -1,37 +0,0 @@
|
|||||||
package com.yunxi.scm.module.demo.controller.admin.material.vo;
|
|
||||||
|
|
||||||
import com.yunxi.scm.framework.common.pojo.PageParam;
|
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
|
||||||
import lombok.Data;
|
|
||||||
import lombok.EqualsAndHashCode;
|
|
||||||
import lombok.ToString;
|
|
||||||
import org.springframework.format.annotation.DateTimeFormat;
|
|
||||||
|
|
||||||
import java.time.LocalDateTime;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import static com.yunxi.scm.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
|
|
||||||
|
|
||||||
@Schema(description = "管理后台 - 物料管理分页 Request VO")
|
|
||||||
@Data
|
|
||||||
@EqualsAndHashCode(callSuper = true)
|
|
||||||
@ToString(callSuper = true)
|
|
||||||
public class MaterialPageReqVO extends PageParam {
|
|
||||||
|
|
||||||
@Schema(description = "名称", example = "李四")
|
|
||||||
private String name;
|
|
||||||
|
|
||||||
@Schema(description = "状态", example = "1")
|
|
||||||
private Byte status;
|
|
||||||
|
|
||||||
@Schema(description = "类型", example = "2")
|
|
||||||
private Byte type;
|
|
||||||
|
|
||||||
@Schema(description = "分类", example = "[1,2]")
|
|
||||||
private List<Integer> category;
|
|
||||||
|
|
||||||
@Schema(description = "创建时间")
|
|
||||||
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
|
|
||||||
private LocalDateTime[] createTime;
|
|
||||||
|
|
||||||
}
|
|
@ -1,19 +0,0 @@
|
|||||||
package com.yunxi.scm.module.demo.controller.admin.material.vo;
|
|
||||||
|
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
|
||||||
import lombok.*;
|
|
||||||
import java.time.LocalDateTime;
|
|
||||||
|
|
||||||
@Schema(description = "管理后台 - 物料管理 Response VO")
|
|
||||||
@Data
|
|
||||||
@EqualsAndHashCode(callSuper = true)
|
|
||||||
@ToString(callSuper = true)
|
|
||||||
public class MaterialRespVO extends MaterialBaseVO {
|
|
||||||
|
|
||||||
@Schema(description = "ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "14541")
|
|
||||||
private Long id;
|
|
||||||
|
|
||||||
@Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
|
|
||||||
private LocalDateTime createTime;
|
|
||||||
|
|
||||||
}
|
|
@ -1,18 +0,0 @@
|
|||||||
package com.yunxi.scm.module.demo.controller.admin.material.vo;
|
|
||||||
|
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
|
||||||
import lombok.*;
|
|
||||||
import java.util.*;
|
|
||||||
import javax.validation.constraints.*;
|
|
||||||
|
|
||||||
@Schema(description = "管理后台 - 物料管理更新 Request VO")
|
|
||||||
@Data
|
|
||||||
@EqualsAndHashCode(callSuper = true)
|
|
||||||
@ToString(callSuper = true)
|
|
||||||
public class MaterialUpdateReqVO extends MaterialBaseVO {
|
|
||||||
|
|
||||||
@Schema(description = "ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "14541")
|
|
||||||
@NotNull(message = "ID不能为空")
|
|
||||||
private Long id;
|
|
||||||
|
|
||||||
}
|
|
@ -1,27 +0,0 @@
|
|||||||
package com.yunxi.scm.module.demo.controller.app;
|
|
||||||
|
|
||||||
import com.yunxi.scm.framework.common.pojo.CommonResult;
|
|
||||||
import com.yunxi.scm.framework.security.core.annotations.PreAuthenticated;
|
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
|
||||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
|
||||||
import org.springframework.validation.annotation.Validated;
|
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
import static com.yunxi.scm.framework.common.pojo.CommonResult.success;
|
|
||||||
|
|
||||||
@Tag(name = "用户 App - Test")
|
|
||||||
@RestController
|
|
||||||
@RequestMapping("/demo/test")
|
|
||||||
@Validated
|
|
||||||
public class AppDemoTestController {
|
|
||||||
|
|
||||||
@GetMapping("/get")
|
|
||||||
@Operation(summary = "获取 test 信息")
|
|
||||||
@PreAuthenticated // 认证后可访问
|
|
||||||
public CommonResult<String> get() {
|
|
||||||
return success("需认证后才能访问的app接口");
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,34 +0,0 @@
|
|||||||
package com.yunxi.scm.module.demo.convert.material;
|
|
||||||
|
|
||||||
import java.util.*;
|
|
||||||
|
|
||||||
import com.yunxi.scm.framework.common.pojo.PageResult;
|
|
||||||
|
|
||||||
import com.yunxi.scm.module.demo.dal.dataobject.material.MaterialDO;
|
|
||||||
import org.mapstruct.Mapper;
|
|
||||||
import org.mapstruct.factory.Mappers;
|
|
||||||
import com.yunxi.scm.module.demo.controller.admin.material.vo.*;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 物料管理 Convert
|
|
||||||
*
|
|
||||||
* @author ccongli
|
|
||||||
*/
|
|
||||||
@Mapper
|
|
||||||
public interface MaterialConvert {
|
|
||||||
|
|
||||||
MaterialConvert INSTANCE = Mappers.getMapper(MaterialConvert.class);
|
|
||||||
|
|
||||||
MaterialDO convert(MaterialCreateReqVO bean);
|
|
||||||
|
|
||||||
MaterialDO convert(MaterialUpdateReqVO bean);
|
|
||||||
|
|
||||||
MaterialRespVO convert(MaterialDO bean);
|
|
||||||
|
|
||||||
List<MaterialRespVO> convertList(List<MaterialDO> list);
|
|
||||||
|
|
||||||
PageResult<MaterialRespVO> convertPage(PageResult<MaterialDO> page);
|
|
||||||
|
|
||||||
List<MaterialExcelVO> convertList02(List<MaterialDO> list);
|
|
||||||
|
|
||||||
}
|
|
@ -1,71 +0,0 @@
|
|||||||
package com.yunxi.scm.module.demo.dal.dataobject.material;
|
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.annotation.KeySequence;
|
|
||||||
import com.baomidou.mybatisplus.annotation.TableField;
|
|
||||||
import com.baomidou.mybatisplus.annotation.TableId;
|
|
||||||
import com.baomidou.mybatisplus.annotation.TableName;
|
|
||||||
import com.yunxi.scm.framework.mybatis.core.dataobject.BaseDO;
|
|
||||||
import com.yunxi.scm.framework.mybatis.core.type.IntegerListTypeHandler;
|
|
||||||
import lombok.*;
|
|
||||||
|
|
||||||
import java.math.BigDecimal;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 物料管理 DO
|
|
||||||
*
|
|
||||||
* @author ccongli
|
|
||||||
*/
|
|
||||||
@TableName(value = "demo_material",autoResultMap = true)
|
|
||||||
@KeySequence("demo_material_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。
|
|
||||||
@Data
|
|
||||||
@EqualsAndHashCode(callSuper = true)
|
|
||||||
@ToString(callSuper = true)
|
|
||||||
@Builder
|
|
||||||
@NoArgsConstructor
|
|
||||||
@AllArgsConstructor
|
|
||||||
public class MaterialDO extends BaseDO {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ID
|
|
||||||
*/
|
|
||||||
@TableId
|
|
||||||
private Long id;
|
|
||||||
/**
|
|
||||||
* 名称
|
|
||||||
*/
|
|
||||||
private String name;
|
|
||||||
/**
|
|
||||||
* 状态
|
|
||||||
*
|
|
||||||
* 枚举 {@link TODO material_status 对应的类}
|
|
||||||
*/
|
|
||||||
private Byte status;
|
|
||||||
/**
|
|
||||||
* 类型
|
|
||||||
*/
|
|
||||||
private Byte type;
|
|
||||||
/**
|
|
||||||
* 分类
|
|
||||||
*/
|
|
||||||
// @TableField(typeHandler = JacksonTypeHandler.class)
|
|
||||||
@TableField(typeHandler = IntegerListTypeHandler.class)
|
|
||||||
private List<Integer> category;
|
|
||||||
/**
|
|
||||||
* 图片
|
|
||||||
*/
|
|
||||||
private String imgurl;
|
|
||||||
/**
|
|
||||||
* 库存数量
|
|
||||||
*/
|
|
||||||
private Integer stock;
|
|
||||||
/**
|
|
||||||
* 单价
|
|
||||||
*/
|
|
||||||
private BigDecimal price;
|
|
||||||
/**
|
|
||||||
* 备注
|
|
||||||
*/
|
|
||||||
private String remark;
|
|
||||||
|
|
||||||
}
|
|
@ -1,40 +0,0 @@
|
|||||||
package com.yunxi.scm.module.demo.dal.mysql.material;
|
|
||||||
|
|
||||||
import java.util.*;
|
|
||||||
|
|
||||||
import com.yunxi.scm.framework.common.pojo.PageResult;
|
|
||||||
import com.yunxi.scm.framework.mybatis.core.query.LambdaQueryWrapperX;
|
|
||||||
import com.yunxi.scm.framework.mybatis.core.mapper.BaseMapperX;
|
|
||||||
import com.yunxi.scm.module.demo.dal.dataobject.material.MaterialDO;
|
|
||||||
import org.apache.ibatis.annotations.Mapper;
|
|
||||||
import com.yunxi.scm.module.demo.controller.admin.material.vo.*;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 物料管理 Mapper
|
|
||||||
*
|
|
||||||
* @author ccongli
|
|
||||||
*/
|
|
||||||
@Mapper
|
|
||||||
public interface MaterialMapper extends BaseMapperX<MaterialDO> {
|
|
||||||
|
|
||||||
default PageResult<MaterialDO> selectPage(MaterialPageReqVO reqVO) {
|
|
||||||
return selectPage(reqVO, new LambdaQueryWrapperX<MaterialDO>()
|
|
||||||
.likeIfPresent(MaterialDO::getName, reqVO.getName())
|
|
||||||
.eqIfPresent(MaterialDO::getStatus, reqVO.getStatus())
|
|
||||||
.eqIfPresent(MaterialDO::getType, reqVO.getType())
|
|
||||||
.eqIfPresent(MaterialDO::getCategory, reqVO.getCategory())
|
|
||||||
.betweenIfPresent(MaterialDO::getCreateTime, reqVO.getCreateTime())
|
|
||||||
.orderByDesc(MaterialDO::getId));
|
|
||||||
}
|
|
||||||
|
|
||||||
default List<MaterialDO> selectList(MaterialExportReqVO reqVO) {
|
|
||||||
return selectList(new LambdaQueryWrapperX<MaterialDO>()
|
|
||||||
.likeIfPresent(MaterialDO::getName, reqVO.getName())
|
|
||||||
.eqIfPresent(MaterialDO::getStatus, reqVO.getStatus())
|
|
||||||
.eqIfPresent(MaterialDO::getType, reqVO.getType())
|
|
||||||
.eqIfPresent(MaterialDO::getCategory, reqVO.getCategory())
|
|
||||||
.betweenIfPresent(MaterialDO::getCreateTime, reqVO.getCreateTime())
|
|
||||||
.orderByDesc(MaterialDO::getId));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,70 +0,0 @@
|
|||||||
package com.yunxi.scm.module.demo.service.material;
|
|
||||||
|
|
||||||
import java.util.*;
|
|
||||||
import javax.validation.*;
|
|
||||||
import com.yunxi.scm.module.demo.controller.admin.material.vo.*;
|
|
||||||
import com.yunxi.scm.module.demo.dal.dataobject.material.MaterialDO;
|
|
||||||
import com.yunxi.scm.framework.common.pojo.PageResult;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 物料管理 Service 接口
|
|
||||||
*
|
|
||||||
* @author ccongli
|
|
||||||
*/
|
|
||||||
public interface MaterialService {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 创建物料管理
|
|
||||||
*
|
|
||||||
* @param createReqVO 创建信息
|
|
||||||
* @return 编号
|
|
||||||
*/
|
|
||||||
Long createMaterial(@Valid MaterialCreateReqVO createReqVO);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 更新物料管理
|
|
||||||
*
|
|
||||||
* @param updateReqVO 更新信息
|
|
||||||
*/
|
|
||||||
void updateMaterial(@Valid MaterialUpdateReqVO updateReqVO);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 删除物料管理
|
|
||||||
*
|
|
||||||
* @param id 编号
|
|
||||||
*/
|
|
||||||
void deleteMaterial(Long id);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 获得物料管理
|
|
||||||
*
|
|
||||||
* @param id 编号
|
|
||||||
* @return 物料管理
|
|
||||||
*/
|
|
||||||
MaterialDO getMaterial(Long id);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 获得物料管理列表
|
|
||||||
*
|
|
||||||
* @param ids 编号
|
|
||||||
* @return 物料管理列表
|
|
||||||
*/
|
|
||||||
List<MaterialDO> getMaterialList(Collection<Long> ids);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 获得物料管理分页
|
|
||||||
*
|
|
||||||
* @param pageReqVO 分页查询
|
|
||||||
* @return 物料管理分页
|
|
||||||
*/
|
|
||||||
PageResult<MaterialDO> getMaterialPage(MaterialPageReqVO pageReqVO);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 获得物料管理列表, 用于 Excel 导出
|
|
||||||
*
|
|
||||||
* @param exportReqVO 查询条件
|
|
||||||
* @return 物料管理列表
|
|
||||||
*/
|
|
||||||
List<MaterialDO> getMaterialList(MaterialExportReqVO exportReqVO);
|
|
||||||
|
|
||||||
}
|
|
@ -1,85 +0,0 @@
|
|||||||
package com.yunxi.scm.module.demo.service.material;
|
|
||||||
|
|
||||||
import com.yunxi.scm.framework.common.pojo.PageResult;
|
|
||||||
import com.yunxi.scm.module.demo.controller.admin.material.vo.MaterialCreateReqVO;
|
|
||||||
import com.yunxi.scm.module.demo.controller.admin.material.vo.MaterialExportReqVO;
|
|
||||||
import com.yunxi.scm.module.demo.controller.admin.material.vo.MaterialPageReqVO;
|
|
||||||
import com.yunxi.scm.module.demo.controller.admin.material.vo.MaterialUpdateReqVO;
|
|
||||||
import com.yunxi.scm.module.demo.convert.material.MaterialConvert;
|
|
||||||
import com.yunxi.scm.module.demo.dal.dataobject.material.MaterialDO;
|
|
||||||
import com.yunxi.scm.module.demo.dal.mysql.material.MaterialMapper;
|
|
||||||
import org.springframework.stereotype.Service;
|
|
||||||
import org.springframework.validation.annotation.Validated;
|
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import static com.yunxi.scm.framework.common.exception.util.ServiceExceptionUtil.exception;
|
|
||||||
import static com.yunxi.scm.module.demo.enums.ErrorCodeConstants.MATERIAL_NOT_EXISTS;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 物料管理 Service 实现类
|
|
||||||
*
|
|
||||||
* @author ccongli
|
|
||||||
*/
|
|
||||||
@Service
|
|
||||||
@Validated
|
|
||||||
public class MaterialServiceImpl implements MaterialService {
|
|
||||||
|
|
||||||
@Resource
|
|
||||||
private MaterialMapper materialMapperDemo;
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Long createMaterial(MaterialCreateReqVO createReqVO) {
|
|
||||||
// 插入
|
|
||||||
MaterialDO material = MaterialConvert.INSTANCE.convert(createReqVO);
|
|
||||||
materialMapperDemo.insert(material);
|
|
||||||
// 返回
|
|
||||||
return material.getId();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void updateMaterial(MaterialUpdateReqVO updateReqVO) {
|
|
||||||
// 校验存在
|
|
||||||
validateMaterialExists(updateReqVO.getId());
|
|
||||||
// 更新
|
|
||||||
MaterialDO updateObj = MaterialConvert.INSTANCE.convert(updateReqVO);
|
|
||||||
materialMapperDemo.updateById(updateObj);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void deleteMaterial(Long id) {
|
|
||||||
// 校验存在
|
|
||||||
validateMaterialExists(id);
|
|
||||||
// 删除
|
|
||||||
materialMapperDemo.deleteById(id);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void validateMaterialExists(Long id) {
|
|
||||||
if (materialMapperDemo.selectById(id) == null) {
|
|
||||||
throw exception(MATERIAL_NOT_EXISTS);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public MaterialDO getMaterial(Long id) {
|
|
||||||
return materialMapperDemo.selectById(id);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<MaterialDO> getMaterialList(Collection<Long> ids) {
|
|
||||||
return materialMapperDemo.selectBatchIds(ids);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public PageResult<MaterialDO> getMaterialPage(MaterialPageReqVO pageReqVO) {
|
|
||||||
return materialMapperDemo.selectPage(pageReqVO);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<MaterialDO> getMaterialList(MaterialExportReqVO exportReqVO) {
|
|
||||||
return materialMapperDemo.selectList(exportReqVO);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,179 +0,0 @@
|
|||||||
package com.yunxi.scm.module.demo.service.material;
|
|
||||||
|
|
||||||
import com.yunxi.scm.framework.common.pojo.PageResult;
|
|
||||||
import com.yunxi.scm.framework.test.core.ut.BaseDbUnitTest;
|
|
||||||
import com.yunxi.scm.module.demo.controller.admin.material.vo.MaterialCreateReqVO;
|
|
||||||
import com.yunxi.scm.module.demo.controller.admin.material.vo.MaterialExportReqVO;
|
|
||||||
import com.yunxi.scm.module.demo.controller.admin.material.vo.MaterialPageReqVO;
|
|
||||||
import com.yunxi.scm.module.demo.controller.admin.material.vo.MaterialUpdateReqVO;
|
|
||||||
import com.yunxi.scm.module.demo.dal.dataobject.material.MaterialDO;
|
|
||||||
import com.yunxi.scm.module.demo.dal.mysql.material.MaterialMapper;
|
|
||||||
import org.junit.jupiter.api.Disabled;
|
|
||||||
import org.junit.jupiter.api.Test;
|
|
||||||
import org.springframework.context.annotation.Import;
|
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import static com.yunxi.scm.framework.common.util.date.LocalDateTimeUtils.buildBetweenTime;
|
|
||||||
import static com.yunxi.scm.framework.common.util.object.ObjectUtils.cloneIgnoreId;
|
|
||||||
import static com.yunxi.scm.framework.test.core.util.AssertUtils.assertPojoEquals;
|
|
||||||
import static com.yunxi.scm.framework.test.core.util.AssertUtils.assertServiceException;
|
|
||||||
import static com.yunxi.scm.framework.test.core.util.RandomUtils.randomLongId;
|
|
||||||
import static com.yunxi.scm.framework.test.core.util.RandomUtils.randomPojo;
|
|
||||||
import static com.yunxi.scm.module.demo.enums.ErrorCodeConstants.MATERIAL_NOT_EXISTS;
|
|
||||||
import static org.junit.jupiter.api.Assertions.*;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* {@link MaterialServiceImpl} 的单元测试类
|
|
||||||
*
|
|
||||||
* @author ccongli
|
|
||||||
*/
|
|
||||||
@Import(MaterialServiceImpl.class)
|
|
||||||
public class MaterialServiceDemoImplTest extends BaseDbUnitTest {
|
|
||||||
|
|
||||||
@Resource
|
|
||||||
private MaterialServiceImpl materialService;
|
|
||||||
|
|
||||||
@Resource
|
|
||||||
private MaterialMapper materialMapperDemo;
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testCreateMaterial_success() {
|
|
||||||
// 准备参数
|
|
||||||
MaterialCreateReqVO reqVO = randomPojo(MaterialCreateReqVO.class);
|
|
||||||
|
|
||||||
// 调用
|
|
||||||
Long materialId = materialService.createMaterial(reqVO);
|
|
||||||
// 断言
|
|
||||||
assertNotNull(materialId);
|
|
||||||
// 校验记录的属性是否正确
|
|
||||||
MaterialDO material = materialMapperDemo.selectById(materialId);
|
|
||||||
assertPojoEquals(reqVO, material);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUpdateMaterial_success() {
|
|
||||||
// mock 数据
|
|
||||||
MaterialDO dbMaterial = randomPojo(MaterialDO.class);
|
|
||||||
materialMapperDemo.insert(dbMaterial);// @Sql: 先插入出一条存在的数据
|
|
||||||
// 准备参数
|
|
||||||
MaterialUpdateReqVO reqVO = randomPojo(MaterialUpdateReqVO.class, o -> {
|
|
||||||
o.setId(dbMaterial.getId()); // 设置更新的 ID
|
|
||||||
});
|
|
||||||
|
|
||||||
// 调用
|
|
||||||
materialService.updateMaterial(reqVO);
|
|
||||||
// 校验是否更新正确
|
|
||||||
MaterialDO material = materialMapperDemo.selectById(reqVO.getId()); // 获取最新的
|
|
||||||
assertPojoEquals(reqVO, material);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUpdateMaterial_notExists() {
|
|
||||||
// 准备参数
|
|
||||||
MaterialUpdateReqVO reqVO = randomPojo(MaterialUpdateReqVO.class);
|
|
||||||
|
|
||||||
// 调用, 并断言异常
|
|
||||||
assertServiceException(() -> materialService.updateMaterial(reqVO), MATERIAL_NOT_EXISTS);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testDeleteMaterial_success() {
|
|
||||||
// mock 数据
|
|
||||||
MaterialDO dbMaterial = randomPojo(MaterialDO.class);
|
|
||||||
materialMapperDemo.insert(dbMaterial);// @Sql: 先插入出一条存在的数据
|
|
||||||
// 准备参数
|
|
||||||
Long id = dbMaterial.getId();
|
|
||||||
|
|
||||||
// 调用
|
|
||||||
materialService.deleteMaterial(id);
|
|
||||||
// 校验数据不存在了
|
|
||||||
assertNull(materialMapperDemo.selectById(id));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testDeleteMaterial_notExists() {
|
|
||||||
// 准备参数
|
|
||||||
Long id = randomLongId();
|
|
||||||
|
|
||||||
// 调用, 并断言异常
|
|
||||||
assertServiceException(() -> materialService.deleteMaterial(id), MATERIAL_NOT_EXISTS);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
@Disabled // TODO 请修改 null 为需要的值,然后删除 @Disabled 注解
|
|
||||||
public void testGetMaterialPage() {
|
|
||||||
// mock 数据
|
|
||||||
MaterialDO dbMaterial = randomPojo(MaterialDO.class, o -> { // 等会查询到
|
|
||||||
o.setName(null);
|
|
||||||
o.setStatus(null);
|
|
||||||
o.setType(null);
|
|
||||||
o.setCategory(null);
|
|
||||||
o.setCreateTime(null);
|
|
||||||
});
|
|
||||||
materialMapperDemo.insert(dbMaterial);
|
|
||||||
// 测试 name 不匹配
|
|
||||||
materialMapperDemo.insert(cloneIgnoreId(dbMaterial, o -> o.setName(null)));
|
|
||||||
// 测试 status 不匹配
|
|
||||||
materialMapperDemo.insert(cloneIgnoreId(dbMaterial, o -> o.setStatus(null)));
|
|
||||||
// 测试 type 不匹配
|
|
||||||
materialMapperDemo.insert(cloneIgnoreId(dbMaterial, o -> o.setType(null)));
|
|
||||||
// 测试 category 不匹配
|
|
||||||
materialMapperDemo.insert(cloneIgnoreId(dbMaterial, o -> o.setCategory(null)));
|
|
||||||
// 测试 createTime 不匹配
|
|
||||||
materialMapperDemo.insert(cloneIgnoreId(dbMaterial, o -> o.setCreateTime(null)));
|
|
||||||
// 准备参数
|
|
||||||
MaterialPageReqVO reqVO = new MaterialPageReqVO();
|
|
||||||
reqVO.setName(null);
|
|
||||||
reqVO.setStatus(null);
|
|
||||||
reqVO.setType(null);
|
|
||||||
reqVO.setCategory(null);
|
|
||||||
reqVO.setCreateTime(buildBetweenTime(2023, 2, 1, 2023, 2, 28));
|
|
||||||
|
|
||||||
// 调用
|
|
||||||
PageResult<MaterialDO> pageResult = materialService.getMaterialPage(reqVO);
|
|
||||||
// 断言
|
|
||||||
assertEquals(1, pageResult.getTotal());
|
|
||||||
assertEquals(1, pageResult.getList().size());
|
|
||||||
assertPojoEquals(dbMaterial, pageResult.getList().get(0));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
@Disabled // TODO 请修改 null 为需要的值,然后删除 @Disabled 注解
|
|
||||||
public void testGetMaterialList() {
|
|
||||||
// mock 数据
|
|
||||||
MaterialDO dbMaterial = randomPojo(MaterialDO.class, o -> { // 等会查询到
|
|
||||||
o.setName(null);
|
|
||||||
o.setStatus(null);
|
|
||||||
o.setType(null);
|
|
||||||
o.setCategory(null);
|
|
||||||
o.setCreateTime(null);
|
|
||||||
});
|
|
||||||
materialMapperDemo.insert(dbMaterial);
|
|
||||||
// 测试 name 不匹配
|
|
||||||
materialMapperDemo.insert(cloneIgnoreId(dbMaterial, o -> o.setName(null)));
|
|
||||||
// 测试 status 不匹配
|
|
||||||
materialMapperDemo.insert(cloneIgnoreId(dbMaterial, o -> o.setStatus(null)));
|
|
||||||
// 测试 type 不匹配
|
|
||||||
materialMapperDemo.insert(cloneIgnoreId(dbMaterial, o -> o.setType(null)));
|
|
||||||
// 测试 category 不匹配
|
|
||||||
materialMapperDemo.insert(cloneIgnoreId(dbMaterial, o -> o.setCategory(null)));
|
|
||||||
// 测试 createTime 不匹配
|
|
||||||
materialMapperDemo.insert(cloneIgnoreId(dbMaterial, o -> o.setCreateTime(null)));
|
|
||||||
// 准备参数
|
|
||||||
MaterialExportReqVO reqVO = new MaterialExportReqVO();
|
|
||||||
reqVO.setName(null);
|
|
||||||
reqVO.setStatus(null);
|
|
||||||
reqVO.setType(null);
|
|
||||||
reqVO.setCategory(null);
|
|
||||||
reqVO.setCreateTime(buildBetweenTime(2023, 2, 1, 2023, 2, 28));
|
|
||||||
|
|
||||||
// 调用
|
|
||||||
List<MaterialDO> list = materialService.getMaterialList(reqVO);
|
|
||||||
// 断言
|
|
||||||
assertEquals(1, list.size());
|
|
||||||
assertPojoEquals(dbMaterial, list.get(0));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
Loading…
Reference in new issue