一直以来,都想给自己的移动端自动化生涯画个圆满的句号,奈何有两大难题之前一直没有得到很好的解决;类比一下整个行业内的移动端录制回放工具(Total Control、Testing的移动录制工具等),要么是基于纯坐标的(回放兼容性、准确性是个问题),要么做的太重(使用前依赖的东西太多),要么没有做到完美的By对象行为轨迹抓取、精细化回放,要么没有做到PC/Mobile同屏......很多遗憾和缺陷其实是在日常工作中因诸多不便累积起来的,这也形成了小编做这方面研究和总结的原动力。
Uiautomator基础
核心框架依然是小编十分喜爱的Uiautomator;它的优势不言而喻!相信看完之前的文章后大家对这个框架已经不是很陌生,那在此就不炒现饭了。直接上代码!
Uiautomator中需要用到几大武器先罗列如下:
如何利用Uiautomator写出自动化用例
在此分享一点入门知识:https://jingyan.baidu.com/article/6525d4b18b23bfac7d2e9435.html 。然而,使用代码编写自动化测试用例的时代已经结束;智能化时代掀开的是更便捷的“基于录制、回放系统的自动化测试解决方案”;那么问题来了,我们怎样才能实现录制、怎样才能实现回放?不急,继续往下看!
什么是“基于录制、回放的自动化系统”
录制:指的是用户在手机(Mobile)上操作时的行为轨迹和用户数据按照某种约定俗成的规则自动化记录下来
回放:指的是将之前的用户行为在手机上让手机自己执行一遍或者按照某种策略多变的执行
录制时遇到的难题(同屏传递 和 DumpXML)
一:怎么在手机上记录下来用户的行为轨迹?
首先,需要弄清楚两个概念:
1). 用户的行为轨迹有哪些? 回答:点击、双击、滑动、拖拽、输入、下拉等(按照动作类型划分)
2). 怎么获取?回答:要获取行为轨迹,必须要清楚操作在哪里,做的什么事情;然后是考虑用什么途径去获取上述信息;为了解决这个难题,行业内有的公司采用的直接从手机上获取坐标(手机必须先Root),有的采用的是PC协助用adb监听的方式;
然后,切入点在哪里?
从最终要达成的效果来看,直接从手机上获取受制于手机需要root这一步,因此绝大多数手机是User版绕不过这个难题,且将来会遭遇兼容性的大问题;因此毫无疑问使用PC协助的方式;但使用PC协助又该注意什么样的问题?用adb循环监听手机屏幕的触屏事件吗?貌似可以达到录制点击的目的,但是输入呢?后续滑动等操作呢?会遇到很多大问题!因此,小编采用的方式也是困扰自己很久的一大难题:同屏传递(在PC上投影手机屏幕进行录制)
效果如下:
点击悬浮窗功能,吊起PC端虚拟屏幕,虚拟屏幕链接上手机端的View,并在虚拟屏幕上监听一系列鼠标操作,也包括键盘输入...这么设计的好处是反馈实时,步调一致; PC与Mobile画面的跟随性比较好,用户体验较adb 截取image传递好了一大截!
二:怎么 精确地 在手机上记录用户的行为轨迹?
为什么会有这个需求?源自实际落地时的效果并不尽如人意;以往的录制以坐标为主,一旦换了不同分辨率的手机,或者控件的位置发生变化,之前的脚本就得介入维护;久而久之,性价比不高了;
解决办法:将录制坐标转化为录制UI对象,这里就不得不使用UiautomatorViewer(UiautomatorViewer可以精确的找到控件属性,为后面回放打下坚实基础)
然而,另一大难题是:uiautomator dump xml 存在巨大的性能问题;平均延时2~4s
为了精确录制获取控件对象,不得不做些转变。需要将Uiautomator中对外提供的Bridge桥接模式做些改进,摒弃adb外部抓取的思路,自定义一套信息传递通道,并兼容请求多变等复杂场景,以提升获取对象的整体速度(经实验可提升100倍),最后结合一点小算法精确投票找到操作对象,才算解决了第二大难题!
回放端的设计
回放采用多端回放的设计方式,不仅支持在PC端连数据线回放,也支持在手机内部自动回放,效果如下:
PC端回放
移动端回放
系统最大的不同是什么?
回答: 一台PC可以带N台手机,可以同时录制N台手机,也支持N台手机之间的一般交互性事件的录制和回放
总结与反思:
用例的持续集成化执行在很多公司都大同小异,唯有录制工具这块的实现则各有千秋。根据项目的不同需定制化各自的录制方法以实现不同项目上多变的需求。因此,在录制部分的实现上,呈现了百花齐放的局面。基于Uiautomator+同屏传递技术是小编实操后觉得可行的其中一种方案,它于Uiautomator设计十分轻量化,加上同屏传递克服了无线投屏技术,整个行成一套录制体系。小编在过去的几年中一直寻求Uiautomator性能问题的最佳解决方案和同屏传递技术的实现方法,终于在近期攻克所有难题、有了自己心中完美的封版之作。特此下笔以纪念不可逆转的往昔青春岁月!欢迎各路大神前来讨论,共同进步!
由于时间关系,不在此就具体实现源码解读和介绍,稍后会奉上UiautomatorViewer加强型试用版,待系统整体功能稳定之后会在此继续分享原理和开源项目!谢谢大家的阅读~!
附录:
广播提示:adb shell am broadcast -a android.intent.action.BROADCAST_FORM_ADB --es msg Notice:
动作唤醒:adb shell am instrument -w -r -e debug false -e class com.wy.slidingmenubestimplementation.TestDemo#testhellotest -e actionInfo 540#627#qiuhanruo com.wy.slidingmenubestimplementation.test/android.support.test.runner.AndroidJUnitRunner
adb shell am instrument -w -r -e debug false -e class com.wy.slidingmenubestimplementation.TestInput#typeMethod -e actionInfo XXXX#XXXX#XXXX com.wy.slidingmenubestimplementation.test/android.support.test.runner.AndroidJUnitRunner
加强型UiautomatorViewer试用版
工具下载
链接:https://pan.baidu.com/s/1k62G0DmaS-0JA3zi51SA4w