转转QA 微信小程序自动化探索实践,欢迎提意见

笑哼 for 转转QA · August 08, 2018 · Last by 笑哼 replied at September 07, 2018 · 5725 hits

图片没上传进来,直接去公众号看吧,公众号链接:https://mp.weixin.qq.com/s/U0jFiRsVsChHb8K9995QKQ
作者|肖恒
- 小程序自动化的应用

  • 转转自己的小程序——欢乐送分享到微信群的自动化 自动化视频地址:https://v.qq.com/x/page/s1346vw2clt.html
  • 转转欢乐送是转转孵化的处理闲置小程序,闲置直接送给更需要的人,一口价,24小时送出,无需沟通,快递上门取件。送出闲置得星星,星星领取好物。领取人还可以发出感谢。有爱,简单,欢乐。本文主要介绍转转欢乐送分享到微信群场景的自动化实践。

- 小程序自动化准备工作

  • 打开微信上小程序的调试功能(为了拿到小程序的context)
    • 在私信聊天页,输入http://debugx5.qq.com
    • 勾选【打开TBS内核Inspector调试功能】。
  • 小程序的进程(appium的配置参数chromeOptions中要用到)
    • 没有启动微信,没有启动小程序时在adbshell下的进程清单如下:
    • 刚启动微信,没有进入到小程序页面时在adbshell下的进程清单如下:
    • 启动欢乐送小程序后的进程清单如下,会发现和刚启动微信的进程清单一致,说明刚进入微信会加载小程序相关内容(只是此时的top进程是com.tencent.mm):
    • 进入小程序页面后的进程清单如下,由进程号得知当前的top进程为com.tencent.mm:tools(可简写为tools);
    • 从上图发现appbrand0、tools是进入到小程序后新增的进程,且在进入小程序页面后当前正在运行的进程是tools,对应chromeOptions中的值。

- webview调试利器---chrome-inspector(较好的查看webview页面元素)

  • 其URL:chrome://inspect/#devices。能识别手机上打开的webview页面。是否每个入口的小程序都能在chrome_inspector上查看对应的界面呢?遇到过两种情形:
    • (2018.6.22~至今)只能查看搜一搜入口的小程序(从chrome-inspector上显示的搜一搜url试出来的)
    • (2018.6.22之前)所有入口均能显示小程序页面的url(下拉小程序;搜一搜;微信钱包)
      • 建议:从执行case的稳定性考虑,推荐使用从搜一搜进入到小程序页面

- 基于APPIUM的小程序上下文切换

  • 切换到webview模式下的优点与缺点
    • 看同一个安卓页面上的显示,分别用chrome_inspector和uiautomator显示
  • 对比可以看出在chrome-inspector下页面元素显示的优势:
    • 能够覆盖更多的业务场景(比如上边右图可以轻松定位发布有奖,要用左图的话需要图像识别)
    • 维护量更小(图像识别需要对每个不同的设备的此页面都需要单独截一张图片,以保证能准确识别对应元素)
  • 如何切换到对应元素所在的小程序页面
    • 切换到小程序页面:先切换到元素所在的context,然后切换到元素所在的handle中。元素所在的context对应前面获取到的当前页面的top进程名;handle的话需要你自己去遍历所有的handle,当此handle下的page_source包含你想要的元素,就是你所需要的handle(此处每个页面挑一个只能代表当前页面的元素,防止多个页面有相同元素)
    • 多个小程序页面之间来回切换:再次遍历所有的handle,切换到元素所在的handle中 然后有的人会说,我照着你这篇教程做了,但是仍然没有切换成功。

- 不是所有的设备都能切换成功的(可能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的存放”中可以清晰看到),切换成功。 -只存放2.28、2.29、2.30时,切换会报错。
      • 第二种情形:设备自身的webview版本比微信里的低。
    • 安卓设备自带的webview版本(47)低于57(微信里的webview版本):
      • 只存放2.28和2.29时,切换会报错。
      • 只存放2.28、2.29、2.21时,切换会报错。
  • 所以设备低的可能需要自己尝试其它办法。
    • 第三种情形:设备自身的webview版本与微信里的一致。
      • 小伙伴们,快拿起你的androidsystem webview57版本的手机跑个小程序自动化吧(应该成功)。

- 小程序自动化的搭建
-原则:与端内native、webview保持一致,易维护,易编写case。

  • Case的存放
    • 存放在一个单独的小程序的testsuit里
  • element的编写

    • 小程序中的元素添加1个key(mini_program),与端内保持一致。
  • 小程序中chromedriver的存放

    • 与端内webview保持一致(放在框架里能在不同执行机上更方便地同时执行不同的设备)。
  • appium配置参数

    • 这里值得一提的是chromedriverExecutableDir参数(需要appium版本在1.8及以上才能使用),那么在1.8以下版本呢?(也不需要你做处理,在初始化过程中我会去拿你执行机上的appium版本,系统的webview版本,然后配置对应的参数)
  • 执行机环境的兼容

    • Uiautomator2及appium输入法的兼容(目前执行机上安装了不同版本的Uiautomator2、appium输入法的包)。
  • 执行

    • 支持命令行参数执行,参数用-w或--wechat。
  • 小程序初始化

    • 为了使用上的方便和节省不必要的操作,在执行小程序case时会自动关闭调用端内混淆包的文件和执行端内的预操作。
  • 小程序页面基本操作

    • 元素是否存在、点击、滑动、中英文输入、小程序页面来回切换。

- 未来

  • 对于ios端的小程序的自动化,能有一个可行的方案。(目前可以反编译微信的包来做,但易封号)。
  • 大家都能更方便的编写、调试、执行case,查看执行结果。

- 推荐两篇文章

  • 关于我们做自动化的目的、前期端内搭建的Ui自动化框架、原理、支持的功能可参考转转 App UI自动化进化史
  • 小程序的介绍和测试可参考1分钟了解转转小程序测试体系

公众号链接:https://mp.weixin.qq.com/s/U0jFiRsVsChHb8K9995QKQ

共收到 9 条回复 时间 点赞

阅读体验差了很多哦

笑哼 #2 · August 08, 2018 作者
simple 回复

公众号上有,这个直接从公众号上复制图片没复制进来😀

用4399AT不需要安装和配置浏览器对应的驱动,全部封装好,就可使用~

@xiaohengdada 你好,我按照你说的从搜一搜入口进入小程序,切换到WEBVIEW_com.tencent.mm:tools以后, body里面是空的,然后我运行driver.window_handles来打印所有句柄,可是报错如下:
selenium.common.exceptions.WebDriverException: Message: An unknown server-side error occurred while processing the command. Original error: Could not proxy. Proxy error: Could not proxy command to remote server. Original error: 404 - "unknown command: session/b4c871631fc8b03bd53d7de34e69b789/window/handles"

现在答题的小程序挺多的。能否对此类小程序做自动化?监控接口,获得题目答案,然后取接口值,点击页面区域,完成自动答题呢。

笑哼 #6 · August 22, 2018 作者
jackyd 回复

加我微信,遇到过这个错误,解决了

请问各位移动端使用的模拟器么,有没有比较方便的技术推荐

lofbat-github 回复

使用的真机

simple 回复

排版我改了下

需要 Sign In 后方可回复, 如果你还没有账号请点击这里 Sign Up