一、简介
monkey testing,也有人叫做搞怪测试。就是用一些稀奇古怪的操作方式去测试被测试系统,以测试系统的稳定性。monkey test,一般指这样的测试活动,用毫无规律的指令或操作使用被测系统,观察系统的稳定性和容错性能。
二、原理
Monkey测试是Android自动化测试的一种手段,Monkey测试本身非常简单,就是模拟用户的按键输入,触摸屏输入,手势输入等,看设备多长时间会出异常。
当Monkey程序在模拟器或设备运行的时候,如果用户触发了比如点击,触摸,手势或一些系统级别的事件的时候,它就会产生随机脉冲,所以可以用Monkey用随机重复的方法去负荷测试你开发的软件.
三、特点
- 基于Android测试开发环境
- 需要获取对应程序包
- 一般是产品稳定后,或者首轮功能测试完成后进行Monkey测试
- Monkey测试的操作事件是随机进行,而不是刻意指定
- 主要测试产品是否存在崩溃问题和ANR问题
四、获取包名的方法
向开发人员索取应用程序包名
-
adb命令获取包名
直接获取当前开启应用的包名
adb shell dumpsys activity | find "mFocusedActivity"
结果:
mFocusedActivity: ActivityRecord{15300bd2 u0 com.tencent.mm/.ui.LauncherUI t3}
注意:改命令在Android 8.0之下可以使用,8.0以上会存在问题,修改命令如下即可:
adb shell dumpsys activity | find "mResumeActivity"
- adb logcat获取包名,命令如下:
adb shell "logcat | grep START"
如果,无法获取,首先,检查设备是否连接成功,然后命令进入shell,再获取包名
adb shell
接着,输入命令:
# logcat | grep START
然后,在手机或者模拟器中打开想要获取的应用程序,接着在adb命令行中会自动获取到对应的程序包名。
- 从data数据中获取包名
首先,是进行shell
adb shell
然后,再找到shell中的data文件夹
root@shamu:/ # cd data
root@shamu:/data # ls
再找到data文件夹下的data文件
root@shamu:/data # cd data
root@shamu:/data/data # ls
结果,就可以查看到手机中安装的所有应用程序包名:
五、基本语法
# -p:packageName
# -v:日志级别,显示程序的执行测试反馈信息
# 100:事件数
adb shell monkey -p 包名 -v 100
六、日志级别
参数: -v 用于指定反馈信息级别(信息级别就是日志的详细程度),总共分3个级别。
分别对应的参数如下表所示:
- 日志级别 Level0
adb shell monkey -p 包名 –v 100
说明 缺省值,仅提供启动提示、测试完成和最终结果等少量信息
- 日志级别 Level 1
adb shell monkey -p 包名 –v -v 100
说明 提供较为详细的日志,包括每个发送到Activity的事件信息
- 日志级别 Level 2
adb shell monkey -p 包名 –v -v –v 100
说明 最详细的日志,包括了测试中选中/未选中的Activity信息
七、伪随机数生成器
应用场景:在测试时,发现程序有bug,那么可以通过此方法,复现bug。因为加-s后,monkey执行的操作将会固定,若不加-s那么monkey的操作将会随机进行。
参数: -s 用于指定伪随机数生成器的seed值,如果seed相同,则两次Monkey测试所产生的事件序列也相同的。 示例:
Monkey测试1:
adb shell monkey -p 包名 –s 10 1000
Monkey 测试2:
adb shell monkey -p 包名 –s 10 1000
两次测试的效果是相同的,因为模拟的用户操作序列(每次操作按照一定的先后顺序所组成的一系列 操作,即一个序列)是一样的。
操作序列虽然是随机生成的,但是只要我们指定了相同的Seed值,就可以保证两次测试产生的随机操作序列是完全相同的,所以这个操作序列伪随机的。
八、事件类型
- --pct-touch:指定触摸事件的百分比,如:--pct-touch 5
- --pct-motion (滑动事件)
- --pct-trackball (轨迹球事件)
- --pct-nav (导航事件 up/down/left/right)
- --pct-majornav (主要导航事件 back key 、 menu key)
- --pct-syskeys (系统按键事件 Home 、Back 、startCall 、 endCall 、 volumeControl)
- --pct-appswitch (activity之间的切换)
- --pct-anyevent (任意事件)
九、ANR日志导出
Android系统的ANR日志存放在/data/anr/traces.txt中,其中包含应用程序每个线程堆栈信息。测试人员或者开发人员可以根据这个信息定位bug。ANR日志文件traces.txt导出手机操作如下:
- 首先进入shell
adb shell
- 然后,复制ANR日志文件traces.txt至具有读写操作的文件中
cp /data/anr/traces.txt /sdcard/traces.txt
- 最后,pull命令导出至计算机
adb pull /sdcard/traces.txt
十、Crash日志导出
执行压力测试,并且生成monkey_test.log日志文件。
adb shell monkey -p cn.besttest.crashtest -v 100 >D:\monkey\monkey_crash.log
查看E盘文件夹下已经生成了monkey_crash.log。
十一、结果分析
- 按关键字进行搜索,ANR、Exception、Crash、Error。
ANR问题(程序无响应):在日志中搜索“ANR"(application no response)
闪退问题:在日志中搜索"crash"
异常:搜索"exception"
强制退出:搜索"force closed"
- 找到有问题的地方,查看上下文信息。注意第一个switch上下文信息。
- 查看monkey里面出错前的一些事件动作,可以手动执行该动作。
- 进行问题复现,可以使用之前执行的monkey命令在执行一遍,注意seed值要一样。