美文网首页
对微信公众号接口的单元测试(Django)

对微信公众号接口的单元测试(Django)

作者: null_fca6 | 来源:发表于2018-10-20 14:48 被阅读0次

先简要概述微信公众号如何进行第三方配置(Django)

配置

menu = {
        'button': [
            {
                "name": "服务",
                "sub_button": [
                    {
                        "type": "click",
                        "name": "抢啥",
                        "key": event_keys['book_what'],
                    },
                    {
                        "type": "click",
                        "name": "查票",
                        "key": event_keys['get_ticket'],
                    },
                    {
                        "type": "click",
                        "name": "绑定",
                        "key": event_keys['account_bind'],
                    },
                    {
                        "type": "click",
                        "name": "帮助",
                        "key": event_keys['help'],
                    }
                ]
            },
            {
                "name": "抢票",
                "sub_button": []
            }
        ]
    }
  • 用户事件响应:通过对微信发过来的POST事件进行解析、认证后,直接发送给对应的handler列表进行检查,让他们对这些数据进行对应的相应。

单元测试

如果已经进行好相关的配置,又已经实现相关的Handler处理,那就该进行单元测试了。

此时的单元测试最大的困难就是模拟按键以及输入信息,那如何做到呢?

修改配置

在单元测试中,首先设置settings.IGNORE_WECHAT_SIGNATURE = True,防止微信的验证阻拦等

xml格式

实际上微信公众号规定了按键操作以及输入操作的信息格式,均为xml,在官方文档里有说明。此处仅仅介绍自定义菜单的操作以及发送文本消息的xml格式:

文本消息xml模板:xxxx是你的微信公众号的id,下面的{}内的为变量,可以在微信公众开发平台上查找:
fromUser是用户的id,curTime是当前时间,textMsg是文本消息的内容
<xml>  
<ToUserName>< ![CDATA[xxxx] ]></ToUserName>  
<FromUserName>< ![CDATA[{fromUser}] ]></FromUserName>  
<CreateTime>{curTime}</CreateTime>  
<MsgType>< ![CDATA[text] ]></MsgType>  
<Content>< ![CDATA[{textMsg}] ]></Content>  
<MsgId>{msgId}</MsgId>  
</xml>

自定义菜单事件xml模板:xxxx是你的微信公众号的id,下面的{}内的为变量,可以在微信公众开发平台上查找:
fromUser是用户的id,curTime是当前时间,EVENTKEY是菜单中设置的键值,例如上述的event_keys['help']
<xml>
<ToUserName><![CDATA[xxxx]]></ToUserName>
<FromUserName><![CDATA[{fromUser}]]></FromUserName>
<CreateTime>{curTime}</CreateTime>
<MsgType><![CDATA[event]]></MsgType>
<Event><![CDATA[CLICK]]></Event>
<EventKey><![CDATA[{EVENTKEY}]]></EventKey>
</xml>

既然有了模板,我们就可以模拟输入了,接下来需要解决的就是如何将输入post到后端:
注意需要post到/wechat/,同时制定xml格式,其中的self是TestCase子类下的

response = self.client.post(
                    path='/wechat/',
                    content_type='application/xml',
                    data=data
                )

以下是一个完整模拟访问帮助功能的测试类:

class TestHelpOrSubscribe(TestCase):

    def setUp(self):
        # 设置配置
        settings.IGNORE_WECHAT_SIGNATURE = True

        # user1 => not bind
        # user2 => bind
        User.objects.create(open_id='abc')
        User.objects.create(open_id='a', student_id='2016013265')

        # textMsgs => 用户一般可能输入(成功)
        self.textMsgs = ['帮助', 'Help', 'help', 'HELP']

        # clickEvents => 用户一般可能点击事件
        self.clickEvents = [CustomWeChatView.event_keys['help']]

    # 是否返回帮助
    def is_help(self, content):
        pattern = '“紫荆之声”使用指南'
        return content.find(pattern) != -1

    def test_text(self):
        users = User.objects.all()

        for user in users:
            for textMsg in self.textMsgs:
                fromUser = user.open_id
                curTime = str(getTimeStamp(datetime.datetime.now()))
                msgId = str(random.randint(0, 99999)) + curTime
                data = getTextXml(fromUser, curTime, textMsg, msgId)

                response = self.client.post(
                    path='/wechat/',
                    content_type='application/xml',
                    data=data
                )

                content = str(response.content.decode('utf-8'))
                self.assertEqual(self.is_help(content), True)

    def test_event_click(self):
        users = User.objects.all()

        for user in users:
            for clickEvent in self.clickEvents:
                fromUser = user.open_id
                curTime = str(getTimeStamp(datetime.datetime.now()))
                data = getClickXml(fromUser, curTime, clickEvent)

                response = self.client.post(
                    path='/wechat/',
                    content_type='application/xml',
                    data=data
                )

                content = str(response.content.decode('utf-8'))
                self.assertEqual(self.is_help(content), True)

如果有对测试不了解的,请看我之前的Django单元测试文档:https://www.jianshu.com/p/5533c866453a

这样就完成了对微信公众号接口的测试。

参考

相关文章

  • 技术博客汇总

    对微信公众号接口的单元测试 Github与Travis CI测试与部署 Django单元测试 NodeJs单元测试...

  • 对微信公众号接口的单元测试(Django)

    先简要概述微信公众号如何进行第三方配置(Django) 配置 微信官方文档:https://mp.weixin.q...

  • 微信公众号接口

    以下代码为微信公众号接口代码(未完结),用django框架开发

  • 微信公众号测试

    4. 微信公众号测试: 1)接口配置测试 由于微信公众号需要调用微信的接口,所以我们首先需要进行调用接口配置测试。...

  • 接口在线调试

    微信公众号开发需要熟悉各个接口的调用,我们推出了微信公众平台接口在线调试工具。 进入微信公众平台接口调试工具

  • 微信开发(基于PHP)Lesson 2

    微信官方接口分析 1.对接微信公众平台①获取API接口路径: 登录微信公众号(服务号即可)->开发者工具->开发者...

  • 【微信】支付

    公众号支付 调用微信js支付接口的页面,必须接口域名授权。在公众平台中设置,最多可以授权3个。 使用微信公众号支付...

  • 23个Python爬虫开源项目代码Python爬虫开源项目代码

    WechatSogou [1]– 微信公众号爬虫。 基于搜狗微信搜索的微信公众号爬虫接口,可以扩展成基于搜狗搜索的...

  • 基于JavaEE——微信网页(二)微信开发

    微信开发测试公众号(沙盒号) 微信API帮助文档 微信接口在线调试 首先申请微信开发的测试公众号,登陆后会看到微信...

  • 微信公众平台测试接口号部署

    本文章主要介绍,如何将已有的django程序和微信公众平台测试接口号相关联。 主要任务 为将django程序和微信...

网友评论

      本文标题:对微信公众号接口的单元测试(Django)

      本文链接:https://www.haomeiwen.com/subject/loqmzftx.html