Monkey介绍
Monkey就是猴子,Monkey测试,就像一只猴子,在电脑面前,乱敲键盘测试。。
Monkey程序模拟用户触摸屏幕,滑动Trackball、按键等操作来对设备上的程序进行压力测试,检测程序多久的时间会发生异常
Monkey用来做什么
主要用于Android的稳定性测试,自动的一个压力测试小工具,主要目的就是为了测试App,是否会Crash(崩溃)
Monkey程序介绍
Monkey程序由Android系统自带,使用java语言写成,在Android文件系统中存放路径是:/system/framework/monkey.jar
Monkey.jar程序是由一个名为“monkey”的shell脚本来启动执行,shell脚本在Android文件系统中的存放路径是:/system/bin/monkey
Monkey命令启动方式:
1.可以通过cmd窗口中执行:adb shell monkey {+命令参数} 来进行Monkey测试
2.在PC上adb shell 进入Android系统,通过执行monkey {+命令参数} 来进行Monkey测试
3.在Android机或者模拟器上直接执行monkey命令,可以在Android机上安装Android终端模拟器
Monkey命令
使用Monkey测试手机所有程序
adb shell monkey 100
-p <允许的包名列表>
adb shell monkey -p 包名 100
用此参数指定一个或者多个包,指定包之后,monkey将只允许系统启动指定的APP,如果不指定包,monkey将允许系统启动设备中的所有APP
显示日志详细程度
用于指定反馈信息级别(信息级别就是日志的详细程度),总共分三个级别,分别对应的参数如下,
1.adb shell monkey -p 包名 -v 30 //缺省值,仅提供启动提示,测试完成和最终结果等少量信息
2. adb shell monkey -p 包名 -v -v 30 //较为详细
3. adb shell monkey -p 包名 -v -v -v 30 //最详细日志
将日志信息发送到本地
adb shell monkey -p 包名 -v 30 >D:\2.log
正常情况下,如果monkey顺利执行,在log的最后会打印执行时间的次数和所花费的时间
//Monkey finished 代表执行完成
** -s 随机数种子**
用于指定伪随机数生成器的seed值,如果seed值相同,则两次Monkey测试所产生的时间序列也相同。
adb shell monkey -s 10 100
** -throttle <毫秒>**
用于指定用户操作间的时延,单位是毫秒,如果不指定这个参数,Monkey会尽可能快的生成和发送消息
adb shell monkey -p com.baidu.searchbox --throttle 300 100
表示执行100个伪随机用户事件流,事件间隔为300毫秒
注:一般设置为300毫秒,原因是实际用户操作的最快300毫秒左右一个动作事件
**–pct-touch < percent > 触摸事件 **
调整触摸事件的百分比。(触摸事件是指在屏幕中的一个down-up事件,即在屏幕某处按下并抬起的操作)
‘-’-'pct-touch :触摸事件。即在某一位置的Down-Up(手指的放下和抬起)事件,
如:adb shell monkey - -pct-touch 67 -v 10
表示执行10个伪随机用户时间流,并调整其中触摸事件的百分比为67%
注:此参数设置要适应当前被测应用程序的操作,比如一个应用80%的操作都是触摸,那就可以将此参数的百分比设置成相应较高的百分比
–pct-motion
调整手势事件motion事件百分比
–pct-motion:动作事件。以Down(ACTION_DOWN)开始,Up(ACTION_UP)结尾,中间至少有一次Move(ACTION_MOVE)。
如:adb shell monkey --pct-motion 67 -v 10
表示执行10个伪随机用户事件流,并调整其中动作事件的百分比为67%。
注:这里的移动是直线滑动
–ignore-crashes
作用:通常,应用发生崩溃或异常时Monkey会停止运行。如果设置此项,Monkey将继续发送事件给系统,直到事件计数完成
–ignore-timeouts(ANR)
作用:通常,应用程序发生任何超时错误(如“Application Not responding”对话框)Monkey将停止运行,设置此项,Monkey将继续发送事件给系统,直到事件计数完成。
adb shell monkey --ignore-timeouts –v 10
Monkey实例
用monkey 命令 对登录apk进行 性能测试
monkey -p 包名 -s 23 --throttle 2000 --ignore-crashes --ignore-timeouts -v -v -v 100000>/data/local/tmp/log.txt
1. -p后面接着的对应的包名,对具体某个app测试
2. -s后面是对应的种子数,好像就是操作步骤,一般设置相同的种子数目的是复现bug
3. --ignore-crashes --ignore-timeouts 这里是在monkey测试的过程中遇到carash或者timeout的情况时忽略掉,一般不设置时,出现carash或者timeout时,Monkey测试会终止。这里是防止Monkey测试终止。
4. -v 指的是Monkey测试时打印log级别。
5. 100000 这里是指点击的次数,根据她们测试的经验,对于单个应用程序这个次数设置在100000次就可以了;如果是真机,一般设置在500000次。
6. --throttle-时间 ,设置事务之间的延迟等待时间,单位是毫秒
7.>路径,设置日志存储路径
Monkey异常分析
一般我们可以一次发送5万次随机事件的请求,每个请求之间的间隔为150毫秒,测试大约会进行40min,完成以后就可以查看日志。
日志中可能的错误:
1.程序奔溃,crash (ctrl+f搜索)
2.程序无响应,ApplicationNo Response(ctrl+f搜索‘ANR ’,加空格是为了屏蔽掉一些无效信息)
3.其他问题:在日志中搜索”Exception”。
Monkey 执行中断, 在log最后也能看到当前执行次数