1.3 移动端自动化测试工具的选择

之所以需要选择,是因为可选项太多了,不同的平台,会有很多不同的自动化测试工具供选择,其中既有商业性的收费工具,也有开源免费的自动化测试工具。

这本书的主题Robotium就是其中一种开源的自动化测试框架,在正式展开前,先看看当下还有哪些在Android测试方面比较常用的测试框架可供选择。

1.3.1 Appium

Appium也是一种自动化测试框架,可以用来测试natvie、hybrid和mobile web APP, Appium最吸引人的一点是,它既支持Android方面的自动化测试,又支持iOS方面的测试。

它还支持使用不同的编程语言编写测试代码,但这种便捷性是以牺牲一部分执行速度换来的,因为这需要额外的转换时间,转换成对应的可操作的底层的测试框架。Appium在Android方面底层使用的测试框架是uiautomator和instrumentation, iOS则使用Apple提供的UIAutomation。明白了这点,也就不奇怪为什么Appium可以支持跨进程地操作iOS的测试了。

Appium经常被“吐槽”的还有一点,就是稳定性还有待提升,但它的这些优点也是很明显的,参与的人越来越多,贡献的力量也就越大,经过一段时间的发展,相信Appium会更加稳定和流行。

读者可以访问Appium的官方网站http://appium.io/,在这里可以获得关于它的一些详细介绍。

国内TesterHome社区也有不少Appium方面的资料和讨论。

1.3.2 uiautomator

uiautomator是Google官方提供的一款自动化测试框架,其主要特点是支持跨进程的操作,这一点极大地方便了对应用外控件的操作。

当然了,uiautomator在提供便捷性的同时,也存在着一些不足,如只支持Android SDK Platform、API 16及以上的。除此之外,它对WebView的支持也不好。

还有一点就是调试很不方便,要调试首先需要在启动的命令行配置好调试项后才能进行,启动后还需在Eclipse中新建Remote Java Application选项,相对来说比较麻烦。虽然也可以通过输出Log的形式来调试,但不如其他工具有插件支持调试方式便捷。

uiautomator的编译运行也比较麻烦,测试代码一有修改,就需要重写、编译产生jar文件,然后还要将jar文件Push到手机指定的目录下才能使用,虽然可以通过批处理文件将这些步骤封装起来,但还是略显麻烦。

想了解更详细的信息,请到它的官方网站,那里可以查看uiautomator的API详细介绍、命令行运行uiautomator的参数及命令解释,以及一些入门的例子。

官方网站:http://developer.android.com/tools/testing/testing_ui.html。

1.3.3 Robotium

Robotium也是一款开源的自动化测试框架,可以支持native和hybrid的自动化测试,API使用起来简单方便,执行速度也快。

但Robotium有一个比较大的局限性就是不支持跨进程的操作,但也有相应的解决方案,后面章节会介绍到。

Robotium在ADT插件的支持下,可以很简单地在Eclipse下调试运行,这一点比uiautomator便捷多了。

Robotium官方网站的wiki标签下还提供了一些简单易懂、容易上手的示例项目,在这里也可以查看Robotium的API文档,Robotium的方法命名很直观,一般通过方法名就可以知道这个方法所能实现的功能。

最后,Robotium是开源的,托管在GitHub https://github.com/RobotiumTech/Robotium。

它的代码量不大,可以很容易地进行二次开发,然后定制出自己需要的功能。

当然还有其他的自动化测试框架可供选择,如monkey、monkeyrunner、Testdroid(商业)、Eggplant(商业)等,每种工具都有优缺点,关键在于根据产品的特性,选择一款适合的自动化测试工具,不要盲目跟风,合适才是最重要的,当然可以混合使用多种自动化测试工具来克服一些工具本身的局限性,以便得到更好的自动化测试效果。