|
@@ -1,22 +1,28 @@
|
|
package cn.iocoder.yudao.module.system.framework.sms.core.client.impl;
|
|
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.http.HttpUtils;
|
|
import cn.iocoder.yudao.framework.test.core.ut.BaseMockitoUnitTest;
|
|
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.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.enums.SmsTemplateAuditStatusEnum;
|
|
import cn.iocoder.yudao.module.system.framework.sms.core.property.SmsChannelProperties;
|
|
import cn.iocoder.yudao.module.system.framework.sms.core.property.SmsChannelProperties;
|
|
|
|
+import com.google.common.collect.Lists;
|
|
|
|
+
|
|
import org.junit.jupiter.api.Test;
|
|
import org.junit.jupiter.api.Test;
|
|
import org.mockito.InjectMocks;
|
|
import org.mockito.InjectMocks;
|
|
-import org.mockito.Mock;
|
|
|
|
|
|
+import org.mockito.MockedStatic;
|
|
|
|
|
|
import java.time.LocalDateTime;
|
|
import java.time.LocalDateTime;
|
|
import java.util.List;
|
|
import java.util.List;
|
|
|
|
|
|
-import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.randomString;
|
|
|
|
|
|
+import static cn.iocoder.yudao.framework.test.core.util.RandomUtils.*;
|
|
import static org.junit.jupiter.api.Assertions.*;
|
|
import static org.junit.jupiter.api.Assertions.*;
|
|
|
|
+import static org.mockito.ArgumentMatchers.*;
|
|
|
|
+import static org.mockito.ArgumentMatchers.anyString;
|
|
|
|
+import static org.mockito.Mockito.mockStatic;
|
|
|
|
|
|
-// TODO @芋艿:补全单测
|
|
|
|
/**
|
|
/**
|
|
* {@link TencentSmsClient} 的单元测试
|
|
* {@link TencentSmsClient} 的单元测试
|
|
*
|
|
*
|
|
@@ -32,9 +38,6 @@ public class TencentSmsClientTest extends BaseMockitoUnitTest {
|
|
@InjectMocks
|
|
@InjectMocks
|
|
private TencentSmsClient smsClient = new TencentSmsClient(properties);
|
|
private TencentSmsClient smsClient = new TencentSmsClient(properties);
|
|
|
|
|
|
- @Mock
|
|
|
|
- private SmsClient client;
|
|
|
|
-
|
|
|
|
@Test
|
|
@Test
|
|
public void testDoInit() {
|
|
public void testDoInit() {
|
|
// 准备参数
|
|
// 准备参数
|
|
@@ -42,104 +45,93 @@ public class TencentSmsClientTest extends BaseMockitoUnitTest {
|
|
|
|
|
|
// 调用
|
|
// 调用
|
|
smsClient.doInit();
|
|
smsClient.doInit();
|
|
- // 断言
|
|
|
|
- assertNotSame(client, ReflectUtil.getFieldValue(smsClient, "client"));
|
|
|
|
}
|
|
}
|
|
|
|
|
|
@Test
|
|
@Test
|
|
- public void testRefresh() {
|
|
|
|
- // 准备参数
|
|
|
|
- SmsChannelProperties p = new SmsChannelProperties()
|
|
|
|
- .setApiKey(randomString() + " " + randomString()) // 随机一个 apiKey,避免构建报错
|
|
|
|
- .setApiSecret(randomString()) // 随机一个 apiSecret,避免构建报错
|
|
|
|
- .setSignature("芋道源码");
|
|
|
|
- // 调用
|
|
|
|
- smsClient.refresh(p);
|
|
|
|
- // 断言
|
|
|
|
- assertNotSame(client, ReflectUtil.getFieldValue(smsClient, "client"));
|
|
|
|
|
|
+ public void testDoSendSms_success() throws Throwable {
|
|
|
|
+
|
|
|
|
+ try (MockedStatic<HttpUtils> httpUtilsMockedStatic = mockStatic(HttpUtils.class)) {
|
|
|
|
+ // 准备参数
|
|
|
|
+ Long sendLogId = randomLongId();
|
|
|
|
+ String mobile = randomString();
|
|
|
|
+ String apiTemplateId = randomString();
|
|
|
|
+ List<KeyValue<String, Object>> templateParams = Lists.newArrayList(
|
|
|
|
+ new KeyValue<>("1", 1234), new KeyValue<>("2", "login"));
|
|
|
|
+
|
|
|
|
+ // mock 方法
|
|
|
|
+ httpUtilsMockedStatic.when(() -> HttpUtils.post(anyString(), anyMap(), anyString()))
|
|
|
|
+ .thenReturn(
|
|
|
|
+ "{\n" +
|
|
|
|
+ " \"Response\": {\n" +
|
|
|
|
+ " \"SendStatusSet\": [\n" +
|
|
|
|
+ " {\n" +
|
|
|
|
+ " \"SerialNo\": \"5000:1045710669157053657849499619\",\n" +
|
|
|
|
+ " \"PhoneNumber\": \"+8618511122233\",\n" +
|
|
|
|
+ " \"Fee\": 1,\n" +
|
|
|
|
+ " \"SessionContext\": \"test\",\n" +
|
|
|
|
+ " \"Code\": \"Ok\",\n" +
|
|
|
|
+ " \"Message\": \"send success\",\n" +
|
|
|
|
+ " \"IsoCode\": \"CN\"\n" +
|
|
|
|
+ " },\n" +
|
|
|
|
+ " ],\n" +
|
|
|
|
+ " \"RequestId\": \"a0aabda6-cf91-4f3e-a81f-9198114a2279\"\n" +
|
|
|
|
+ " }\n" +
|
|
|
|
+ "}"
|
|
|
|
+ );
|
|
|
|
+
|
|
|
|
+ // 调用
|
|
|
|
+ SmsSendRespDTO result = smsClient.sendSms(sendLogId, mobile,
|
|
|
|
+ apiTemplateId, templateParams);
|
|
|
|
+ // 断言
|
|
|
|
+ assertTrue(result.getSuccess());
|
|
|
|
+ assertEquals("5000:1045710669157053657849499619", result.getSerialNo());
|
|
|
|
+ assertEquals("a0aabda6-cf91-4f3e-a81f-9198114a2279", result.getApiRequestId());
|
|
|
|
+ assertEquals("send success", result.getApiMsg());
|
|
|
|
+
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
-// @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());
|
|
|
|
-// }
|
|
|
|
-
|
|
|
|
-// @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 {
|
|
|
|
+ try (MockedStatic<HttpUtils> httpUtilsMockedStatic = mockStatic(HttpUtils.class)) {
|
|
|
|
+ // 准备参数
|
|
|
|
+ Long sendLogId = randomLongId();
|
|
|
|
+ String mobile = randomString();
|
|
|
|
+ String apiTemplateId = randomString();
|
|
|
|
+ List<KeyValue<String, Object>> templateParams = Lists.newArrayList(
|
|
|
|
+ new KeyValue<>("1", 1234), new KeyValue<>("2", "login"));
|
|
|
|
+
|
|
|
|
+ // mock 方法
|
|
|
|
+ httpUtilsMockedStatic.when(() -> HttpUtils.post(anyString(), anyMap(), anyString()))
|
|
|
|
+ .thenReturn(
|
|
|
|
+ "{\n" +
|
|
|
|
+ " \"Response\": {\n" +
|
|
|
|
+ " \"SendStatusSet\": [\n" +
|
|
|
|
+ " {\n" +
|
|
|
|
+ " \"SerialNo\": \"5000:1045710669157053657849499619\",\n" +
|
|
|
|
+ " \"PhoneNumber\": \"+8618511122233\",\n" +
|
|
|
|
+ " \"Fee\": 1,\n" +
|
|
|
|
+ " \"SessionContext\": \"test\",\n" +
|
|
|
|
+ " \"Code\": \"ERROR\",\n" +
|
|
|
|
+ " \"Message\": \"send success\",\n" +
|
|
|
|
+ " \"IsoCode\": \"CN\"\n" +
|
|
|
|
+ " },\n" +
|
|
|
|
+ " ],\n" +
|
|
|
|
+ " \"RequestId\": \"a0aabda6-cf91-4f3e-a81f-9198114a2279\"\n" +
|
|
|
|
+ " }\n" +
|
|
|
|
+ "}"
|
|
|
|
+ );
|
|
|
|
+
|
|
|
|
+ // 调用
|
|
|
|
+ SmsSendRespDTO result = smsClient.sendSms(sendLogId, mobile,
|
|
|
|
+ apiTemplateId, templateParams);
|
|
|
|
+ // 断言
|
|
|
|
+ assertFalse(result.getSuccess());
|
|
|
|
+ assertEquals("5000:1045710669157053657849499619", result.getSerialNo());
|
|
|
|
+ assertEquals("a0aabda6-cf91-4f3e-a81f-9198114a2279", result.getApiRequestId());
|
|
|
|
+ assertEquals("send success", result.getApiMsg());
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
|
|
@Test
|
|
@Test
|
|
public void testParseSmsReceiveStatus() {
|
|
public void testParseSmsReceiveStatus() {
|
|
@@ -156,7 +148,6 @@ public class TencentSmsClientTest extends BaseMockitoUnitTest {
|
|
" \"ext\": {\"logId\":\"67890\"}\n" +
|
|
" \"ext\": {\"logId\":\"67890\"}\n" +
|
|
" }\n" +
|
|
" }\n" +
|
|
"]";
|
|
"]";
|
|
- // mock 方法
|
|
|
|
|
|
|
|
// 调用
|
|
// 调用
|
|
List<SmsReceiveRespDTO> statuses = smsClient.parseSmsReceiveStatus(text);
|
|
List<SmsReceiveRespDTO> statuses = smsClient.parseSmsReceiveStatus(text);
|
|
@@ -164,42 +155,46 @@ public class TencentSmsClientTest extends BaseMockitoUnitTest {
|
|
assertEquals(1, statuses.size());
|
|
assertEquals(1, statuses.size());
|
|
assertTrue(statuses.get(0).getSuccess());
|
|
assertTrue(statuses.get(0).getSuccess());
|
|
assertEquals("DELIVRD", statuses.get(0).getErrorCode());
|
|
assertEquals("DELIVRD", statuses.get(0).getErrorCode());
|
|
- assertEquals("用户短信送达成功", statuses.get(0).getErrorMsg());
|
|
|
|
assertEquals("13900000001", statuses.get(0).getMobile());
|
|
assertEquals("13900000001", statuses.get(0).getMobile());
|
|
assertEquals(LocalDateTime.of(2015, 10, 17, 8, 3, 4), statuses.get(0).getReceiveTime());
|
|
assertEquals(LocalDateTime.of(2015, 10, 17, 8, 3, 4), statuses.get(0).getReceiveTime());
|
|
assertEquals("12345", statuses.get(0).getSerialNo());
|
|
assertEquals("12345", statuses.get(0).getSerialNo());
|
|
- 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 {
|
|
|
|
+
|
|
|
|
+ try (MockedStatic<HttpUtils> httpUtilsMockedStatic = mockStatic(HttpUtils.class)) {
|
|
|
|
+
|
|
|
|
+ // 准备参数
|
|
|
|
+ String apiTemplateId = "1122";
|
|
|
|
+
|
|
|
|
+ // mock 方法
|
|
|
|
+ httpUtilsMockedStatic.when(() -> HttpUtils.post(anyString(), anyMap(), anyString()))
|
|
|
|
+ .thenReturn("{ \"Response\": {\n" +
|
|
|
|
+ " \"DescribeTemplateStatusSet\": [\n" +
|
|
|
|
+ " {\n" +
|
|
|
|
+ " \"TemplateName\": \"验证码\",\n" +
|
|
|
|
+ " \"TemplateId\": 1122,\n" +
|
|
|
|
+ " \"International\": 0,\n" +
|
|
|
|
+ " \"ReviewReply\": \"审批备注\",\n" +
|
|
|
|
+ " \"CreateTime\": 1617379200,\n" +
|
|
|
|
+ " \"TemplateContent\": \"您的验证码是{1}\",\n" +
|
|
|
|
+ " \"StatusCode\": 0\n" +
|
|
|
|
+ " },\n" +
|
|
|
|
+ " \n" +
|
|
|
|
+ " ],\n" +
|
|
|
|
+ " \"RequestId\": \"f36e4f00-605e-49b1-ad0d-bfaba81c7325\"\n" +
|
|
|
|
+ " }}");
|
|
|
|
+
|
|
|
|
+ // 调用
|
|
|
|
+ SmsTemplateRespDTO result = smsClient.getSmsTemplate(apiTemplateId);
|
|
|
|
+ // 断言
|
|
|
|
+ assertEquals("1122", result.getId());
|
|
|
|
+ assertEquals("您的验证码是{1}", result.getContent());
|
|
|
|
+ assertEquals(SmsTemplateAuditStatusEnum.SUCCESS.getStatus(), result.getAuditStatus());
|
|
|
|
+ assertEquals("审批备注", result.getAuditReason());
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
|
|
@Test
|
|
@Test
|
|
public void testConvertSmsTemplateAuditStatus() {
|
|
public void testConvertSmsTemplateAuditStatus() {
|