互联网-测试

迁移到最新版的Android Uiautomator

2015-07-18  本文已影响1870人  每天多一点

概要

Android目前的测试工具相较于4.0之前的版本变化很大. 令人欣喜的是Android的测试工具被重新整理分类. 针对不同的测试目的, 分别有了不同的测试解决方案:

基于较高版本的Junit

统一了Runner

早期的Uiautomator是以ant组织的jar包程序, 由内置的Uiautomator命令启动.
而最新的Support Library使用AndroidJUnitRunner 统一了各种用例的执行. 带来的好处是无论是单元测试还是UI测试, 都可以使用统一的runner. 在这之前, Uiautomator的用例是通过Uiautomator命令来支持的. 当然, 现在Uiautomator也依然好用.

命令行的限制

由于新版的Uiautomator用例是APK的附属品. 早期Uiautomator中使用的各种系统命令也需要获取一定的权限才可以正常运行. 比较普遍的如, 获取SurfaceFlinger权限, Dump权限, 读取Logcat的权限等等, 需要添加到Apk的manifest文件.
同时, 笔者实验时, 发现以前应用内部可以通过命令行调用Uiautomator, 似乎现在变得不可行.
需要注意的是, 以前通过命令行来实现的测试手段, 在新版的Uiautomator下,会有更好的解决方案. 比如, 之前通过dumpsys windows命令来取得当前的顶层Activity名字. 在新版的Uiautomator上, 借助context可以轻松取得task栈, 进而得到顶层Activity的名字.

成本考量

总结

从官方的推荐来看, 针对单应用测试, 在可以得到代码的前提下, 最理想的是Espresso, 同时, 为了兼顾个别跨应用的用例, 可以辅以Uiautomator.
而针对非白盒的情况, Uiautomator仍然是首选. 同时, 编译jar包上传到测试机运行的方式仍然支持.
从长远观点来看, 迁移到新的Uiautomator方式会获得更多的灵活性.

上一篇 下一篇

猜你喜欢

热点阅读