支付模块的 code review

pull/2/head
YunaiV 2021-11-10 09:40:09 +08:00
parent e46a27b937
commit 3368a995ca
14 changed files with 101 additions and 88 deletions

View File

@ -11,6 +11,8 @@ import lombok.ToString;
@ToString(callSuper = true) @ToString(callSuper = true)
public class PayChannelCreateReqVO extends PayChannelBaseVO { public class PayChannelCreateReqVO extends PayChannelBaseVO {
// TODO @aquan我在想要不这个创建和修改特殊一点。前端传递 string 过来,后端解析成对应的。因为有 code所以我们都知道是哪个配置类。
// 然后,在 PayChannelEnum 里,枚举每个渠道对应的配置类。另外,我们就不单独给配置类搞 vo 了。参数校验,通过手动调用 Validator 去校验。
// 通过这样的方式VO 和 api 都收成,一个 update一个 create
} }

View File

@ -62,5 +62,7 @@ public class PayWechatChannelUpdateReqVO extends PayChannelBaseVO {
@ApiModelProperty(value = "apiclient_cert.pem 证书对应的字符串", required = true, example = "-----BEGIN CERTIFICATE-----") @ApiModelProperty(value = "apiclient_cert.pem 证书对应的字符串", required = true, example = "-----BEGIN CERTIFICATE-----")
private String privateCertContent; private String privateCertContent;
// TODO @aquan参数校验。可以使用 @AssertTruev2 和 v3 的
} }
} }

View File

@ -1,13 +1,15 @@
package cn.iocoder.yudao.adminserver.modules.pay.dal.mysql.app; package cn.iocoder.yudao.adminserver.modules.pay.dal.mysql.app;
import java.util.*; import cn.iocoder.yudao.adminserver.modules.pay.controller.app.vo.PayAppExportReqVO;
import cn.iocoder.yudao.adminserver.modules.pay.controller.app.vo.PayAppPageReqVO;
import cn.iocoder.yudao.coreservice.modules.pay.dal.dataobject.merchant.PayAppDO; import cn.iocoder.yudao.coreservice.modules.pay.dal.dataobject.merchant.PayAppDO;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.mybatis.core.query.QueryWrapperX;
import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX; import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
import cn.iocoder.yudao.framework.mybatis.core.query.QueryWrapperX;
import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Mapper;
import cn.iocoder.yudao.adminserver.modules.pay.controller.app.vo.*;
import java.util.Collection;
import java.util.List;
/** /**
* Mapper * Mapper
@ -17,7 +19,7 @@ import cn.iocoder.yudao.adminserver.modules.pay.controller.app.vo.*;
@Mapper @Mapper
public interface PayAppMapper extends BaseMapperX<PayAppDO> { public interface PayAppMapper extends BaseMapperX<PayAppDO> {
default PageResult<PayAppDO> selectPage(PayAppPageReqVO reqVO,Collection<Long> merchantIds) { default PageResult<PayAppDO> selectPage(PayAppPageReqVO reqVO, Collection<Long> merchantIds) {
return selectPage(reqVO, new QueryWrapperX<PayAppDO>() return selectPage(reqVO, new QueryWrapperX<PayAppDO>()
.likeIfPresent("name", reqVO.getName()) .likeIfPresent("name", reqVO.getName())
.eqIfPresent("status", reqVO.getStatus()) .eqIfPresent("status", reqVO.getStatus())
@ -38,7 +40,7 @@ public interface PayAppMapper extends BaseMapperX<PayAppDO> {
.eqIfPresent("refund_notify_url", reqVO.getRefundNotifyUrl()) .eqIfPresent("refund_notify_url", reqVO.getRefundNotifyUrl())
.eqIfPresent("merchant_id", reqVO.getMerchantId()) .eqIfPresent("merchant_id", reqVO.getMerchantId())
.betweenIfPresent("create_time", reqVO.getBeginCreateTime(), reqVO.getEndCreateTime()) .betweenIfPresent("create_time", reqVO.getBeginCreateTime(), reqVO.getEndCreateTime())
.orderByDesc("id") ); .orderByDesc("id"));
} }
} }

View File

@ -1,26 +1,31 @@
package cn.iocoder.yudao.adminserver.modules.pay.service.app.impl; package cn.iocoder.yudao.adminserver.modules.pay.service.app.impl;
import cn.hutool.core.util.StrUtil; import cn.hutool.core.util.StrUtil;
import cn.iocoder.yudao.adminserver.modules.pay.controller.app.vo.PayAppCreateReqVO;
import cn.iocoder.yudao.adminserver.modules.pay.controller.app.vo.PayAppExportReqVO;
import cn.iocoder.yudao.adminserver.modules.pay.controller.app.vo.PayAppPageReqVO;
import cn.iocoder.yudao.adminserver.modules.pay.controller.app.vo.PayAppUpdateReqVO;
import cn.iocoder.yudao.adminserver.modules.pay.convert.app.PayAppConvert;
import cn.iocoder.yudao.adminserver.modules.pay.dal.mysql.app.PayAppMapper;
import cn.iocoder.yudao.adminserver.modules.pay.service.app.PayAppService;
import cn.iocoder.yudao.adminserver.modules.pay.service.merchant.PayMerchantService; import cn.iocoder.yudao.adminserver.modules.pay.service.merchant.PayMerchantService;
import cn.iocoder.yudao.coreservice.modules.pay.dal.dataobject.merchant.PayAppDO; import cn.iocoder.yudao.coreservice.modules.pay.dal.dataobject.merchant.PayAppDO;
import cn.iocoder.yudao.coreservice.modules.pay.dal.dataobject.merchant.PayMerchantDO; import cn.iocoder.yudao.coreservice.modules.pay.dal.dataobject.merchant.PayMerchantDO;
import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum; import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum;
import cn.iocoder.yudao.framework.common.util.collection.CollectionUtils; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import com.google.common.annotations.VisibleForTesting; import com.google.common.annotations.VisibleForTesting;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import org.springframework.validation.annotation.Validated; import org.springframework.validation.annotation.Validated;
import java.util.*; import javax.annotation.Resource;
import cn.iocoder.yudao.adminserver.modules.pay.controller.app.vo.*; import java.util.Collection;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import java.util.Collections;
import java.util.List;
import cn.iocoder.yudao.adminserver.modules.pay.convert.app.PayAppConvert; import java.util.Set;
import cn.iocoder.yudao.adminserver.modules.pay.dal.mysql.app.PayAppMapper;
import cn.iocoder.yudao.adminserver.modules.pay.service.app.PayAppService;
import static cn.iocoder.yudao.coreservice.modules.pay.enums.PayErrorCodeCoreConstants.APP_NOT_EXISTS;
import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception; import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
import static cn.iocoder.yudao.coreservice.modules.pay.enums.PayErrorCodeCoreConstants.*; import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.convertSet;
/** /**
* Service * Service
@ -84,7 +89,8 @@ public class PayAppServiceImpl implements PayAppService {
@Override @Override
public PageResult<PayAppDO> getAppPage(PayAppPageReqVO pageReqVO) { public PageResult<PayAppDO> getAppPage(PayAppPageReqVO pageReqVO) {
return appMapper.selectPage(pageReqVO,this.getMerchantCondition(pageReqVO.getMerchantName())); // TODO @aquan会有一个场景merchantName 匹配不到商户编号的时候,应该返回没数据的
return appMapper.selectPage(pageReqVO, this.getMerchantCondition(pageReqVO.getMerchantName()));
} }
@Override @Override
@ -94,6 +100,7 @@ public class PayAppServiceImpl implements PayAppService {
/** /**
* *
*
* @param merchantName * @param merchantName
* @return * @return
*/ */
@ -101,7 +108,7 @@ public class PayAppServiceImpl implements PayAppService {
if (StrUtil.isBlank(merchantName)) { if (StrUtil.isBlank(merchantName)) {
return Collections.emptySet(); return Collections.emptySet();
} }
return CollectionUtils.convertSet(merchantService.getMerchantListByName(merchantName), PayMerchantDO::getId); return convertSet(merchantService.getMerchantListByName(merchantName), PayMerchantDO::getId);
} }
/** /**

View File

@ -1,22 +1,21 @@
package cn.iocoder.yudao.adminserver.modules.pay.service.channel; package cn.iocoder.yudao.adminserver.modules.pay.service.channel;
import java.util.*;
import javax.validation.*;
import cn.iocoder.yudao.adminserver.modules.pay.controller.channel.vo.*; import cn.iocoder.yudao.adminserver.modules.pay.controller.channel.vo.*;
import cn.iocoder.yudao.coreservice.modules.pay.dal.dataobject.merchant.PayChannelDO; import cn.iocoder.yudao.coreservice.modules.pay.dal.dataobject.merchant.PayChannelDO;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import org.springframework.web.multipart.MultipartFile; import org.springframework.web.multipart.MultipartFile;
import javax.validation.Valid;
import java.util.Collection;
import java.util.List;
/** /**
* * Service
* Service
* *
* @author * @author // TODO @aquan作者不要我
*/ */
public interface PayChannelService { public interface PayChannelService {
/** /**
* *
* *
@ -72,8 +71,7 @@ public interface PayChannelService {
* , Excel * , Excel
* *
* @param exportReqVO * @param exportReqVO
* @return * @return
*
*/ */
List<PayChannelDO> getChannelList(PayChannelExportReqVO exportReqVO); List<PayChannelDO> getChannelList(PayChannelExportReqVO exportReqVO);
@ -83,6 +81,7 @@ public interface PayChannelService {
* @param payIds * @param payIds
* @return * @return
*/ */
// TODO @aquan暂时不用提供这种哈。之前提供的原因是数据字典比较特殊。
List<PayChannelDO> getSimpleChannels(Collection<Long> payIds); List<PayChannelDO> getSimpleChannels(Collection<Long> payIds);
/** /**
@ -91,6 +90,7 @@ public interface PayChannelService {
* @param file pem * @param file pem
* @return * @return
*/ */
// TODO @aquan可以前端读取么
String parsingPemFile(MultipartFile file); String parsingPemFile(MultipartFile file);
/** /**
@ -99,6 +99,7 @@ public interface PayChannelService {
* @param reqVO * @param reqVO
* @return * @return
*/ */
// TODO @aquanpojo 如果要做参数校验,需要添加 @Valid
Long createWechatChannel(PayWechatChannelCreateReqVO reqVO); Long createWechatChannel(PayWechatChannelCreateReqVO reqVO);
/** /**

View File

@ -1,43 +1,34 @@
package cn.iocoder.yudao.adminserver.modules.pay.service.channel.impl; package cn.iocoder.yudao.adminserver.modules.pay.service.channel.impl;
import cn.hutool.core.io.IoUtil; import cn.hutool.core.io.IoUtil;
import cn.iocoder.yudao.coreservice.modules.pay.dal.dataobject.merchant.PayChannelDO;
import cn.iocoder.yudao.framework.common.util.json.JsonUtils;
import cn.iocoder.yudao.framework.pay.core.client.impl.wx.WXPayClientConfig;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.fasterxml.jackson.databind.json.JsonMapper;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import org.springframework.util.Assert;
import org.springframework.validation.annotation.Validated;
import java.io.IOException;
import java.util.*;
import cn.iocoder.yudao.adminserver.modules.pay.controller.channel.vo.*; import cn.iocoder.yudao.adminserver.modules.pay.controller.channel.vo.*;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.adminserver.modules.pay.convert.channel.PayChannelConvert; import cn.iocoder.yudao.adminserver.modules.pay.convert.channel.PayChannelConvert;
import cn.iocoder.yudao.adminserver.modules.pay.dal.mysql.channel.PayChannelMapper; import cn.iocoder.yudao.adminserver.modules.pay.dal.mysql.channel.PayChannelMapper;
import cn.iocoder.yudao.adminserver.modules.pay.service.channel.PayChannelService; import cn.iocoder.yudao.adminserver.modules.pay.service.channel.PayChannelService;
import cn.iocoder.yudao.coreservice.modules.pay.dal.dataobject.merchant.PayChannelDO;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.pay.core.client.impl.wx.WXPayClientConfig;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.multipart.MultipartFile; import org.springframework.web.multipart.MultipartFile;
import javax.annotation.Resource;
import java.io.IOException;
import java.util.Collection;
import java.util.List;
import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
import static cn.iocoder.yudao.coreservice.modules.pay.enums.PayErrorCodeCoreConstants.*; import static cn.iocoder.yudao.coreservice.modules.pay.enums.PayErrorCodeCoreConstants.*;
import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
/** /**
* * Service
* Service
* *
* @author * @author // TODO aquan作者写自己哈
*/ */
@Slf4j
@Service @Service
@Slf4j
@Validated @Validated
public class PayChannelServiceImpl implements PayChannelService { public class PayChannelServiceImpl implements PayChannelService {
@ -162,6 +153,7 @@ public class PayChannelServiceImpl implements PayChannelService {
); );
} }
// TODO @aquanservice 不出现 mybatis plus 哈
/** /**
* *
* *

View File

@ -1,15 +1,20 @@
package cn.iocoder.yudao.adminserver.modules.pay.service.merchant; package cn.iocoder.yudao.adminserver.modules.pay.service.merchant;
import java.util.*;
import javax.validation.*;
import cn.hutool.core.collection.CollUtil; import cn.hutool.core.collection.CollUtil;
import cn.iocoder.yudao.adminserver.modules.pay.controller.merchant.vo.*; import cn.iocoder.yudao.adminserver.modules.pay.controller.merchant.vo.PayMerchantCreateReqVO;
import cn.iocoder.yudao.adminserver.modules.system.dal.dataobject.dept.SysDeptDO; import cn.iocoder.yudao.adminserver.modules.pay.controller.merchant.vo.PayMerchantExportReqVO;
import cn.iocoder.yudao.adminserver.modules.pay.controller.merchant.vo.PayMerchantPageReqVO;
import cn.iocoder.yudao.adminserver.modules.pay.controller.merchant.vo.PayMerchantUpdateReqVO;
import cn.iocoder.yudao.coreservice.modules.pay.dal.dataobject.merchant.PayMerchantDO; import cn.iocoder.yudao.coreservice.modules.pay.dal.dataobject.merchant.PayMerchantDO;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.util.collection.CollectionUtils; import cn.iocoder.yudao.framework.common.util.collection.CollectionUtils;
import javax.validation.Valid;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import java.util.Map;
/** /**
* Service * Service
* *
@ -87,6 +92,7 @@ public interface PayMerchantService {
*/ */
List<PayMerchantDO> getMerchantListByName(String merchantName); List<PayMerchantDO> getMerchantListByName(String merchantName);
// TODO aquan暂时不用提供这样的检索。商户不多的。
/** /**
* *
* @param merchantName * @param merchantName
@ -100,6 +106,7 @@ public interface PayMerchantService {
* @param merchantIds * @param merchantIds
* @return * @return
*/ */
// TODO @aquan和 getMerchantList 重复了
List<PayMerchantDO> getSimpleMerchants(Collection<Long> merchantIds); List<PayMerchantDO> getSimpleMerchants(Collection<Long> merchantIds);
/** /**
@ -108,11 +115,13 @@ public interface PayMerchantService {
* @param merchantIds * @param merchantIds
* @return Map * @return Map
*/ */
default Map<Long, PayMerchantDO> getMerchantMap(Collection<Long> merchantIds){ default Map<Long, PayMerchantDO> getMerchantMap(Collection<Long> merchantIds) {
// TODO @aquan可以不用判空交给 getMerchantList 解决
if (CollUtil.isEmpty(merchantIds)) { if (CollUtil.isEmpty(merchantIds)) {
return Collections.emptyMap(); return Collections.emptyMap();
} }
List<PayMerchantDO> list = getSimpleMerchants(merchantIds); List<PayMerchantDO> list = getSimpleMerchants(merchantIds);
return CollectionUtils.convertMap(list, PayMerchantDO::getId); return CollectionUtils.convertMap(list, PayMerchantDO::getId);
} }
} }

View File

@ -113,6 +113,7 @@ public class PayMerchantServiceImpl implements PayMerchantService {
*/ */
@Override @Override
public List<PayMerchantDO> getMerchantListByName(String merchantName) { public List<PayMerchantDO> getMerchantListByName(String merchantName) {
// TODO @aquanService 层,不要出现 mybatis plus 的代码,要放到 mapper 里提供。技术与业务分离,原则上
return this.merchantMapper.selectList(new QueryWrapper<PayMerchantDO>() return this.merchantMapper.selectList(new QueryWrapper<PayMerchantDO>()
.lambda().likeRight(PayMerchantDO::getName, merchantName)); .lambda().likeRight(PayMerchantDO::getName, merchantName));
} }
@ -160,6 +161,7 @@ public class PayMerchantServiceImpl implements PayMerchantService {
return merchantMapper.selectBatchIds(merchantIds); return merchantMapper.selectBatchIds(merchantIds);
} }
// TODO @芋艿:后续增加下合适的算法
/** /**
* *
* @return * @return
@ -168,5 +170,4 @@ public class PayMerchantServiceImpl implements PayMerchantService {
return "M" + DateUtil.format(LocalDateTime.now(),"yyyyMMddHHmmssSSS"); return "M" + DateUtil.format(LocalDateTime.now(),"yyyyMMddHHmmssSSS");
} }
} }

View File

@ -61,5 +61,5 @@ yudao:
- cn.iocoder.yudao.adminserver.modules.infra.enums.InfErrorCodeConstants - cn.iocoder.yudao.adminserver.modules.infra.enums.InfErrorCodeConstants
- cn.iocoder.yudao.adminserver.modules.system.enums.SysErrorCodeConstants - cn.iocoder.yudao.adminserver.modules.system.enums.SysErrorCodeConstants
pay: pay:
payReturnUrl: http://127.0.0.1 payReturnUrl: http://127.0.0.1 # TODO @aquan这个变量配置到 dev 或者 local 里,不同环境有差别哈
debug: false debug: false

View File

@ -1,7 +1,5 @@
package cn.iocoder.yudao.adminserver.modules.pay.app.service; package cn.iocoder.yudao.adminserver.modules.pay.app.service;
import javax.annotation.Resource;
import cn.iocoder.yudao.adminserver.BaseDbUnitTest; import cn.iocoder.yudao.adminserver.BaseDbUnitTest;
import cn.iocoder.yudao.adminserver.modules.pay.controller.app.vo.PayAppCreateReqVO; import cn.iocoder.yudao.adminserver.modules.pay.controller.app.vo.PayAppCreateReqVO;
import cn.iocoder.yudao.adminserver.modules.pay.controller.app.vo.PayAppExportReqVO; import cn.iocoder.yudao.adminserver.modules.pay.controller.app.vo.PayAppExportReqVO;
@ -10,22 +8,21 @@ import cn.iocoder.yudao.adminserver.modules.pay.controller.app.vo.PayAppUpdateRe
import cn.iocoder.yudao.adminserver.modules.pay.dal.mysql.app.PayAppMapper; import cn.iocoder.yudao.adminserver.modules.pay.dal.mysql.app.PayAppMapper;
import cn.iocoder.yudao.adminserver.modules.pay.service.app.impl.PayAppServiceImpl; import cn.iocoder.yudao.adminserver.modules.pay.service.app.impl.PayAppServiceImpl;
import cn.iocoder.yudao.coreservice.modules.pay.dal.dataobject.merchant.PayAppDO; import cn.iocoder.yudao.coreservice.modules.pay.dal.dataobject.merchant.PayAppDO;
import cn.iocoder.yudao.framework.common.util.object.ObjectUtils;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.util.object.ObjectUtils;
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 java.util.*;
import static cn.iocoder.yudao.coreservice.modules.pay.enums.PayErrorCodeCoreConstants.*; import javax.annotation.Resource;
import java.util.List;
import static cn.iocoder.yudao.coreservice.modules.pay.enums.PayErrorCodeCoreConstants.APP_NOT_EXISTS;
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.common.util.date.DateUtils.buildTime; import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.randomLongId;
import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.*; import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.randomPojo;
import static org.junit.jupiter.api.Assertions.*; import static org.junit.jupiter.api.Assertions.*;
import static org.mockito.Mockito.*;
/** /**
* {@link PayAppServiceImpl} * {@link PayAppServiceImpl}
* *
@ -148,7 +145,7 @@ public class PayAppServiceTest extends BaseDbUnitTest {
assertPojoEquals(dbApp, pageResult.getList().get(0)); assertPojoEquals(dbApp, pageResult.getList().get(0));
} }
@Test // TODO 请修改 null 为需要的值 @Test // TODO aquan请修改 null 为需要的值
public void testGetAppList() { public void testGetAppList() {
// mock 数据 // mock 数据
PayAppDO dbApp = randomPojo(PayAppDO.class, o -> { // 等会查询到 PayAppDO dbApp = randomPojo(PayAppDO.class, o -> { // 等会查询到

View File

@ -1,30 +1,28 @@
package cn.iocoder.yudao.adminserver.modules.pay.channel; package cn.iocoder.yudao.adminserver.modules.pay.channel;
import cn.iocoder.yudao.coreservice.modules.pay.dal.dataobject.merchant.PayChannelDO;
import org.junit.jupiter.api.Test;
import javax.annotation.Resource;
import cn.iocoder.yudao.adminserver.BaseDbUnitTest; import cn.iocoder.yudao.adminserver.BaseDbUnitTest;
import cn.iocoder.yudao.adminserver.modules.pay.service.channel.impl.PayChannelServiceImpl; import cn.iocoder.yudao.adminserver.modules.pay.controller.channel.vo.PayChannelCreateReqVO;
import cn.iocoder.yudao.adminserver.modules.pay.controller.channel.vo.*; import cn.iocoder.yudao.adminserver.modules.pay.controller.channel.vo.PayChannelExportReqVO;
import cn.iocoder.yudao.adminserver.modules.pay.controller.channel.vo.PayChannelPageReqVO;
import cn.iocoder.yudao.adminserver.modules.pay.controller.channel.vo.PayChannelUpdateReqVO;
import cn.iocoder.yudao.adminserver.modules.pay.dal.mysql.channel.PayChannelMapper; import cn.iocoder.yudao.adminserver.modules.pay.dal.mysql.channel.PayChannelMapper;
import cn.iocoder.yudao.framework.common.util.object.ObjectUtils; import cn.iocoder.yudao.adminserver.modules.pay.service.channel.impl.PayChannelServiceImpl;
import cn.iocoder.yudao.coreservice.modules.pay.dal.dataobject.merchant.PayChannelDO;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.util.object.ObjectUtils;
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 java.util.*;
import static cn.iocoder.yudao.coreservice.modules.pay.enums.PayErrorCodeCoreConstants.*; import javax.annotation.Resource;
import java.util.List;
import static cn.iocoder.yudao.coreservice.modules.pay.enums.PayErrorCodeCoreConstants.CHANNEL_NOT_EXISTS;
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.common.util.date.DateUtils.buildTime; import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.randomLongId;
import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.*; import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.randomPojo;
import static org.junit.jupiter.api.Assertions.*; import static org.junit.jupiter.api.Assertions.*;
import static org.mockito.Mockito.*;
/** /**
* {@link PayChannelServiceImpl} * {@link PayChannelServiceImpl}
* *
@ -152,7 +150,7 @@ public class PayChannelServiceTest extends BaseDbUnitTest {
assertPojoEquals(dbChannel, pageResult.getList().get(0)); assertPojoEquals(dbChannel, pageResult.getList().get(0));
} }
@Test // TODO 请修改 null 为需要的值 @Test // TODO aquan请修改 null 为需要的值
public void testGetChannelList() { public void testGetChannelList() {
// mock 数据 // mock 数据
PayChannelDO dbChannel = randomPojo(PayChannelDO.class, o -> { // 等会查询到 PayChannelDO dbChannel = randomPojo(PayChannelDO.class, o -> { // 等会查询到

View File

@ -46,7 +46,6 @@ public class PayChannelDO extends BaseDO {
* *
*/ */
private Double feeRate; private Double feeRate;
/** /**
* *
*/ */

View File

@ -45,5 +45,7 @@ public interface PayErrorCodeCoreConstants {
*/ */
ErrorCode CHANNEL_NOT_EXISTS = new ErrorCode(1007006000, "支付渠道不存在"); ErrorCode CHANNEL_NOT_EXISTS = new ErrorCode(1007006000, "支付渠道不存在");
ErrorCode CHANNEL_KEY_READ_ERROR = new ErrorCode(1007006002, "支付渠道秘钥文件读取失败"); ErrorCode CHANNEL_KEY_READ_ERROR = new ErrorCode(1007006002, "支付渠道秘钥文件读取失败");
// TODO @aquan下面这个错误码缺了 CHANNEL 前缀。另外,错误码的分段,上面有啦,合并下进去哈
ErrorCode EXIST_SAME_CHANNEL_ERROR = new ErrorCode(1007006003, "已存在相同的渠道"); ErrorCode EXIST_SAME_CHANNEL_ERROR = new ErrorCode(1007006003, "已存在相同的渠道");
} }

View File

@ -16,6 +16,7 @@ public enum PayChannelEnum {
WX_PUB("wx_pub", "微信 JSAPI 支付"), // 公众号的网页 WX_PUB("wx_pub", "微信 JSAPI 支付"), // 公众号的网页
// TODO @芋艿 这个地方你写的是 wx_lit 是不是少写了一个e 还是我这里多加了一个e // TODO @芋艿 这个地方你写的是 wx_lit 是不是少写了一个e 还是我这里多加了一个e
// TODO @aquan这里就是 lite 哈,轻量
WX_LITE("wx_lite","微信小程序支付"), WX_LITE("wx_lite","微信小程序支付"),
WX_APP("wx_app", "微信 App 支付"), WX_APP("wx_app", "微信 App 支付"),