欢乐送小程序自动化探索实践
作者|肖恒
https://v.qq.com/txp/iframe/player.html?vid=k1346d5ze4a&width=500&height=375&auto=0
转转欢乐送是转转孵化的处理闲置小程序,闲置直接送给更需要的人,一口价,24小时送出,无需沟通,快递上门取件。送出闲置得星星,星星领取好物。领取人还可以发出感谢。有爱,简单,欢乐。
本文主要介绍转转欢乐送分享到微信群场景的自动化实践。
1、 打开微信上小程序的调试功能(为了拿到小程序的context)
在私信聊天页,输入http://debugx5.qq.com,点击后跳转到x5调试页面,点击信息,然后勾选【打开TBS内核Inspector调试功能】。
2、小程序的进程(appium的配置参数chromeOptions中要用到)
没有启动微信,没有启动小程序时在adbshell下的进程清单如下:
启动欢乐送小程序后的进程清单如下,会发现和刚启动微信的进程清单一致,说明刚进入微信会加载小程序相关内容(只是此时的top进程是com.tencent.mm):
进入小程序页面后的进程清单如下,由进程号得知当前的top进程为com.tencent.mm:tools(可简写为tools);
从上图发现appbrand0、tools是进入到小程序后新增的进程,且在进入小程序页面后当前正在运行的进程是tools,对应chromeOptions中的值。
3、webview调试利器---chrome-inspector(较好的查看webview页面元素)
其URL:chrome://inspect/#devices。能识别手机上打开的webview页面。是否每个入口的小程序都能在chrome_inspector上查看对应的界面呢?遇到过两种情形:
(1)(2018.6.22~至今)只能查看搜一搜入口的小程序(从chrome-inspector上显示的搜一搜url试出来的)
(2)(2018.6.22之前)所有入口均能显示小程序页面的url(下拉小程序;搜一搜;微信钱包)
建议:从执行case的稳定性考虑,推荐使用从搜一搜进入到小程序页面
1、 切换到webview模式下的优点与缺点
看同一个安卓页面上的显示,分别用chrome_inspector和uiautomator显示
对比可以看出在chrome-inspector下页面元素显示的优势:
能够覆盖更多的业务场景(比如上边右图可以轻松定位发布有奖,要用左图的话需要图像识别)
维护量更小(图像识别需要对每个不同的设备的此页面都需要单独截一张图片,以保证能准确识别对应元素)
2、如何切换到对应元素所在的小程序页面
切换到小程序页面:先切换到元素所在的context,然后切换到元素所在的handle中。元素所在的context对应前面获取到的当前页面的top进程名;handle的话需要你自己去遍历所有的handle,当此handle下的page_source包含你想要的元素,就是你所需要的handle(此处每个页面挑一个只能代表当前页面的元素,防止多个页面有相同元素)
多个小程序页面之间来回切换:再次遍历所有的handle,切换到元素所在的handle中
然后有的人会说,我照着你这篇教程做了,但是仍然没有切换成功。
3、不是所有的设备都能切换成功的(可能appium框架里有bug)
Chromedriver与webview版本对应关系(这个很重要)的链接:https://github.com/appium/appium/blob/master/docs/en/writing-running-appium/web/chromedriver.md
第一种情形:设备自身的android system webview版本比微信里的webview版本高。
安卓设备自带的android system webview版本(59)高于57(微信里的webview版本与tbs版本号有关,目前我们的微信基本都是最新的):
只存放chromedriver2.28和2.29时(chromedriver的存放位置在“小程序自动化的搭建---小程序中chromedriver的存放”中可以清晰看到),切换成功。
第二种情形:设备自身的webview版本比微信里的低。
安卓设备自带的webview版本(47)低于57(微信里的webview版本):
只存放2.28和2.29时,切换会报错。
所以设备低的可能需要自己尝试去改源码。
第三种情形:设备自身的webview版本与微信里的一致。
小伙伴们,快拿起你的androidsystem webview57版本的手机跑个小程序自动化吧(应该成功)。
小程序自动化的搭建原则:与端内native、webview保持一致,易维护,易编写case。
1、Case的存放
存放在一个单独的小程序的testsuit里
2、 element的编写
小程序中的元素添加1个key(mini_program),与端内保持一致。
3、小程序中chromedriver的存放
与端内webview保持一致(放在框架里能在不同执行机上更方便地同时执行不同的设备)。
4、appium配置参数
这里值得一提的是chromedriverExecutableDir参数(需要appium版本在1.8及以上才能使用),那么在1.8以下版本呢?(也不需要你做处理,在初始化过程中我会去拿你执行机上的appium版本,系统的webview版本,然后配置对应的参数)
5、执行机环境的兼容
Uiautomator2及appium输入法的兼容(目前执行机上安装了不同版本的Uiautomator2、appium输入法的包)。
6、执行
支持命令行参数执行,参数用-w或--wechat。
7、小程序初始化
为了使用上的方便和节省不必要的操作,在执行小程序case时会自动关闭调用端内混淆包的文件和执行端内的预操作。
8、小程序页面基本操作
元素是否存在、点击、滑动、中英文输入、小程序页面来回切换。
未来1、对于ios端的小程序的自动化,能有一个可行的方案。(目前可以反编译微信的包来做,但易封号)。
2、大家都能更方便的编写、调试、执行case,查看执行结果。
推荐两篇文章1、关于我们做自动化的目的、前期端内搭建的Ui自动化框架、原理、支持的功能可参考转转 App UI自动化进化史
2、小程序的介绍和测试可参考1分钟了解转转小程序测试体系