diff --git a/weixin-java-enterprise/src/main/java/me/chanjar/weixin/common/bean/result/WxError.java b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/common/bean/result/WxError.java index 00b93b148..8b5dde6fb 100644 --- a/weixin-java-enterprise/src/main/java/me/chanjar/weixin/common/bean/result/WxError.java +++ b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/common/bean/result/WxError.java @@ -10,10 +10,12 @@ import me.chanjar.weixin.enterprise.util.json.WxCpGsonBuilder; */ public class WxError { - protected int errorCode; + private int errorCode; - protected String errorMsg; + private String errorMsg; + private String json; + public int getErrorCode() { return errorCode; } @@ -31,12 +33,14 @@ public class WxError { } public static WxError fromJson(String json) { - return WxCpGsonBuilder.create().fromJson(json, WxError.class); + WxError error = WxCpGsonBuilder.create().fromJson(json, WxError.class); + error.json = json; + return error; } @Override public String toString() { - return "微信错误 errcode=" + errorCode + ", errmsg=" + errorMsg; + return "微信错误 errcode=" + errorCode + ", errmsg=" + errorMsg + "\njson:" + json; } } diff --git a/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/api/WxCpConsts.java b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/api/WxCpConsts.java index 0938e2de5..1d26ba8f3 100644 --- a/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/api/WxCpConsts.java +++ b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/api/WxCpConsts.java @@ -18,7 +18,7 @@ public class WxCpConsts { public static final String XML_MSG_EVENT = "event"; /////////////////////// - // 客服消息的消息类型 + // 消息的消息类型 /////////////////////// public static final String CUSTOM_MSG_TEXT = "text"; public static final String CUSTOM_MSG_IMAGE = "image"; diff --git a/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/api/WxCpService.java b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/api/WxCpService.java index 6300abd00..6d161fe0a 100644 --- a/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/api/WxCpService.java +++ b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/api/WxCpService.java @@ -15,16 +15,17 @@ import me.chanjar.weixin.enterprise.exception.WxErrorException; * 微信API的Service */ public interface WxCpService { - + /** *
    * 验证推送过来的消息的正确性
    * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=验证消息真实性
    * 
+ * * @param msgSignature * @param timestamp * @param nonce - * @param data 微信传输过来的数据,有可能是echoStr,有可能是xml消息 + * @param data 微信传输过来的数据,有可能是echoStr,有可能是xml消息 * @return */ public boolean checkSignature(String msgSignature, String timestamp, String nonce, String data); @@ -34,6 +35,7 @@ public interface WxCpService { * 用在二次验证的时候 * 企业在员工验证成功后,调用本方法告诉企业号平台该员工关注成功。 * + * * @param userId */ public void userAuthenticated(String userId) throws WxErrorException; @@ -42,90 +44,93 @@ public interface WxCpService { *
    * 获取access_token,本方法线程安全
    * 且在多线程同时刷新时只刷新一次,避免超出2000次/日的调用次数上限
-   * 
    * 另:本service的所有方法都会在access_token过期是调用此方法
-   * 
    * 程序员在非必要情况下尽量不要主动调用此方法
-
    * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=获取access_token
    * 
+ * * @throws me.chanjar.weixin.enterprise.exception.WxErrorException */ public void accessTokenRefresh() throws WxErrorException; - + /** *
    * 上传多媒体文件
-   * 
    * 上传的多媒体文件有格式和大小限制,如下:
    *   图片(image): 1M,支持JPG格式
    *   语音(voice):2M,播放长度不超过60s,支持AMR\MP3格式
    *   视频(video):10MB,支持MP4格式
    *   缩略图(thumb):64KB,支持JPG格式
-   *    
    * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=上传下载多媒体文件
    * 
- * @param mediaType 媒体类型, 请看{@link WxCpConsts} - * @param fileType 文件类型,请看{@link WxCpConsts} - * @param inputStream 输入流 + * + * @param mediaType 媒体类型, 请看{@link WxCpConsts} + * @param fileType 文件类型,请看{@link WxCpConsts} + * @param inputStream 输入流 * @throws WxErrorException */ - public WxMediaUploadResult mediaUpload(String mediaType, String fileType, InputStream inputStream) throws WxErrorException, IOException; + public WxMediaUploadResult mediaUpload(String mediaType, String fileType, InputStream inputStream) + throws WxErrorException, IOException; /** - * @see #mediaUpload(String, String, InputStream) * @param mediaType * @param file * @throws WxErrorException + * @see #mediaUpload(String, String, InputStream) */ public WxMediaUploadResult mediaUpload(String mediaType, File file) throws WxErrorException; - + /** *
    * 下载多媒体文件
    * 根据微信文档,视频文件下载不了,会返回null
    * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=上传下载多媒体文件
    * 
- * @params media_id + * * @return 保存到本地的临时文件 * @throws WxErrorException + * @params media_id */ public File mediaDownload(String media_id) throws WxErrorException; - + /** *
-   * 发送客服消息
-   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=发送客服消息
+   * 发送消息
+   * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=发送消息
    * 
+ * * @param message * @throws WxErrorException */ public void messageSend(WxCpMessage message) throws WxErrorException; - + /** *
    * 自定义菜单创建接口
    * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=自定义菜单创建接口
    * 
+ * * @param menu * @throws WxErrorException */ public void menuCreate(WxCpMenu menu) throws WxErrorException; - + /** *
    * 自定义菜单删除接口
    * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=自定义菜单删除接口
    * 
+ * * @throws WxErrorException */ public void menuDelete() throws WxErrorException; - + /** *
    * 自定义菜单查询接口
    * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=自定义菜单查询接口
    * 
+ * * @return * @throws WxErrorException */ @@ -137,30 +142,32 @@ public interface WxCpService { * 最多支持创建500个部门 * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=部门管理接口 * + * * @param depart 部门 * @return 部门id * @throws WxErrorException */ public Integer departCreate(WxCpDepart depart) throws WxErrorException; - + /** *
    * 部门管理接口 - 查询所有部门
    * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=部门管理接口
    * 
+ * * @return * @throws WxErrorException */ public List departGet() throws WxErrorException; - + /** *
    * 部门管理接口 - 修改部门名
    * 详情请见: http://mp.weixin.qq.com/wiki/index.php?title=部门管理接口
-   * 
    * 如果id为0(未部门),1(黑名单),2(星标组),或者不存在的id,微信会返回系统繁忙的错误
    * 
- * @param group 要更新的group,group的id,name必须设置 + * + * @param group 要更新的group,group的id,name必须设置 * @throws WxErrorException */ public void departUpdate(WxCpDepart group) throws WxErrorException; @@ -168,33 +175,114 @@ public interface WxCpService { /** *
    * 部门管理接口 - 删除部门
-   *
    * 
+ * * @param departId * @throws WxErrorException */ public void departDelete(Integer departId) throws WxErrorException; - public void userCreate(WxCpUser user) throws WxErrorException; - - public void userUpdate(WxCpUser user) throws WxErrorException; - - public void userDelete(String userid) throws WxErrorException; - - public WxCpUser userGet(String userid) throws WxErrorException; - /** * http://qydev.weixin.qq.com/wiki/index.php?title=管理成员#.E8.8E.B7.E5.8F.96.E9.83.A8.E9.97.A8.E6.88.90.E5.91.98 - * @param departId 必填。部门id - * @param fetchChild 非必填。1/0:是否递归获取子部门下面的成员 - * @param status 非必填。0获取全部员工,1获取已关注成员列表,2获取禁用成员列表,4获取未关注成员列表。status可叠加 + * + * @param departId 必填。部门id + * @param fetchChild 非必填。1/0:是否递归获取子部门下面的成员 + * @param status 非必填。0获取全部员工,1获取已关注成员列表,2获取禁用成员列表,4获取未关注成员列表。status可叠加 * @return * @throws WxErrorException */ - public List userGetByDepart(Integer departId, Boolean fetchChild, Integer status) throws WxErrorException; + public List departGetUsers(Integer departId, Boolean fetchChild, Integer status) throws WxErrorException; + + /** + * 新建用户 + * + * @param user + * @throws WxErrorException + */ + public void userCreate(WxCpUser user) throws WxErrorException; + + /** + * 更新用户 + * + * @param user + * @throws WxErrorException + */ + public void userUpdate(WxCpUser user) throws WxErrorException; + + /** + * 删除用户 + * + * @param userid + * @throws WxErrorException + */ + public void userDelete(String userid) throws WxErrorException; + + /** + * 获取用户 + * + * @param userid + * @return + * @throws WxErrorException + */ + public WxCpUser userGet(String userid) throws WxErrorException; + + /** + * 创建标签 + * + * @param tagName + * @return + */ + public String tagCreate(String tagName) throws WxErrorException; + + /** + * 更新标签 + * + * @param tagId + * @param tagName + */ + public void tagUpdate(String tagId, String tagName) throws WxErrorException; + + /** + * 删除标签 + * + * @param tagId + */ + public void tagDelete(String tagId) throws WxErrorException; + + /** + * 获得标签列表 + * + * @return + */ + public List tagGet() throws WxErrorException; + + /** + * 获取标签成员 + * + * @param tagId + * @return + */ + public List tagGetUsers(String tagId) throws WxErrorException; + + /** + * 增加标签成员 + * + * @param tagId + * @param userIds + */ + public void tagAddUsers(String tagId, List userIds) throws WxErrorException; + + /** + * 移除标签成员 + * + * @param tagId + * @param userIds + */ + public void tagRemoveUsers(String tagId, List userIds) throws WxErrorException; /** * 注入 {@link WxCpConfigStorage} 的实现 + * * @param wxConfigProvider */ public void setWxCpConfigStorage(WxCpConfigStorage wxConfigProvider); diff --git a/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/api/WxCpServiceImpl.java b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/api/WxCpServiceImpl.java index 4d74a71e8..17fe39e7b 100644 --- a/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/api/WxCpServiceImpl.java +++ b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/api/WxCpServiceImpl.java @@ -8,6 +8,9 @@ import java.util.List; import java.util.UUID; import java.util.concurrent.atomic.AtomicBoolean; +import com.google.gson.JsonArray; +import com.google.gson.JsonObject; +import com.google.gson.JsonPrimitive; import me.chanjar.weixin.common.bean.result.WxAccessToken; import me.chanjar.weixin.common.util.GsonHelper; import me.chanjar.weixin.enterprise.bean.*; @@ -208,7 +211,7 @@ public class WxCpServiceImpl implements WxCpService { } @Override - public List userGetByDepart(Integer departId, Boolean fetchChild, Integer status) throws WxErrorException { + public List departGetUsers(Integer departId, Boolean fetchChild, Integer status) throws WxErrorException { String url = "https://qyapi.weixin.qq.com/cgi-bin/user/simplelist?department_id=" + departId; String params = ""; if (fetchChild != null) { @@ -229,6 +232,81 @@ public class WxCpServiceImpl implements WxCpService { ); } + @Override + public String tagCreate(String tagName) throws WxErrorException { + String url = "https://qyapi.weixin.qq.com/cgi-bin/tag/create"; + JsonObject o = new JsonObject(); + o.addProperty("tagname", tagName); + String responseContent = execute(new SimplePostRequestExecutor(), url, o.toString()); + JsonElement tmpJsonElement = Streams.parse(new JsonReader(new StringReader(responseContent))); + return tmpJsonElement.getAsJsonObject().get("tagid").getAsString(); + } + + @Override + public void tagUpdate(String tagId, String tagName) throws WxErrorException { + String url = "https://qyapi.weixin.qq.com/cgi-bin/tag/update"; + JsonObject o = new JsonObject(); + o.addProperty("tagid", tagId); + o.addProperty("tagname", tagName); + execute(new SimplePostRequestExecutor(), url, o.toString()); + } + + @Override + public void tagDelete(String tagId) throws WxErrorException { + String url = "https://qyapi.weixin.qq.com/cgi-bin/tag/delete?tagid=" + tagId; + execute(new SimpleGetRequestExecutor(), url, null); + } + + @Override + public List tagGet() throws WxErrorException { + String url = "https://qyapi.weixin.qq.com/cgi-bin/tag/list"; + String responseContent = execute(new SimpleGetRequestExecutor(), url, null); + JsonElement tmpJsonElement = Streams.parse(new JsonReader(new StringReader(responseContent))); + return WxCpGsonBuilder.INSTANCE.create() + .fromJson( + tmpJsonElement.getAsJsonObject().get("taglist"), + new TypeToken>() { }.getType() + ); + } + + @Override + public List tagGetUsers(String tagId) throws WxErrorException { + String url = "https://qyapi.weixin.qq.com/cgi-bin/tag/get?tagid=" + tagId; + String responseContent = execute(new SimpleGetRequestExecutor(), url, null); + JsonElement tmpJsonElement = Streams.parse(new JsonReader(new StringReader(responseContent))); + return WxCpGsonBuilder.INSTANCE.create() + .fromJson( + tmpJsonElement.getAsJsonObject().get("userlist"), + new TypeToken>() { }.getType() + ); + } + + @Override + public void tagAddUsers(String tagId, List userIds) throws WxErrorException { + String url = "https://qyapi.weixin.qq.com/cgi-bin/tag/addtagusers"; + JsonObject jsonObject = new JsonObject(); + jsonObject.addProperty("tagid", tagId); + JsonArray jsonArray = new JsonArray(); + for (String userId : userIds) { + jsonArray.add(new JsonPrimitive(userId)); + } + jsonObject.add("userlist", jsonArray); + execute(new SimplePostRequestExecutor(), url, jsonObject.toString()); + } + + @Override + public void tagRemoveUsers(String tagId, List userIds) throws WxErrorException { + String url = "https://qyapi.weixin.qq.com/cgi-bin/tag/deltagusers"; + JsonObject jsonObject = new JsonObject(); + jsonObject.addProperty("tagid", tagId); + JsonArray jsonArray = new JsonArray(); + for (String userId : userIds) { + jsonArray.add(new JsonPrimitive(userId)); + } + jsonObject.add("userlist", jsonArray); + execute(new SimplePostRequestExecutor(), url, jsonObject.toString()); + } + /** * 向微信端发送请求,在这里执行的策略是当发生access_token过期时才去刷新,然后重新执行请求,而不是全局定时请求 * diff --git a/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/bean/WxCpMessage.java b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/bean/WxCpMessage.java index ec1cb0c20..219e6b512 100644 --- a/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/bean/WxCpMessage.java +++ b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/bean/WxCpMessage.java @@ -7,7 +7,7 @@ import me.chanjar.weixin.enterprise.bean.messagebuilder.*; import me.chanjar.weixin.enterprise.util.json.WxCpGsonBuilder; /** - * 客服消息 + * 消息 * @author Daniel Qian * */ diff --git a/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/bean/WxCpTag.java b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/bean/WxCpTag.java new file mode 100644 index 000000000..50646b54e --- /dev/null +++ b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/bean/WxCpTag.java @@ -0,0 +1,55 @@ +package me.chanjar.weixin.enterprise.bean; + +import com.google.gson.JsonElement; +import com.google.gson.JsonObject; +import com.google.gson.internal.Streams; +import com.google.gson.stream.JsonReader; +import me.chanjar.weixin.common.util.GsonHelper; +import me.chanjar.weixin.enterprise.util.json.WxCpGsonBuilder; + +import java.io.StringReader; + +/** + * Created by Daniel Qian + */ +public class WxCpTag { + + private String id; + + private String name; + + public WxCpTag() { + super(); + } + + public WxCpTag(String id, String name) { + super(); + this.id = id; + this.name = name; + } + + public String getName() { + return name; + } + + public void setName(String name) { + this.name = name; + } + + public String getId() { + return id; + } + + public void setId(String id) { + this.id = id; + } + + public static WxCpTag fromJson(String json) { + return WxCpGsonBuilder.create().fromJson(json, WxCpTag.class); + } + + public String toJson() { + return WxCpGsonBuilder.create().toJson(this); + } + +} diff --git a/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/bean/WxCpUser.java b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/bean/WxCpUser.java index aa44ea610..5dc87d2d5 100644 --- a/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/bean/WxCpUser.java +++ b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/bean/WxCpUser.java @@ -96,14 +96,6 @@ public class WxCpUser { this.weiXinId = weiXinId; } - public String toJson() { - return WxCpGsonBuilder.INSTANCE.create().toJson(this); - } - - public static WxCpUser fromJson(String json) { - return WxCpGsonBuilder.INSTANCE.create().fromJson(json, WxCpUser.class); - } - public void addExtAttr(String name, String value) { this.extAttrs.add(new Attr(name, value)); } @@ -112,6 +104,14 @@ public class WxCpUser { return extAttrs; } + public String toJson() { + return WxCpGsonBuilder.INSTANCE.create().toJson(this); + } + + public static WxCpUser fromJson(String json) { + return WxCpGsonBuilder.INSTANCE.create().fromJson(json, WxCpUser.class); + } + public static class Attr { private String name; diff --git a/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/util/json/WxCpGsonBuilder.java b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/util/json/WxCpGsonBuilder.java index 5ec386c3c..3110f119a 100644 --- a/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/util/json/WxCpGsonBuilder.java +++ b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/util/json/WxCpGsonBuilder.java @@ -1,6 +1,5 @@ package me.chanjar.weixin.enterprise.util.json; - import com.google.gson.Gson; import com.google.gson.GsonBuilder; import me.chanjar.weixin.common.bean.result.WxAccessToken; @@ -11,7 +10,7 @@ import me.chanjar.weixin.enterprise.bean.result.*; public class WxCpGsonBuilder { public static final GsonBuilder INSTANCE = new GsonBuilder(); - + static { INSTANCE.disableHtmlEscaping(); INSTANCE.registerTypeAdapter(WxCpMessage.class, new WxCpMessageGsonAdapter()); @@ -21,10 +20,11 @@ public class WxCpGsonBuilder { INSTANCE.registerTypeAdapter(WxAccessToken.class, new WxCpAccessTokenAdapter()); INSTANCE.registerTypeAdapter(WxError.class, new WxErrorAdapter()); INSTANCE.registerTypeAdapter(WxMediaUploadResult.class, new WxCpMediaUploadResultAdapter()); + INSTANCE.registerTypeAdapter(WxCpTag.class, new WxCpTagGsonAdapter()); } - + public static Gson create() { return INSTANCE.create(); } - + } diff --git a/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/util/json/WxCpTagGsonAdapter.java b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/util/json/WxCpTagGsonAdapter.java new file mode 100644 index 000000000..1d015dc70 --- /dev/null +++ b/weixin-java-enterprise/src/main/java/me/chanjar/weixin/enterprise/util/json/WxCpTagGsonAdapter.java @@ -0,0 +1,39 @@ +/* + * KINGSTAR MEDIA SOLUTIONS Co.,LTD. Copyright c 2005-2013. All rights reserved. + * + * This source code is the property of KINGSTAR MEDIA SOLUTIONS LTD. It is intended + * only for the use of KINGSTAR MEDIA application development. Reengineering, reproduction + * arose from modification of the original source, or other redistribution of this source + * is not permitted without written permission of the KINGSTAR MEDIA SOLUTIONS LTD. + */ +package me.chanjar.weixin.enterprise.util.json; + +import com.google.gson.*; +import com.google.gson.internal.Streams; +import com.google.gson.stream.JsonReader; +import me.chanjar.weixin.common.util.GsonHelper; +import me.chanjar.weixin.enterprise.bean.WxCpDepart; +import me.chanjar.weixin.enterprise.bean.WxCpTag; + +import java.io.StringReader; +import java.lang.reflect.Type; + +/** + * @author Daniel Qian + */ +public class WxCpTagGsonAdapter implements JsonSerializer, JsonDeserializer { + + public JsonElement serialize(WxCpTag group, Type typeOfSrc, JsonSerializationContext context) { + JsonObject o = new JsonObject(); + o.addProperty("tagid", group.getId()); + o.addProperty("tagname", group.getName()); + return o; + } + + public WxCpTag deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) + throws JsonParseException { + JsonObject jsonObject = json.getAsJsonObject(); + return new WxCpTag(GsonHelper.getString(jsonObject, "tagid"), GsonHelper.getString(jsonObject, "name")); + } + +} diff --git a/weixin-java-enterprise/src/test/java/me/chanjar/weixin/enterprise/api/WxCpMessageAPITest.java b/weixin-java-enterprise/src/test/java/me/chanjar/weixin/enterprise/api/WxCpMessageAPITest.java index 7c26c922f..7ee283380 100644 --- a/weixin-java-enterprise/src/test/java/me/chanjar/weixin/enterprise/api/WxCpMessageAPITest.java +++ b/weixin-java-enterprise/src/test/java/me/chanjar/weixin/enterprise/api/WxCpMessageAPITest.java @@ -9,7 +9,7 @@ import me.chanjar.weixin.enterprise.exception.WxErrorException; import com.google.inject.Inject; /*** - * 测试发送客服消息 + * 测试发送消息 * @author Daniel Qian * */ diff --git a/weixin-java-enterprise/src/test/java/me/chanjar/weixin/enterprise/api/WxCpTagAPITest.java b/weixin-java-enterprise/src/test/java/me/chanjar/weixin/enterprise/api/WxCpTagAPITest.java new file mode 100644 index 000000000..44b8e3914 --- /dev/null +++ b/weixin-java-enterprise/src/test/java/me/chanjar/weixin/enterprise/api/WxCpTagAPITest.java @@ -0,0 +1,66 @@ +package me.chanjar.weixin.enterprise.api; + +import com.google.inject.Inject; +import me.chanjar.weixin.enterprise.bean.WxCpTag; +import me.chanjar.weixin.enterprise.bean.WxCpUser; +import org.testng.Assert; +import org.testng.annotations.Guice; +import org.testng.annotations.Test; + +import java.util.ArrayList; +import java.util.List; + +@Test(groups = "departAPI", dependsOnGroups = "baseAPI") +@Guice(modules = ApiTestModule.class) +public class WxCpTagAPITest { + + @Inject + protected WxCpServiceImpl wxService; + + @Inject + protected WxCpConfigStorage configStorage; + + protected String tagId; + + public void testTagCreate() throws Exception { + tagId = wxService.tagCreate("测试标签4"); + System.out.println(tagId); + } + + @Test(dependsOnMethods = "testTagCreate") + public void testTagUpdate() throws Exception { + wxService.tagUpdate(tagId, "测试标签-改名"); + } + + @Test(dependsOnMethods = "testTagUpdate") + public void testTagGet() throws Exception { + List tags = wxService.tagGet(); + Assert.assertNotEquals(tags.size(), 0); + } + + @Test(dependsOnMethods = "testTagGet") + public void testTagAddUsers() throws Exception { + List userIds = new ArrayList(); + userIds.add(((ApiTestModule.WxXmlCpConfigStorage)configStorage).getUserId()); + wxService.tagAddUsers(tagId, userIds); + } + + @Test(dependsOnMethods = "testTagAddUsers") + public void testTagGetUsers() throws Exception { + List users = wxService.tagGetUsers(tagId); + Assert.assertNotEquals(users.size(), 0); + } + + @Test(dependsOnMethods = "testTagGetUsers") + public void testTagRemoveUsers() throws Exception { + List userIds = new ArrayList(); + userIds.add(((ApiTestModule.WxXmlCpConfigStorage)configStorage).getUserId()); + wxService.tagRemoveUsers(tagId, userIds); + } + + @Test(dependsOnMethods = "testTagRemoveUsers") + public void testTagDelete() throws Exception { + wxService.tagDelete(tagId); + } + +} diff --git a/weixin-java-enterprise/src/test/java/me/chanjar/weixin/enterprise/api/WxCpUserAPITest.java b/weixin-java-enterprise/src/test/java/me/chanjar/weixin/enterprise/api/WxCpUserAPITest.java index 9e4b00207..a9f3bb101 100644 --- a/weixin-java-enterprise/src/test/java/me/chanjar/weixin/enterprise/api/WxCpUserAPITest.java +++ b/weixin-java-enterprise/src/test/java/me/chanjar/weixin/enterprise/api/WxCpUserAPITest.java @@ -54,12 +54,12 @@ public class WxCpUserAPITest { } @Test(dependsOnMethods = "testUserGet") - public void testUserGetByDepart() throws WxErrorException { - List users = wxService.userGetByDepart(1, true, 0); + public void testDepartGetUsers() throws WxErrorException { + List users = wxService.departGetUsers(1, true, 0); Assert.assertNotEquals(users.size(), 0); } - @Test(dependsOnMethods = "testUserGetByDepart") + @Test(dependsOnMethods = "testDepartGetUsers") public void testUserDelete() throws WxErrorException { wxService.userDelete("xiaohe.yang"); } diff --git a/weixin-java-enterprise/src/test/resources/testng.xml b/weixin-java-enterprise/src/test/resources/testng.xml index 85f26420a..3c65a32c7 100644 --- a/weixin-java-enterprise/src/test/resources/testng.xml +++ b/weixin-java-enterprise/src/test/resources/testng.xml @@ -9,7 +9,9 @@ - + + +