转转QA 小程序测试体系——基础篇

笑哼 for 转转QA · 2018年09月28日 · 最后由 回复于 2023年03月23日 · 19362 次阅读
本帖已被设为精华帖!

作者 | 谢水宁


2017年1月9号微信小程序正式上线,小程序无须安装就能使用,依托微信强大的生态环境,能做到很多 H5 所不能做的事情。目前公司已有小程序主要有 11 个。
但对于小程序如何做测试,依然没有一个相应完整的操作文档。这里将从四个方面简单介绍如何对小程序进行测试。

小程序相关介绍

在测试前,先简单理解下小程序特性。

  1. 小程序发布审核
    1. 发布前需申请外网域名,并在微信 web 开发者工具里找到项目,设置好服务器的域名。
    2. 开发完上传代码后,在微信公众平台—》登录小程序管理后台—》点击开发管理—》点击提交版本审核即可。
    3. 审核通过后会有相应提示,接着把审核通过的小程序发布线上;若未审核通过可做相应修改继续提审。
    4. 第一次提交小程序审核时,需先上线后端,一般第一次审核时间比较久(3d 左右)。
  2. 小程序的限制
    1. 页面层级跳转不能超过 10 层。
    2. 用户本地缓存不能超过 10MB。
    3. 小程序代码包不能超过 3M,所以部分图片资源需上传 CDN。
    4. 小程序发布需提交微信审核通过才可发版。
    5. 提交审核前,外网域名需申请(除微信域名之外)。
  3. 层级问题
    1. 小程序原生页面存在 10 层限制问题,即超过 10 层时便无法打开新页面,而业务流程或者访问形成闭环时,很容易陷入 10 层问题。
    2. 为避免层级限制导致的无法打开页面和层级限制带来的交互路径限制,内部提出了【层级策略】以解决层级限制问题。
    3. 【层级策略】将页面路径存储到 storage,返回时则刷新拉取存储的页面路径,目前只保存页面路径,不保存表单等数据。具体解决方案见文档 “层级策略.txt”。
  4. 服务通知
    1. 基于微信的通知渠道,为开发者提供了可以高效触达用户的模板消息能力,以便实现服务的闭环并提供更佳的体验。
    2. 模板推送位置:服务通知。模板下发条件:用户本人在微信体系内与页面有交互行为后触发。模板跳转能力:点击查看详情仅能跳转下发模板的该帐号的各个页面。
    3. 小程序给用户推送服务通知,依赖用户的 formId。
    4. 更多服务通知详情戳一戳https://mp.weixin.qq.com/debug/wxadoc/dev/api/notice.html
  5. 基础库版本
    1. 小程序的能力需要微信客户端来支撑,每一个基础库都只能在对应的客户端版本上运行,高版本的基础库对应的 api 不支持低版本,所以在使用这些新能力的时候需要做兼容。
    2. 由于微信版本和基础库版本不是一一对应关系,且小程序 api 是基于各个基础库版本进行发布的,所以在测试过程中需要提前获悉当前基础库版本号。
    3. 目前可在 zeye 后台查看基于转转用户使用的基础库、微信版本、手机型号覆盖率等数据。
    4. 目前我们主要通过日志的方式自动获取到版本号,可通过两种途径拿到:1.体验版进入首页时通过 console 查到;2.通过我的功能页面拿到。
    5. 更多可查看此https://mp.weixin.qq.com/debug/wxadoc/dev/framework/client-lib.html
  6. 开发版、体验版、线上版
    1. 小程序并不像服务端那样区别线上和线下版本,而是有开发版、体验版、线上版。
    2. 如果只是开发后端逻辑功能,可在三个版本中任意一个进行测试;如果是开发前端功能则需在相应的开发版/测试版进行测试。
    3. 三者具体区别如下:
      • 权限层:前两者需申请开发者和体验者权限才可使用,后者则面向所有用户。
      • 性能层:开发版和体验版自身带有 vConsole 性能面板(回归需关闭此功能),而线上版则木有。
      • 代码层:开发人员可同时在多个开发版上开发互不影响;体验版当前只能有一份代码处于审核中,审核通过后可发布上线,也可直接重新提交审核,覆盖原审核版本;线上版本则为所有用户使用的代码版本,该版本代码在新版本代码发布后被覆盖更新。
    4. 包大小:开发版本不限制包大小;体验者&正式版则限制包大小。
    5. 二维码:体验版保持不变,开发版 30min 后失效需重新生成。
  7. 缓存机制
    1. 为了保证小程序的快速访问和用户体验,微信会缓存小程序,包括小程序文件、授权数据、登录数据等。
    2. 使用小程序常碰到缓存问题,例如切换环境(线上线下互切)、cookie、发版、登陆等,简单粗暴的方法就是将小程序删掉重新进入即可。更多缓存可查看https://mp.weixin.qq.com/debug/wxadoc/dev/api/data.html
    3. 小程序启动机制主要为 “冷启动”&“热启动”,如下。
      • 同一手机,不同小程序应用,至少在逻辑存储上肯定不是共享缓存,满足应用级别隔离。
      • 同一手机,同一个小程序,不同微信用户扫码使用,经测试,也不共享缓存,目前测试条件下,是用户级别隔离。
      • 同一手机,同一个小程序,同一微信用户两次扫码使用,经测试,是共享缓存。
      • 同一手机,同一个小程序,不同微信用户切换使用(分别扫码两次),经测试,同一个用户共享缓存,不同用户间不共享缓存。
    4. 海报页
      1. 可生成定制的海报页,用于分享朋友圈。
      2. 任何版本生成的海报页,扫码都跳转到正式版落地页,可借助【小程序码测试工具】跳转相应页面。
      3. 二维码数据和图片为动态生成过程,不像那种固定图片的可以预加载。
  8. 微信 openId 和 UnionID 区别
    1. 同一公司下多个公众号之间需要用户帐号互通,微信开放平台提供了 UnionID 机制。
    2. 通过获取用户基本信息接口,开发者可通过 OpenID 来获取用户基本信息,而如果开发者拥有多个公众号,可通过 UnionID 在多公众号之间进行用户帐号互通。
    3. 在不同的公众账号下 OpenID 是不一样的,而他们的 UnionID 却是一样的。
    4. UnionId 和 uid 是对应关系;OpenId 和 sourceId 是对应关系。

小程序测试工作

  1. 前期准备
    • 微信版本号需在 6.3.27 及以上,低于提示升级。
    • qa 需申请对应小程序体验者权限&开发者权限。
    • 小程序开发版、体验版、正式版。
    • 小程序 AppID,项目地址&名字。
    • 明确小程序本次测试入口&版本。
    • 微信公众号平台发布的【小程序开发助手】, 可方便快捷的预览和体验线上版本,体验版本以及开发版本。
  2. 测试点
    • 授权:目前已实现静默授权,即用户首次访问小程序,主动获取微信授权,通过获取 openid,生成转转 uid,并存储昵称、头像等信息。后续用户若杀掉小程序重新进入,无需重新授权。
    • 功能:与端内正常测试功能无异;
    • 缓存:功能需求后,此时就需要关注缓存情况:
    • 微信给每个小程序提供了 10MB 的本地缓存。
    • 页面切换时,可能会将上一个页面的数据带到下一个页面展示,例如【主程序 - 红包需求】点击 “未使用” 先显示正确文案—》点击 “已使用” 或 “已过期”—》点击 “未使用”,文案却展示 “已使用” 和 “未使用” 的文案。此时可以给开发人员提 bug,通过代码解决页面缓存问题;
    • 对于账号切换、版本发布等带来的缓存,目前解决方法是简单粗暴的将小程序删掉,重新进入生效。
    • 还可从代码层面解决缓存问题:1.清除当前存储到 storage 里的内容,如 cookie 信息,主要调用 wx.clearStorageSync();2.从基础库 1.9.90 开始,小程序支持自动更新上线代码,接口为 wx.getUpdateManager()。
    • 性能
    • 分享功能测试
    • 分享到好友列表&生成海报页分享到朋友圈;
    • 用线上/测试/开发版分享给好友,落地页就是相应的线上/测试/开发版;
    • 朋友圈识别跳转都是线上版;所以在测试过程中若涉及到扫码跳转,就需借助【小程序码测试工具】。
    • 服务通知:
    • 以模板 ID 的形式推送服务通知;
    • 微信公众号:需关注公众号&无须收集 formId;小程序服务通知:收集 formId;
    • formId 有效期 7d,如果用户没有可用的 formId,则无法给用户推送相应消息;
    • 通过点击操作单个/批量收集 formId,主要存储在 wtable,触发行为如支付、提交表单等;详情戳一戳它https://mp.weixin.qq.com/debug/wxadoc/dev/api/notice.html
    • 批量收集 formId:POST 请求,如 zzwxpush/addFormIds
    • 单个收集 formId:GET 请求,如 zzwxpush/addFormId?formId
    • 每个小程序收集的 formId,只能用于对应的小程序,也只能用于对应的 uid。例如闲置社 108 批量收集 formId,却存储在小程序 103,结果导致闲置社批量 formId 失败,而且小程序存储很多无效可用的 formId,主要原因是由于前端传入参数 source=103 导致。
      • 常出现问题:formId 无效(命中小程序自身策略)、无可用 formId(需收集)。
    • 层级:
    • M 页、toast、弹窗等不受限于层级问题;
    • 小程序原生页面超过 10 层后不能再打开新页面,正常业务流程或闭环容易造成 10 层问题,例如个人中心--》商品列表页--》个人中心……
    • 解决方法【层级策略】:将页面链接存储到 storage,返回时则刷新拉取存储的页面链接。目前只保存页面路径,不保存页面数据。
    • 兼容:
    • 微信版本:小程序的接口完全依赖于微信,因此部分基础库较高的接口可能在低版本的微信上不生效,需做兼容,如:页面内分享是基于 1.2.0 的基础库开发,因此要求对应微信版本在 6.5.8 及以上;
    • 不同机型:如某页面在华为机型展示没问题,但到小米机型却展示有问题;
    • 手机系统:Android 和 ios 两个版本兼容性可能不同;如个人主页中【安卓和 ios】评价样式有问题。
    • 埋点:
    • 埋点测试大致和端内测试流程一样,关注 actiontype&pagetype 等参数;
    • 小程序统计常需区分用户来源渠道,因此还需关注【backup】中的 channel,pagechannel,type 等参数。
    • appid:主要存储小程序 source 参数值。
    • scene:场景值,详情https://mp.weixin.qq.com/debug/wxadoc/dev/framework/app-service/scene.html
    • channel:只对小程序入口页生效,会伴随整个生命周期,直到退出小程序。如果没有明确的参数值,则默认为 none。
    • pagechannel:针对页面 url 参数,只带到落地页,不会带到后续页面。如果没有明确的参数值,则默认为 none。
    • type:目前用在详情页,主要用于区分此商品是个人 mine/圈子 group/他人 normal。
    • 根据 pm 需求还可以增加相应渠道参数。
    • 内嵌 M 页:
    • 1.6.4 版本开始陆续支持小程序内嵌 M 页。
    • M 页不受限于小程序的层级页面,如【游戏 M 页】点击首页—》游戏频道为 1 层页面,而不是 2 层页面。
    • 测试 M 页需做相应的适配,以在小程序能够正常使用,如登陆等。若 M 页嵌入 native 页面,则还需要额外做 native 页面交互的适配。如【游戏—我的拼团】没做适配,则提示此错误。
    • M 测重点关注页面跳转功能,展示等问题。
  3. 测试坑点 小程序测试过程中经常碰到的坑,重点需关注:
    • 层级页面跳转
    • 兼容性
    • 缓存

常见问题定位&解决

测试微信侧消息时,由于线上访问和线下访问的账号是不通的,所以需要把线上数据写到线下,比如线上 uid=1 线下 uid=2,需要把线上 uid=1 的信息,同步到线下 uid=2 的记录中,才能访问成功。

  • 线下测公众号消息报 “未关注公众号”

    • 原因:由于微信公众号对于我们而言只有线上,并无所谓线下一套的说法,从而导致在线下测公众号消息的时候会打出 “未关注公众号” 日志,从而测不通。
    • 解决:将线上相应用户的 unionid 和 openid 复制黏贴到线下用户中,步骤如下。
    • 线上 uid 查询线上 user 库 user_auth 表获取用户 source=26 的 unionid 和 openid;
    • 在线下 uid 的 user 库 user_auth 表添加上述 source=26 的记录。
    • 同时线下 push 库 wechat_user_map 表添加相应的 unionid 和 openid,此时测试公众号就能通了。
    • 若出现 openid hint/unionid hint 等错误,则说明同步的 openid/unionid 有问题,需要重新线上确认同步到线下。
  • 报错 “用户未授权”

    • 原因:在线下测试时,由于操作不规范,经常会出现 “用户未授权” 的情况。如下错误展示,查询 dbwww58com_user 库 user_auth 表,发现不存在对应小程序端的 uid,即日志 source=103,但库 source=108 ,两个 source 对不上。
    • 解决:将 user_auth 同步线上 source=103 即可。
  • formid 错误汇总

    • 测微信服务通知时,经常出现 formid 以下错误提示。
    • formid 过期(有效期 7d)&收集格式错误导致(格式为时间戳/字母 + 数字组成的 32 位)。
    • 当前用户没有 formid 导致。
    • formid 已使用导致,主要是同一时间可能多个用户收集 formid,从而形成的 formid 可能一样。
    • 相应 form 错误码说明如下:
    • 明确每个小程序收集的 formId,只能用于对应的小程序,也只能用于对应的 uid。
    • 目前发服务通知时,为防止用户下发失败,会重复调用 formId 接口 3 次,若 3 次下发都失败,则以公众号的形式下发服务通知(目前下发成功率达到 98%)。
  • 消息模板跳转链接错误

    • 出现这种错误,首先需要确认 url 是否解析成小程序可跳转的链接;若已解析,则是小程序这个页面还没上线导致微信检索不到此链接导致。
    • page 路径配置错误,重配即可。

工具篇

为了方便小程序测试,已开发了入口构造工具&小程序码测试工具。

  • 入口构造工具

    • 用于 m 页,以及小程序 url 页面入口跳转,若测渠道埋点,可额外添加参数值 channel;
    • 填入 url 参数格式:pages/webview/webview?url=https:xxxxx
  • 小程序码测试工具

    • 开发过程中,涉及到扫描小程序码会跳转到线上版小程序,导致测试过程无法检测扫码跳转是否正确。如【首页改版 V2-商品详情页小浮层】若直接识别小程序,则落地页为线上版小程序而不是相应的开发/测试版本,导致没调用到 “商品详情页浮层” 接口 productDetailLayer
    • 此工具主要是方便通过扫码跳转相应的版本,检查未上线时参数是否正确。 -【查看二维码】扫码查看相应的链接参数;
    • 【打开二维码】扫码跳转相应的版本页面;
    • 【测渠道埋点】扫码分享获取到相应的渠道参数;
共收到 26 条回复 时间 点赞

工具呢?难道是广告贴?😅

所有贴的图根本没法看,太模糊了

尊敬乐于分享不断前行的前辈,我目前也负责小程序测试,鹅厂 29 号来源了一个小程序自动化自动化测试框架 FAT,不知前辈是否已经开始研究?

笑哼 #28 · 2018年09月30日 Author
回复

嗯,已经 clone 和 watch 了

笑哼 #27 · 2018年09月30日 Author
大海 回复

这个我下次会注意下,这次给我的图就是这样的

笑哼 #26 · 2018年09月30日 Author
CXL.im 回复

哪个工具?

回复

请问在哪里可以找到 FAT 呢?谢谢!

属于一篇简单小程序思路测试 2 星文章

luckyhey 回复

Github 组织名搜索 Tencent

回复

FAT 已经调通了

笑哼 回复

我卡在这里了,机器是小米的 MI 4LTE-CT 安卓 4.4
端口里面可以获取 json 对象 但是 chrome inspecter 里面显示小程序 page 404

D:\Anaconda3\envs\Fauto\python.exe C:/Users/Administrator/Desktop/Projects/Fatuto/sample/XcqDemo.py
ws://localhost:9223/devtools/page/071483e5-5e48-4a4e-a5fd-0789d565b65a
ws://localhost:9223/devtools/page/071483e5-5e48-4a4e-a5fd-0789d565b65a
Traceback (most recent call last):
  File "C:/Users/Administrator/Desktop/Projects/Fatuto/sample/XcqDemo.py", line 16, in <module>
    wxDriver.initDriver()
  File "C:\Users\Administrator\Desktop\Projects\Fatuto\fastAutoTest\core\wx\wxEngine.py", line 45, in initDriver
    url = self._urlFetcher.fetchWebSocketDebugUrl()
  File "C:\Users\Administrator\Desktop\Projects\Fatuto\fastAutoTest\core\wx\wxWebSocketDebugUrlFetcher.py", line 62, in fetchWebSocketDebugUrl
    self._fetchInner()
  File "C:\Users\Administrator\Desktop\Projects\Fatuto\fastAutoTest\core\wx\wxWebSocketDebugUrlFetcher.py", line 81, in _fetchInner
    self._webSocketDebugUrl = self._fetchWebSocketDebugUrl(self._localForwardPort)
  File "C:\Users\Administrator\Desktop\Projects\Fatuto\fastAutoTest\core\wx\wxWebSocketDebugUrlFetcher.py", line 139, in _fetchWebSocketDebugUrl
    raise RuntimeError(errorMsg)
RuntimeError: 获取小程序页面特征失败
回复

你打印下图片中的那两个值,看是不是和我的一样,

笑哼 回复

今晚 TMQ 腾讯的工程师分享 里面提及了 小米的机器会有兼容性问题。楼主你用的是什么型号的手机?

小米,兼容性的话,自己可以去框架调整

笑哼 回复

请教一下,whl 文件手动下载完了 然后怎么安装,pip 中安装么?

笑哼 #15 · 2018年10月25日 Author
王小虎 回复

pip 安装或者在 pycharm 中安装都可以

笑哼 回复

C:\Program Files (x86)\Tesseract-OCR>pip install C:\fastAutoTest-2.2.3-py2-none-any.whl
用上门的命令安装给出下面的提示了
fastAutoTest-2.2.3-py2-none-any.whl is not a supported wheel on this platform.
是因为我安装的 python 是 3.7 版本么?

笑哼 #13 · 2018年10月26日 Author
王小虎 回复

FAT 上说了目前只支持 python2

小程序玛的测试工具实现原来能说下么

Mingway_Hu 将本帖设为了精华贴 11月16日 18:41
笑哼 #10 · 2018年11月19日 Author
tester 回复

页面跳转哪个很简单 加下路径就行了,还有跳转 url 和 m 页链接转化 也是一样 会有一定转化规则

谢谢分享

simple 专栏文章:[精华帖] 社区历年精华帖分类归总 中提及了此贴 12月13日 14:44

请问入口构造工具和小程序码测试工具在哪可以找到

ivy520 [该话题已被删除] 中提及了此贴 12月16日 22:55
ivy520 [该话题已被删除] 中提及了此贴 12月16日 23:53
simple [精彩盘点] TesterHome 社区 2018 年 度精华帖 中提及了此贴 01月07日 12:08

不错,很详细

很详细,有空慢慢学习;
文章中提到的工具,方便提供吗?或者工具名称下载地址什么的?

zeye 后台是什么?

需要 登录 后方可回复, 如果你还没有账号请点击这里 注册