3.12 运行Monkey程序
Adrian Cowham
3.12.1 问题
你希望对应用程序进行一些好的随机使用测试。
3.12.2 解决方案
使用Android Monkey命令行工具测试你所开发的测试应用程序。
3.12.3 讨论
从字面上看,测试非常简单,连猴子(Monkey)都能完成。尽管Android缺乏测试工具,但是我必须承认,Monkey是相当好的工具。你可能不熟悉Android Monkey,它是Android SDK自带的一个测试工具,模拟猴子(也可能是个孩子)使用Android设备。想象一下,一只猴子坐在键盘上乱动——了解了吗?还有什么方法比这更能找出隐藏的ANR信息?
运行Monkey很简单,启动模拟器(或者将开发设备连接到开发机器上),然后启动Monkey脚本。我不愿意承认这一点,但是每天运行Monkey,我们不断地发现在常规的QA测试中没有发现的缺陷,这些缺陷如果在用户使用的现场发现,将难以维修,更糟糕的是,会导致用户不再使用我们的应用程序。
下面是在开发过程中使用Monkey的最佳实践:
创建自己的Monkey脚本来封装Android Monkey脚本。这样能确保团队中的开发人员以相同的参数运行Monkey。如果你的团队只有一个人,这样做有助于可预测性(很快将会讨论)。
配置Monkey,使其运行足够长的时间以捕捉缺陷,也可以运行较短的时间以提供更好的生产率。在我们的开发过程中配置Monkey,一共运行50000个事件,在Samsung Galaxy平板电脑上大约运行40分钟,这还不错,但是我希望它在30分钟内完成。很显然,平板电脑的速度越快,吞吐量就越大。
Monkey是随机的,所以当我们第一次开始运行时,每个开发人员都得到不同的结果,无法重现缺陷。后来,我们发现Monkey可以设置随机数发生器的种子。
所以,在你的包装器脚本中要设置Monkey的种子。这能保证在开发团队中运行Monkey的一致性和可预测性。
一旦特定的种子值确认了应用程序,则修改种子值,因为你永远不知道Monkey会找到什么。
下面是一个Monkey脚本包装器,以及参数的描述:
#!/bin/bash
# Utility script to run monkey
#
# See: http://developer.android.com/guide/developing/tools/monkey.html
rm tmp/monkey.log
adb shell monkey -p package.name.here --throttle 100 -s 43686 -v 50000 |
tee tmp/monkey.log
-p package name确保Monkey只针对于指定的包。
--throttle是事件之间的延时。
-s是种子值
-v是VERBOSE选项。
50000是Monkey模拟的事件数量。
Monkey还有许多配置选项;我们有意地不选择配置Monkey生成的事件类型,因为我们了解那种痛苦。例如,我们选择的种子值导致Monkey在运行到一半时禁用Wi-Fi。开始时我们为此而感到沮丧,因为我们感觉这不是想要的覆盖范围。结果是,Monkey禁用Wi-Fi并且乱运行应用程序,这其实帮助了我们。在发现和修复了几个缺陷之后,我们完全确信,应用程序在没有网络连接的情况下能够按照预期运行。
这真是一只好猴子。