Monkey压力测试
1.monkey是什么
- 顾明思义,monkey就是猴子,monkey测试,就像一只猴子,在电脑面前,乱敲键盘在测试。
- 通过monkey程序模拟用户触摸屏幕,滑动trackball、按键等操作来对设备上的程序进行压力测试,检测程序多久的时间会发生异常
- monkey就是SDK中附带的一个工具
2.monkey测试的目的
该用具用于进行压力测试。然后开发人员结合monkey打印的日志和系统打印的日志,解决测试中出现的问题
3.monkey测试的特点
monkey测试,所有的事件都是随机产生的。不带任何人的主观性
4.monkey命令详解
1.标准的monkey命令
- 【adb shell】 monkey 【options】例如 adb shell monkey -v 500
产生500次随机事件,作用在系统中所有activity(其实也不是所有的activity,而是包含
Intent.CATEGORY_LAUNCHER 或Intent.CATEGORY_MONKEY 的activity)。
options选项(常用选项、事件选项、约束选项、调试选项)
1.常用选项
-
-help:打印帮助信息
-
-v:制定打印信息的详细级别,一个 -v增加一个级别,默认级别为0
2.事件选项
- -s:指定产生随机事件种子值,相同的种子值产生相同的事件序列。
- -throttle:每个事件结束后的间隔时间——降低系统的压力(如不指定系统会尽快的发送事件序列)
- –pct-touch:指定触摸事件的百分比
- –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 (任意事件)
3.约束选项
- -p:指定有效的package(如不指定,则对系统中所有的package有效)一个-p对应一个有效package 如:-p com.ckt -p com.ckt.asura;
- -c:activity 必须至少包含一个指定的category,才能被启动,否则启动不了;
4.调试选项
- –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.junit -s 500 -v 10000
但是,工作中为了保证测试数量的完整进行,我们一般不会在发生错误时立刻退出压力测试 -
adb shell monkey -p com.xy.android.junit -s 500 --ignore-crashes
–ignore-timeouts --monitor-native-crashes -v -v 10000 > E:\monkey_log\java_monkey_log.txt
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文件
打开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