一、Monkey是什么?
顾名思义,Monkey就是猴子, Monkey测试,就像一只猴子, 在电脑面前,乱敲键盘在测试。 猴子什么都不懂, 只知道乱敲。
通过Monkey程序模拟用户触摸屏幕、滑动Trackball、 按键等操作来对设备上的程序进行压力测试,检测程序多久的时间会发生异常。
Monkey 就是SDK中附带的一个工具。
二、Monkey测试的目的
该工具用于进行压力测试。然后开发人员结合Monkey打印的日志和系统打印的日志,结局测试中出现问题。
三、Monkey测试的特点
Monkey测试所有的事件都是随机产生的,不带任何人的主观性。
四、Monkey命令详解
- 标准的monkey命令
[adb shell] monkey [options] 例如:
adb shell monkey -v 500 ---------------------------------->产生500次随机事件,作用在系统中所有activity
这只是一个简单的例子,实际情况中通常会有很多options选项 - 四大类---------常用选项、事件选项、约束选项、调试选项
- 常用选项
–help:打印帮助信息
-v:指定打印信息的详细级别,一个**-v**增加一个级别,默认级别为0; - 事件选项
-s:指定产生随机事件种子值,相同的种子值产生相同的事件序列。
如:-s 200
–throttle:每个事件结束后的间隔时间——降低系统的压力(如不指定,系统会尽快的发送事件序列)。
如:–throttle 100
–pct-touch:指定触摸事件的百分比,如:–pct-touch 5% , 相关的还有以下option:
–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 (任意事件) - 约束选项
-p:指定有效的package(如不指定,则对系统中所有package有效),一个**-p** 对应一个有效package
如:-p com.ckt -p com.ckt.asura
-c:activity必须至少包含一个指定的category,才能被启动,否则启动不了。 - 调试选项
–dbg-no-events:初始化启动的activity,但是不产生任何事件。
–hprof:指定该项后在事件序列发送前后会立即生成分析报告 —— 一般建议指定该项。
–ignore-crashes:忽略崩溃
–ignore-timeouts:忽略超时
–ignore-security-exceptions:忽略安全异常
–kill-process-after-error:发生错误后直接杀掉进程
–monitor-native-crashes:跟踪本地方法的崩溃问题
–wait-dbg:知道连接了调试器才执行monkey测试。
五、一个简单的monkey
adb shell monkey -p com.xy.android -s 500 -v 1000
六、monkey输出日志和日志分析
现在D盘中建立文件夹,例如:monkey_log,然后输入
例如:
adb shell monkey -p 应用程序包名 -s 500 --ignore-crashes --ignore-timeouts --monitor-native-crashes -v -v 10000 >D:\monkey_log\java_monkey_log.txt
执行完成后,在monkey_log的文件夹下方有java_monkey_log.txt文件
adb shell monkey -p 应用程序包名 -s 500 --ignore-crashes --ignore-timeouts --monitor-native-crashes -v -v 10000 >D:\monkey_log\java_monkey_log.txt
打开java_monkey_log.txt,查看测试结果,进行分析
(1)找到是monkey里面的哪个地方出现错误;
(2)查看monkey里面出错前的一些事件动作,并手动执行该动作;
(3)若以上步骤还不能找到,可以使用之前执行monkey命令,再执行一遍,注意使用的seed值要一样
测试结果分析:
(1)ANR问题(程序无响应):在日志中搜索“ANR"(application no response);
(2)闪退问题:在日志中搜索"crash";
(3)异常:搜索"exception";
(4)强制退出:搜索"force closed"。
adb shell monkey -p com.hrbb.directbanks -v 5000 --ignore-crashes --ignore-timeouts --monitor-native-crashes -v -v 10000 >D:\monkey_log\logq.txt