mirror of
				https://gitee.com/hhyykk/ipms-sjy.git
				synced 2025-11-04 12:18:42 +08:00 
			
		
		
		
	【代码优化】SYSTEM:去除腾讯云短信的 maven 依赖
This commit is contained in:
		@@ -18,11 +18,11 @@ import cn.iocoder.yudao.module.system.framework.sms.core.property.SmsChannelProp
 | 
			
		||||
import com.fasterxml.jackson.annotation.JsonFormat;
 | 
			
		||||
import com.fasterxml.jackson.annotation.JsonProperty;
 | 
			
		||||
import com.google.common.annotations.VisibleForTesting;
 | 
			
		||||
import jakarta.xml.bind.DatatypeConverter;
 | 
			
		||||
import lombok.Data;
 | 
			
		||||
 | 
			
		||||
import javax.crypto.Mac;
 | 
			
		||||
import javax.crypto.spec.SecretKeySpec;
 | 
			
		||||
import javax.xml.bind.DatatypeConverter;
 | 
			
		||||
import java.nio.charset.StandardCharsets;
 | 
			
		||||
import java.text.SimpleDateFormat;
 | 
			
		||||
import java.time.LocalDateTime;
 | 
			
		||||
@@ -33,6 +33,7 @@ import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.
 | 
			
		||||
import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
 | 
			
		||||
import static cn.iocoder.yudao.framework.common.util.date.DateUtils.TIME_ZONE_DEFAULT;
 | 
			
		||||
 | 
			
		||||
// TODO @scholar 建议参考 AliyunSmsClient 优化下
 | 
			
		||||
/**
 | 
			
		||||
 * 腾讯云短信功能实现
 | 
			
		||||
 *
 | 
			
		||||
@@ -218,7 +219,7 @@ public class TencentSmsClient extends AbstractSmsClient {
 | 
			
		||||
 | 
			
		||||
        QuerySmsTemplateResponse.TemplateInfo templateInfo = new QuerySmsTemplateResponse.TemplateInfo();
 | 
			
		||||
 | 
			
		||||
        Object statusObject = resJson.getJSONObject("Response").getJSONArray("DescribeTemplateStatusSet").getFirst();
 | 
			
		||||
        Object statusObject = resJson.getJSONObject("Response").getJSONArray("DescribeTemplateStatusSet").get(0);
 | 
			
		||||
 | 
			
		||||
        JSONObject statusJSON = new JSONObject(statusObject);
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -1,36 +1,22 @@
 | 
			
		||||
package cn.iocoder.yudao.module.system.framework.sms.core.client.impl;
 | 
			
		||||
 | 
			
		||||
import cn.hutool.core.util.ReflectUtil;
 | 
			
		||||
import cn.iocoder.yudao.framework.common.core.KeyValue;
 | 
			
		||||
import cn.iocoder.yudao.framework.common.util.collection.ArrayUtils;
 | 
			
		||||
import cn.iocoder.yudao.framework.common.util.collection.MapUtils;
 | 
			
		||||
import cn.iocoder.yudao.framework.common.util.json.JsonUtils;
 | 
			
		||||
import cn.iocoder.yudao.framework.test.core.ut.BaseMockitoUnitTest;
 | 
			
		||||
import cn.iocoder.yudao.module.system.framework.sms.core.client.SmsClient;
 | 
			
		||||
import cn.iocoder.yudao.module.system.framework.sms.core.client.dto.SmsReceiveRespDTO;
 | 
			
		||||
import cn.iocoder.yudao.module.system.framework.sms.core.client.dto.SmsSendRespDTO;
 | 
			
		||||
import cn.iocoder.yudao.module.system.framework.sms.core.client.dto.SmsTemplateRespDTO;
 | 
			
		||||
import cn.iocoder.yudao.module.system.framework.sms.core.enums.SmsTemplateAuditStatusEnum;
 | 
			
		||||
import cn.iocoder.yudao.module.system.framework.sms.core.property.SmsChannelProperties;
 | 
			
		||||
import com.google.common.collect.Lists;
 | 
			
		||||
import com.tencentcloudapi.sms.v20210111.SmsClient;
 | 
			
		||||
import com.tencentcloudapi.sms.v20210111.models.DescribeSmsTemplateListResponse;
 | 
			
		||||
import com.tencentcloudapi.sms.v20210111.models.DescribeTemplateListStatus;
 | 
			
		||||
import com.tencentcloudapi.sms.v20210111.models.SendSmsResponse;
 | 
			
		||||
import com.tencentcloudapi.sms.v20210111.models.SendStatus;
 | 
			
		||||
import org.junit.jupiter.api.Test;
 | 
			
		||||
import org.mockito.InjectMocks;
 | 
			
		||||
import org.mockito.Mock;
 | 
			
		||||
 | 
			
		||||
import java.time.LocalDateTime;
 | 
			
		||||
import java.util.ArrayList;
 | 
			
		||||
import java.util.List;
 | 
			
		||||
 | 
			
		||||
import static cn.iocoder.yudao.framework.common.util.json.JsonUtils.toJsonString;
 | 
			
		||||
import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.*;
 | 
			
		||||
import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.randomString;
 | 
			
		||||
import static org.junit.jupiter.api.Assertions.*;
 | 
			
		||||
import static org.mockito.ArgumentMatchers.argThat;
 | 
			
		||||
import static org.mockito.Mockito.when;
 | 
			
		||||
 | 
			
		||||
// TODO @芋艿:补全单测
 | 
			
		||||
/**
 | 
			
		||||
 * {@link TencentSmsClient} 的单元测试
 | 
			
		||||
 *
 | 
			
		||||
@@ -73,87 +59,87 @@ public class TencentSmsClientTest extends BaseMockitoUnitTest {
 | 
			
		||||
        assertNotSame(client, ReflectUtil.getFieldValue(smsClient, "client"));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @Test
 | 
			
		||||
    public void testDoSendSms_success() throws Throwable {
 | 
			
		||||
        // 准备参数
 | 
			
		||||
        Long sendLogId = randomLongId();
 | 
			
		||||
        String mobile = randomString();
 | 
			
		||||
        String apiTemplateId = randomString();
 | 
			
		||||
        List<KeyValue<String, Object>> templateParams = Lists.newArrayList(
 | 
			
		||||
                new KeyValue<>("1", 1234), new KeyValue<>("2", "login"));
 | 
			
		||||
        String requestId = randomString();
 | 
			
		||||
        String serialNo = randomString();
 | 
			
		||||
        // mock 方法
 | 
			
		||||
        SendSmsResponse response = randomPojo(SendSmsResponse.class, o -> {
 | 
			
		||||
            o.setRequestId(requestId);
 | 
			
		||||
            SendStatus[] sendStatuses = new SendStatus[1];
 | 
			
		||||
            o.setSendStatusSet(sendStatuses);
 | 
			
		||||
            SendStatus sendStatus = new SendStatus();
 | 
			
		||||
            sendStatuses[0] = sendStatus;
 | 
			
		||||
            sendStatus.setCode(TencentSmsClient.API_CODE_SUCCESS);
 | 
			
		||||
            sendStatus.setMessage("send success");
 | 
			
		||||
            sendStatus.setSerialNo(serialNo);
 | 
			
		||||
        });
 | 
			
		||||
        when(client.SendSms(argThat(request -> {
 | 
			
		||||
            assertEquals(mobile, request.getPhoneNumberSet()[0]);
 | 
			
		||||
            assertEquals(properties.getSignature(), request.getSignName());
 | 
			
		||||
            assertEquals(apiTemplateId, request.getTemplateId());
 | 
			
		||||
            assertEquals(toJsonString(ArrayUtils.toArray(new ArrayList<>(MapUtils.convertMap(templateParams).values()), String::valueOf)),
 | 
			
		||||
                    toJsonString(request.getTemplateParamSet()));
 | 
			
		||||
            assertEquals(sendLogId, ReflectUtil.getFieldValue(JsonUtils.parseObject(request.getSessionContext(), TencentSmsClient.SessionContext.class), "logId"));
 | 
			
		||||
            return true;
 | 
			
		||||
        }))).thenReturn(response);
 | 
			
		||||
//    @Test
 | 
			
		||||
//    public void testDoSendSms_success() throws Throwable {
 | 
			
		||||
//        // 准备参数
 | 
			
		||||
//        Long sendLogId = randomLongId();
 | 
			
		||||
//        String mobile = randomString();
 | 
			
		||||
//        String apiTemplateId = randomString();
 | 
			
		||||
//        List<KeyValue<String, Object>> templateParams = Lists.newArrayList(
 | 
			
		||||
//                new KeyValue<>("1", 1234), new KeyValue<>("2", "login"));
 | 
			
		||||
//        String requestId = randomString();
 | 
			
		||||
//        String serialNo = randomString();
 | 
			
		||||
//        // mock 方法
 | 
			
		||||
//        SendSmsResponse response = randomPojo(SendSmsResponse.class, o -> {
 | 
			
		||||
//            o.setRequestId(requestId);
 | 
			
		||||
//            SendStatus[] sendStatuses = new SendStatus[1];
 | 
			
		||||
//            o.setSendStatusSet(sendStatuses);
 | 
			
		||||
//            SendStatus sendStatus = new SendStatus();
 | 
			
		||||
//            sendStatuses[0] = sendStatus;
 | 
			
		||||
//            sendStatus.setCode(TencentSmsClient.API_CODE_SUCCESS);
 | 
			
		||||
//            sendStatus.setMessage("send success");
 | 
			
		||||
//            sendStatus.setSerialNo(serialNo);
 | 
			
		||||
//        });
 | 
			
		||||
//        when(client.SendSms(argThat(request -> {
 | 
			
		||||
//            assertEquals(mobile, request.getPhoneNumberSet()[0]);
 | 
			
		||||
//            assertEquals(properties.getSignature(), request.getSignName());
 | 
			
		||||
//            assertEquals(apiTemplateId, request.getTemplateId());
 | 
			
		||||
//            assertEquals(toJsonString(ArrayUtils.toArray(new ArrayList<>(MapUtils.convertMap(templateParams).values()), String::valueOf)),
 | 
			
		||||
//                    toJsonString(request.getTemplateParamSet()));
 | 
			
		||||
//            assertEquals(sendLogId, ReflectUtil.getFieldValue(JsonUtils.parseObject(request.getSessionContext(), TencentSmsClient.SessionContext.class), "logId"));
 | 
			
		||||
//            return true;
 | 
			
		||||
//        }))).thenReturn(response);
 | 
			
		||||
//
 | 
			
		||||
//        // 调用
 | 
			
		||||
//        SmsSendRespDTO result = smsClient.sendSms(sendLogId, mobile, apiTemplateId, templateParams);
 | 
			
		||||
//        // 断言
 | 
			
		||||
//        assertTrue(result.getSuccess());
 | 
			
		||||
//        assertEquals(response.getRequestId(), result.getApiRequestId());
 | 
			
		||||
//        assertEquals(response.getSendStatusSet()[0].getCode(), result.getApiCode());
 | 
			
		||||
//        assertEquals(response.getSendStatusSet()[0].getMessage(), result.getApiMsg());
 | 
			
		||||
//        assertEquals(response.getSendStatusSet()[0].getSerialNo(), result.getSerialNo());
 | 
			
		||||
//    }
 | 
			
		||||
 | 
			
		||||
        // 调用
 | 
			
		||||
        SmsSendRespDTO result = smsClient.sendSms(sendLogId, mobile, apiTemplateId, templateParams);
 | 
			
		||||
        // 断言
 | 
			
		||||
        assertTrue(result.getSuccess());
 | 
			
		||||
        assertEquals(response.getRequestId(), result.getApiRequestId());
 | 
			
		||||
        assertEquals(response.getSendStatusSet()[0].getCode(), result.getApiCode());
 | 
			
		||||
        assertEquals(response.getSendStatusSet()[0].getMessage(), result.getApiMsg());
 | 
			
		||||
        assertEquals(response.getSendStatusSet()[0].getSerialNo(), result.getSerialNo());
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @Test
 | 
			
		||||
    public void testDoSendSms_fail() throws Throwable {
 | 
			
		||||
        // 准备参数
 | 
			
		||||
        Long sendLogId = randomLongId();
 | 
			
		||||
        String mobile = randomString();
 | 
			
		||||
        String apiTemplateId = randomString();
 | 
			
		||||
        List<KeyValue<String, Object>> templateParams = Lists.newArrayList(
 | 
			
		||||
                new KeyValue<>("1", 1234), new KeyValue<>("2", "login"));
 | 
			
		||||
        String requestId = randomString();
 | 
			
		||||
        String serialNo = randomString();
 | 
			
		||||
        // mock 方法
 | 
			
		||||
        SendSmsResponse response = randomPojo(SendSmsResponse.class, o -> {
 | 
			
		||||
            o.setRequestId(requestId);
 | 
			
		||||
            SendStatus[] sendStatuses = new SendStatus[1];
 | 
			
		||||
            o.setSendStatusSet(sendStatuses);
 | 
			
		||||
            SendStatus sendStatus = new SendStatus();
 | 
			
		||||
            sendStatuses[0] = sendStatus;
 | 
			
		||||
            sendStatus.setCode("ERROR");
 | 
			
		||||
            sendStatus.setMessage("send success");
 | 
			
		||||
            sendStatus.setSerialNo(serialNo);
 | 
			
		||||
        });
 | 
			
		||||
        when(client.SendSms(argThat(request -> {
 | 
			
		||||
            assertEquals(mobile, request.getPhoneNumberSet()[0]);
 | 
			
		||||
            assertEquals(properties.getSignature(), request.getSignName());
 | 
			
		||||
            assertEquals(apiTemplateId, request.getTemplateId());
 | 
			
		||||
            assertEquals(toJsonString(ArrayUtils.toArray(new ArrayList<>(MapUtils.convertMap(templateParams).values()), String::valueOf)),
 | 
			
		||||
                    toJsonString(request.getTemplateParamSet()));
 | 
			
		||||
            assertEquals(sendLogId, ReflectUtil.getFieldValue(JsonUtils.parseObject(request.getSessionContext(), TencentSmsClient.SessionContext.class), "logId"));
 | 
			
		||||
            return true;
 | 
			
		||||
        }))).thenReturn(response);
 | 
			
		||||
 | 
			
		||||
        // 调用
 | 
			
		||||
        SmsSendRespDTO result = smsClient.sendSms(sendLogId, mobile, apiTemplateId, templateParams);
 | 
			
		||||
        // 断言
 | 
			
		||||
        assertFalse(result.getSuccess());
 | 
			
		||||
        assertEquals(response.getRequestId(), result.getApiRequestId());
 | 
			
		||||
        assertEquals(response.getSendStatusSet()[0].getCode(), result.getApiCode());
 | 
			
		||||
        assertEquals(response.getSendStatusSet()[0].getMessage(), result.getApiMsg());
 | 
			
		||||
        assertEquals(response.getSendStatusSet()[0].getSerialNo(), result.getSerialNo());
 | 
			
		||||
    }
 | 
			
		||||
//    @Test
 | 
			
		||||
//    public void testDoSendSms_fail() throws Throwable {
 | 
			
		||||
//        // 准备参数
 | 
			
		||||
//        Long sendLogId = randomLongId();
 | 
			
		||||
//        String mobile = randomString();
 | 
			
		||||
//        String apiTemplateId = randomString();
 | 
			
		||||
//        List<KeyValue<String, Object>> templateParams = Lists.newArrayList(
 | 
			
		||||
//                new KeyValue<>("1", 1234), new KeyValue<>("2", "login"));
 | 
			
		||||
//        String requestId = randomString();
 | 
			
		||||
//        String serialNo = randomString();
 | 
			
		||||
//        // mock 方法
 | 
			
		||||
//        SendSmsResponse response = randomPojo(SendSmsResponse.class, o -> {
 | 
			
		||||
//            o.setRequestId(requestId);
 | 
			
		||||
//            SendStatus[] sendStatuses = new SendStatus[1];
 | 
			
		||||
//            o.setSendStatusSet(sendStatuses);
 | 
			
		||||
//            SendStatus sendStatus = new SendStatus();
 | 
			
		||||
//            sendStatuses[0] = sendStatus;
 | 
			
		||||
//            sendStatus.setCode("ERROR");
 | 
			
		||||
//            sendStatus.setMessage("send success");
 | 
			
		||||
//            sendStatus.setSerialNo(serialNo);
 | 
			
		||||
//        });
 | 
			
		||||
//        when(client.SendSms(argThat(request -> {
 | 
			
		||||
//            assertEquals(mobile, request.getPhoneNumberSet()[0]);
 | 
			
		||||
//            assertEquals(properties.getSignature(), request.getSignName());
 | 
			
		||||
//            assertEquals(apiTemplateId, request.getTemplateId());
 | 
			
		||||
//            assertEquals(toJsonString(ArrayUtils.toArray(new ArrayList<>(MapUtils.convertMap(templateParams).values()), String::valueOf)),
 | 
			
		||||
//                    toJsonString(request.getTemplateParamSet()));
 | 
			
		||||
//            assertEquals(sendLogId, ReflectUtil.getFieldValue(JsonUtils.parseObject(request.getSessionContext(), TencentSmsClient.SessionContext.class), "logId"));
 | 
			
		||||
//            return true;
 | 
			
		||||
//        }))).thenReturn(response);
 | 
			
		||||
//
 | 
			
		||||
//        // 调用
 | 
			
		||||
//        SmsSendRespDTO result = smsClient.sendSms(sendLogId, mobile, apiTemplateId, templateParams);
 | 
			
		||||
//        // 断言
 | 
			
		||||
//        assertFalse(result.getSuccess());
 | 
			
		||||
//        assertEquals(response.getRequestId(), result.getApiRequestId());
 | 
			
		||||
//        assertEquals(response.getSendStatusSet()[0].getCode(), result.getApiCode());
 | 
			
		||||
//        assertEquals(response.getSendStatusSet()[0].getMessage(), result.getApiMsg());
 | 
			
		||||
//        assertEquals(response.getSendStatusSet()[0].getSerialNo(), result.getSerialNo());
 | 
			
		||||
//    }
 | 
			
		||||
 | 
			
		||||
    @Test
 | 
			
		||||
    public void testParseSmsReceiveStatus() {
 | 
			
		||||
@@ -185,35 +171,35 @@ public class TencentSmsClientTest extends BaseMockitoUnitTest {
 | 
			
		||||
        assertEquals(67890L, statuses.get(0).getLogId());
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @Test
 | 
			
		||||
    public void testGetSmsTemplate() throws Throwable {
 | 
			
		||||
        // 准备参数
 | 
			
		||||
        Long apiTemplateId = randomLongId();
 | 
			
		||||
        String requestId = randomString();
 | 
			
		||||
 | 
			
		||||
        // mock 方法
 | 
			
		||||
        DescribeSmsTemplateListResponse response = randomPojo(DescribeSmsTemplateListResponse.class, o -> {
 | 
			
		||||
            DescribeTemplateListStatus[] describeTemplateListStatuses = new DescribeTemplateListStatus[1];
 | 
			
		||||
            DescribeTemplateListStatus templateStatus = new DescribeTemplateListStatus();
 | 
			
		||||
            templateStatus.setTemplateId(apiTemplateId);
 | 
			
		||||
            templateStatus.setStatusCode(0L);// 设置模板通过
 | 
			
		||||
            describeTemplateListStatuses[0] = templateStatus;
 | 
			
		||||
            o.setDescribeTemplateStatusSet(describeTemplateListStatuses);
 | 
			
		||||
            o.setRequestId(requestId);
 | 
			
		||||
        });
 | 
			
		||||
        when(client.DescribeSmsTemplateList(argThat(request -> {
 | 
			
		||||
            assertEquals(apiTemplateId, request.getTemplateIdSet()[0]);
 | 
			
		||||
            return true;
 | 
			
		||||
        }))).thenReturn(response);
 | 
			
		||||
 | 
			
		||||
        // 调用
 | 
			
		||||
        SmsTemplateRespDTO result = smsClient.getSmsTemplate(apiTemplateId.toString());
 | 
			
		||||
        // 断言
 | 
			
		||||
        assertEquals(response.getDescribeTemplateStatusSet()[0].getTemplateId().toString(), result.getId());
 | 
			
		||||
        assertEquals(response.getDescribeTemplateStatusSet()[0].getTemplateContent(), result.getContent());
 | 
			
		||||
        assertEquals(SmsTemplateAuditStatusEnum.SUCCESS.getStatus(), result.getAuditStatus());
 | 
			
		||||
        assertEquals(response.getDescribeTemplateStatusSet()[0].getReviewReply(), result.getAuditReason());
 | 
			
		||||
    }
 | 
			
		||||
//    @Test
 | 
			
		||||
//    public void testGetSmsTemplate() throws Throwable {
 | 
			
		||||
//        // 准备参数
 | 
			
		||||
//        Long apiTemplateId = randomLongId();
 | 
			
		||||
//        String requestId = randomString();
 | 
			
		||||
//
 | 
			
		||||
//        // mock 方法
 | 
			
		||||
//        DescribeSmsTemplateListResponse response = randomPojo(DescribeSmsTemplateListResponse.class, o -> {
 | 
			
		||||
//            DescribeTemplateListStatus[] describeTemplateListStatuses = new DescribeTemplateListStatus[1];
 | 
			
		||||
//            DescribeTemplateListStatus templateStatus = new DescribeTemplateListStatus();
 | 
			
		||||
//            templateStatus.setTemplateId(apiTemplateId);
 | 
			
		||||
//            templateStatus.setStatusCode(0L);// 设置模板通过
 | 
			
		||||
//            describeTemplateListStatuses[0] = templateStatus;
 | 
			
		||||
//            o.setDescribeTemplateStatusSet(describeTemplateListStatuses);
 | 
			
		||||
//            o.setRequestId(requestId);
 | 
			
		||||
//        });
 | 
			
		||||
//        when(client.DescribeSmsTemplateList(argThat(request -> {
 | 
			
		||||
//            assertEquals(apiTemplateId, request.getTemplateIdSet()[0]);
 | 
			
		||||
//            return true;
 | 
			
		||||
//        }))).thenReturn(response);
 | 
			
		||||
//
 | 
			
		||||
//        // 调用
 | 
			
		||||
//        SmsTemplateRespDTO result = smsClient.getSmsTemplate(apiTemplateId.toString());
 | 
			
		||||
//        // 断言
 | 
			
		||||
//        assertEquals(response.getDescribeTemplateStatusSet()[0].getTemplateId().toString(), result.getId());
 | 
			
		||||
//        assertEquals(response.getDescribeTemplateStatusSet()[0].getTemplateContent(), result.getContent());
 | 
			
		||||
//        assertEquals(SmsTemplateAuditStatusEnum.SUCCESS.getStatus(), result.getAuditStatus());
 | 
			
		||||
//        assertEquals(response.getDescribeTemplateStatusSet()[0].getReviewReply(), result.getAuditReason());
 | 
			
		||||
//    }
 | 
			
		||||
 | 
			
		||||
    @Test
 | 
			
		||||
    public void testConvertSmsTemplateAuditStatus() {
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user