mirror of
https://gitee.com/binary/weixin-java-tools.git
synced 2026-02-15 04:48:18 +08:00
🎨 #1497 微信公众号群发图文消息接口参数优化,保持跟普通发送接口一致,减少重复代码
This commit is contained in:
@@ -12,14 +12,17 @@ import me.chanjar.weixin.mp.bean.WxMpMassNews;
|
||||
import me.chanjar.weixin.mp.bean.WxMpMassOpenIdsMessage;
|
||||
import me.chanjar.weixin.mp.bean.WxMpMassTagMessage;
|
||||
import me.chanjar.weixin.mp.bean.WxMpMassVideo;
|
||||
import me.chanjar.weixin.mp.bean.material.WxMpNewsArticle;
|
||||
import me.chanjar.weixin.mp.bean.result.WxMpMassSendResult;
|
||||
import me.chanjar.weixin.mp.bean.result.WxMpMassUploadResult;
|
||||
import org.testng.annotations.*;
|
||||
import org.testng.annotations.DataProvider;
|
||||
import org.testng.annotations.Guice;
|
||||
import org.testng.annotations.Test;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.io.InputStream;
|
||||
|
||||
import static org.testng.Assert.*;
|
||||
import static org.testng.Assert.assertNotNull;
|
||||
|
||||
/**
|
||||
* 测试群发消息
|
||||
@@ -35,15 +38,13 @@ public class WxMpMassMessageServiceImplTest {
|
||||
@Test
|
||||
public void testTextMassOpenIdsMessageSend() throws WxErrorException {
|
||||
// 发送群发消息
|
||||
TestConfigStorage configProvider = (TestConfigStorage) this.wxService
|
||||
.getWxMpConfigStorage();
|
||||
TestConfigStorage configProvider = (TestConfigStorage) this.wxService .getWxMpConfigStorage();
|
||||
WxMpMassOpenIdsMessage massMessage = new WxMpMassOpenIdsMessage();
|
||||
massMessage.setMsgType(WxConsts.MassMsgType.TEXT);
|
||||
massMessage.setContent("测试群发消息\n欢迎欢迎,热烈欢迎\n换行测试\n超链接:<a href=\"http://www.baidu.com\">Hello World</a>");
|
||||
massMessage.setContent("测试群发消息\n欢迎欢迎\n换行测试\n超链接:<a href=\"http://www.baidu.com\">Hello World</a>");
|
||||
massMessage.getToUsers().add(configProvider.getOpenid());
|
||||
|
||||
WxMpMassSendResult massResult = this.wxService.getMassMessageService()
|
||||
.massOpenIdsMessageSend(massMessage);
|
||||
WxMpMassSendResult massResult = this.wxService.getMassMessageService().massOpenIdsMessageSend(massMessage);
|
||||
assertNotNull(massResult);
|
||||
assertNotNull(massResult.getMsgId());
|
||||
}
|
||||
@@ -51,15 +52,13 @@ public class WxMpMassMessageServiceImplTest {
|
||||
@Test(dataProvider = "massMessages")
|
||||
public void testMediaMassOpenIdsMessageSend(String massMsgType, String mediaId) throws WxErrorException {
|
||||
// 发送群发消息
|
||||
TestConfigStorage configProvider = (TestConfigStorage) this.wxService
|
||||
.getWxMpConfigStorage();
|
||||
TestConfigStorage configProvider = (TestConfigStorage) this.wxService.getWxMpConfigStorage();
|
||||
WxMpMassOpenIdsMessage massMessage = new WxMpMassOpenIdsMessage();
|
||||
massMessage.setMsgType(massMsgType);
|
||||
massMessage.setMediaId(mediaId);
|
||||
massMessage.getToUsers().add(configProvider.getOpenid());
|
||||
|
||||
WxMpMassSendResult massResult = this.wxService.getMassMessageService()
|
||||
.massOpenIdsMessageSend(massMessage);
|
||||
WxMpMassSendResult massResult = this.wxService.getMassMessageService().massOpenIdsMessageSend(massMessage);
|
||||
assertNotNull(massResult);
|
||||
assertNotNull(massResult.getMsgId());
|
||||
}
|
||||
@@ -68,26 +67,23 @@ public class WxMpMassMessageServiceImplTest {
|
||||
public void testTextMassGroupMessageSend() throws WxErrorException {
|
||||
WxMpMassTagMessage massMessage = new WxMpMassTagMessage();
|
||||
massMessage.setMsgType(WxConsts.MassMsgType.TEXT);
|
||||
massMessage.setContent("测试群发消息\n欢迎欢迎,热烈欢迎\n换行测试\n超链接:<a href=\"http://www.baidu.com\">Hello World</a>");
|
||||
massMessage.setContent("测试群发消息\n欢迎欢迎\n换行测试\n超链接:<a href=\"http://www.baidu.com\">Hello World</a>");
|
||||
massMessage
|
||||
.setTagId(this.wxService.getUserTagService().tagGet().get(0).getId());
|
||||
|
||||
WxMpMassSendResult massResult = this.wxService.getMassMessageService()
|
||||
.massGroupMessageSend(massMessage);
|
||||
WxMpMassSendResult massResult = this.wxService.getMassMessageService().massGroupMessageSend(massMessage);
|
||||
assertNotNull(massResult);
|
||||
assertNotNull(massResult.getMsgId());
|
||||
}
|
||||
|
||||
@Test(dataProvider = "massMessages")
|
||||
public void testMediaMassGroupMessageSend(String massMsgType, String mediaId)
|
||||
throws WxErrorException {
|
||||
public void testMediaMassGroupMessageSend(String massMsgType, String mediaId) throws WxErrorException {
|
||||
WxMpMassTagMessage massMessage = new WxMpMassTagMessage();
|
||||
massMessage.setMsgType(massMsgType);
|
||||
massMessage.setMediaId(mediaId);
|
||||
massMessage.setTagId(this.wxService.getUserTagService().tagGet().get(0).getId());
|
||||
|
||||
WxMpMassSendResult massResult = this.wxService.getMassMessageService()
|
||||
.massGroupMessageSend(massMessage);
|
||||
WxMpMassSendResult massResult = this.wxService.getMassMessageService().massGroupMessageSend(massMessage);
|
||||
assertNotNull(massResult);
|
||||
assertNotNull(massResult.getMsgId());
|
||||
}
|
||||
@@ -155,15 +151,15 @@ public class WxMpMassMessageServiceImplTest {
|
||||
|
||||
// 上传图文消息
|
||||
WxMpMassNews news = new WxMpMassNews();
|
||||
WxMpMassNews.WxMpMassNewsArticle article1 = new WxMpMassNews.WxMpMassNewsArticle();
|
||||
WxMpNewsArticle article1 = new WxMpNewsArticle();
|
||||
article1.setTitle("标题1");
|
||||
article1.setContent("内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1");
|
||||
article1.setContent("内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1内容1");
|
||||
article1.setThumbMediaId(uploadMediaRes.getMediaId());
|
||||
news.addArticle(article1);
|
||||
|
||||
WxMpMassNews.WxMpMassNewsArticle article2 = new WxMpMassNews.WxMpMassNewsArticle();
|
||||
WxMpNewsArticle article2 = new WxMpNewsArticle();
|
||||
article2.setTitle("标题2");
|
||||
article2.setContent("内容2内容2内容2内容2内容2内容2内容2内容2内容2内容2内容2内容2内容2内容2内容2内容2内容2内容2内容2内容2内容2");
|
||||
article2.setContent("内容2内容2内容2内容2内容2内容2内容2内容2内2内容2内容2内容2内容2内容2内容2内容2内容2内容2");
|
||||
article2.setThumbMediaId(uploadMediaRes.getMediaId());
|
||||
article2.setShowCoverPic(true);
|
||||
article2.setAuthor("作者2");
|
||||
@@ -183,7 +179,7 @@ public class WxMpMassMessageServiceImplTest {
|
||||
|
||||
@Test
|
||||
public void testMassDelete() throws Exception {
|
||||
this.wxService.getMassMessageService().delete(1L,2);
|
||||
this.wxService.getMassMessageService().delete(1L, 2);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -103,7 +103,7 @@ public class WxMpMaterialServiceImplTest {
|
||||
public void testAddNews() throws WxErrorException {
|
||||
// 单图文消息
|
||||
WxMpMaterialNews wxMpMaterialNewsSingle = new WxMpMaterialNews();
|
||||
WxMpMaterialNews.WxMpMaterialNewsArticle article = new WxMpMaterialNews.WxMpMaterialNewsArticle();
|
||||
WxMpNewsArticle article = new WxMpNewsArticle();
|
||||
article.setAuthor("author");
|
||||
article.setThumbMediaId(this.thumbMediaId);
|
||||
article.setTitle("single title");
|
||||
@@ -115,7 +115,7 @@ public class WxMpMaterialServiceImplTest {
|
||||
|
||||
// 多图文消息
|
||||
WxMpMaterialNews wxMpMaterialNewsMultiple = new WxMpMaterialNews();
|
||||
WxMpMaterialNews.WxMpMaterialNewsArticle article1 = new WxMpMaterialNews.WxMpMaterialNewsArticle();
|
||||
WxMpNewsArticle article1 = new WxMpNewsArticle();
|
||||
article1.setAuthor("author1");
|
||||
article1.setThumbMediaId(this.thumbMediaId);
|
||||
article1.setTitle("multi title1");
|
||||
@@ -124,7 +124,7 @@ public class WxMpMaterialServiceImplTest {
|
||||
article1.setShowCoverPic(true);
|
||||
article1.setDigest("");
|
||||
|
||||
WxMpMaterialNews.WxMpMaterialNewsArticle article2 = new WxMpMaterialNews.WxMpMaterialNewsArticle();
|
||||
WxMpNewsArticle article2 = new WxMpNewsArticle();
|
||||
article2.setAuthor("author2");
|
||||
article2.setThumbMediaId(this.thumbMediaId);
|
||||
article2.setTitle("multi title2");
|
||||
@@ -196,7 +196,7 @@ public class WxMpMaterialServiceImplTest {
|
||||
.getMaterialService().materialNewsInfo(this.singleNewsMediaId);
|
||||
assertNotNull(wxMpMaterialNewsSingle);
|
||||
WxMpMaterialArticleUpdate wxMpMaterialArticleUpdateSingle = new WxMpMaterialArticleUpdate();
|
||||
WxMpMaterialNews.WxMpMaterialNewsArticle articleSingle = wxMpMaterialNewsSingle.getArticles().get(0);
|
||||
WxMpNewsArticle articleSingle = wxMpMaterialNewsSingle.getArticles().get(0);
|
||||
articleSingle.setContent("content single update");
|
||||
wxMpMaterialArticleUpdateSingle.setMediaId(this.singleNewsMediaId);
|
||||
wxMpMaterialArticleUpdateSingle.setArticles(articleSingle);
|
||||
@@ -213,7 +213,7 @@ public class WxMpMaterialServiceImplTest {
|
||||
.getMaterialService().materialNewsInfo(this.multiNewsMediaId);
|
||||
assertNotNull(wxMpMaterialNewsMultiple);
|
||||
WxMpMaterialArticleUpdate wxMpMaterialArticleUpdateMulti = new WxMpMaterialArticleUpdate();
|
||||
WxMpMaterialNews.WxMpMaterialNewsArticle articleMulti = wxMpMaterialNewsMultiple.getArticles().get(1);
|
||||
WxMpNewsArticle articleMulti = wxMpMaterialNewsMultiple.getArticles().get(1);
|
||||
articleMulti.setContent("content 2 update");
|
||||
wxMpMaterialArticleUpdateMulti.setMediaId(this.multiNewsMediaId);
|
||||
wxMpMaterialArticleUpdateMulti.setArticles(articleMulti);
|
||||
|
||||
Reference in New Issue
Block a user