文章目录
一、Monkey工具是什么?
- 顾名思义,Monkey就是猴子, Monkey测试,就像一只猴子, 在电脑面前,乱敲键盘在测试。 猴子什么都不懂, 只知道乱敲。Monkey测试是Android平台下自动化测试的一种快速有效的手段,通过Monkey工具可以模拟用户触摸屏幕、滑动轨迹球、按键等操作来对模拟器或者手机设备上的软件进行压力测试,检测该软件的稳定性、健壮性。它的原理是向系统发送伪随机的用户事件流(如按键输入、触摸输入、手势输入等),实现对正在开发的应用程序进行压力测试。
二、 环境准备
- Android Studio
- SDK版本为6.0的安卓模拟器
注:由于使用过程中需要通过ADB工具直接操作管理android模拟器或者真实的andriod设备,在使用过程中有些操作(例如通过ls命令查看安卓文件夹下的包)需要root权限。在其他版本中,当运行命令adb shell时,会默认以shell身份进入到手机的shell环境中,需要通过su命令进入root模式(而且安卓有些版本已经把su命令给除去了,需要另行添加su文件,操作麻烦且具有不确定性)。然而,在安卓6.0版本中,使用adb shell命令进入命令行模式后默认为root权限,所以,我们选择6.0版本进行操作。
三、Monkey工具的简单示例
- 首先,打开Android Studio 的 Terminal窗口,输入adb devices命令查看已连接的模拟器。
- 输入 adb shell 命令进入已连接的设备开启命令行模式。若有多个连接设备,可通过 adb -s emulator-5554 命令指定进入设备名为emulator-5554的设备开启命令行模式。可通过 exit 命令退出该命令行模式。
- 在shell命令行模式下,使用 ls data/data 命令查看data 文件夹下的我们需要测试的应用的包名,如下图,找到我们要测试的包 com.example.testui。
- 使用 monkey -p com.example.testui -v 1000 命令对应用testui进行简单的压力测试,我们会发现模拟器上该应用会自行进行操作,同时,命令行也会输出测试的操作轨迹和相关信息。
测试过程(GIF动图):
Terminal下测试的操作轨迹和相关信息:
注:上图中出现的九个百分比为九个不同测试事件的百分比,九个事件分别为0--pct-touch <percent> 调整触摸事件的百分比(触摸事件是一个down-up事件,它发生在屏幕上的某单一位置)(——点击事件,涉及down、up) 1--pct-motion <percent> 调整动作事件的百分比(动作事件由屏幕上某处的一个down事件、一系列的伪随机事件和一个up事件组成) (——注:move事件,涉及down、up、move三个事件) 2--pct-trackball <percent> 调整轨迹事件的百分比(轨迹事件由一个或几个随机的移动组成,有时还伴随有点击)--(轨迹球) 3--pct-nav <percent> 调整“基本”导航事件的百分比(导航事件由来自方向输入设备的up/down/left/right组成) 4--pct-majornav <percent> 调整“主要”导航事件的百分比(这些导航事件通常引发图形界面中的动作,如:5-way键盘的中间按键、回退按键、菜单按键) 5--pct-syskeys <percent> 调整“系统”按键事件的百分比(这些按键通常被保留,由系统使用,如Home、Back、Start Call、End Call及音量控制键) 6--pct-appswitch <percent> 调整启动Activity的百分比。在随机间隔里,Monkey将执行一个startActivity()调用,作为最大程度覆盖包中全部Activity的一种方法。(从一个Activity跳转到另一个Activity) 7--pct-flip <percent> 调整“键盘翻转”事件的百分比。 8--pct-anyevent <percent> 调整其它类型事件的百分比。它包罗了所有其它类型的事件,如:按键、其它不常用的设备按钮、等等。
四、Monkey基本命令详解
-
参数: -p
参数-p用于约束限制,用此参数指定一个或多个包(Package,即App)。指定包之后,Monkey将只允许系统启动指定的APP。如果不指定包,Monkey将允许系统启动设备中的所有APP。- 指定一个包:monkey -p com.bag1 100 - 指定多个包:monkey -p com.bag1 –p com.bag2 -p com.bag3 100 - 不指定包:monkey 100
-
参数: -v
用于指定反馈信息级别(信息级别就是日志的详细程度),总共分3个级别,分别对应的参数如下表所示: - 日志级别 Level 0 示例:adb shell monkey -p com.htc.Weather –v 100 说明:缺省值,仅提供启动提示、测试完成和最终结果等少量信息 - 日志级别 Level 1 示例:adb shell monkey -p com.htc.Weather –v -v 100 说明:提供较为详细的日志,包括每个发送到Activity的事件信息 - 日志级别 Level 2 示例:adb shell monkey -p com.htc.Weather –v -v –v 100 说明:最详细的日志,包括了测试中选中/未选中的Activity信息
-
参数: -s
用于指定伪随机数生成器的seed值,如果seed相同,则两次Monkey测试所产生的事件序列也相同的。- 示例: Monkey测试1:adb shell monkey -p com.bag1 –s 10 100 Monkey测试2:adb shell monkey -p com.bag1 –s 10 100
两次测试的效果是相同的,因为模拟的用户操作序列(每次操作按照一定的先后顺序所组成的一系列操作,即一个序列)是一样的。操作序列虽然是随机生成的,但是只要我们指定了相同的Seed值,就可以保证两次测试产生的随机操作序列是完全相同的,所以这个操作序列伪随机的;
-
参数: --throttle <毫秒>
用于指定用户操作(即事件)间的时延,单位是毫秒;- 示例:adb shell monkey -p com.htc.Weather –throttle 3000 100
-
参数: --ignore-crashes
用于指定当应用程序崩溃时(Force & Close错误),Monkey是否停止运行。如果使用此参数,即使应用程序崩溃,Monkey依然会发送事件,直到事件计数完成。- 示例1:adb shell monkey -p com.htc.Weather --ignore-crashes 1000 测试过程中即使Weather程序崩溃,Monkey依然会继续发送事件直到事件数目达到1000为止; - 示例2:adb shell monkey -p com.htc.Weather 1000 测试过程中,如果Weather程序崩溃,Monkey将会停止运行。
-
参数: --ignore-timeouts
用于指定当应用程序发生ANR(Application No Responding)错误时,Monkey是否停止运行。如果使用此参数,即使应用程序发生ANR错误,Monkey依然会发送事件,直到事件计数完成。 -
参数: --ignore-security-exceptions
用于指定当应用程序发生许可错误时(如证书许可,网络许可等),Monkey是否停止运行。如果使用此参数,即使应用程序发生许可错误,Monkey依然会发送事件,直到事件计数完成。 -
参数: --kill-process-after-error
用于指定当应用程序发生错误时,是否停止其运行。如果指定此参数,当应用程序发生错误时,应用程序停止运行并保持在当前状态(注意:应用程序仅是静止在发生错误时的状态,系统并不会结束该应用程序的进程)。 -
参数: --monitor-native-crashes
用于指定是否监视并报告应用程序发生崩溃的本地代码。 -
参数: --pct-{+事件类别} {+事件类别百分比}
用于指定每种类别事件的数目百分比(在Monkey事件序列中,该类事件数目占总事件数目的百分比)示例:--pct-touch {+百分比} 调整触摸事件的百分比(触摸事件是一个down-up事件,它发生在屏幕上的某单一位置) adb shell monkey -p com.htc.Weather --pct-touch 10 1000
五、Monkey日志分析
-
正常情况,如果Monkey测试顺利执行完成,在log的最后会打印出当前执行事件的次数和所花费的时间;出现 // Monkey finished 代表执行完成。
-
异常情况,查阅Monkey的输出日志 (为了进一步分析问题的来源,可以找到Log中出现问题处的前一次Switch,随后根据Log主要是查看相关的Activity)
1)程序无响应的问题: 在日志中搜索 “ANR”
2)崩溃问题:在日志中搜索 “Exception”
3)如果有空指针,搜索“NullPointerException”
4)如果Monkey执行中断,在log最后也能看到当前执行次数 -
如果要导出log日志在本地,则必须使用 exit 命令退出shell命令行模式,在本机上使用 adb shell monkey -p com.example.testui -s 500 --ignore-crashes --ignore-timeouts --monitor-native-crashes -v -v -v 10000 > D:\log.txt 命令进行测试并导出日志。
六、参考材料
- Android monkey 官方网站:https://developer.android.com/studio/test/monkey.html
- Android monkey 参数分析:https://blog.csdn.net/jlminghui/article/details/38238443
- Android monkey 日志分析:https://blog.csdn.net/qq_18456543/article/details/76209139
作者:蔡艺泽
原文:原文链接