Monkey介绍
通过Monkey程序模拟用户触摸屏幕,滑动Trackball,按键等操作来对设备上的程序进行压力测试,检测程序错就的时间会发生异常
Monkey用来做什么
Monkey主要用于Android的压力测试,自动的一个压力测试小工具,主要目的就是为了测试app是否会Crash(崩溃)
Monkey程序介绍
(1) Monkey程序由Android系统自带,使用Java语言写成,在Android文件系统中的存放路径是: /system/framework/monkey.jar
(2) Monkey.jar程序是由一个名为“monkey”的Shell脚本来启动执行,shell脚本在Android文件系统中 的存放路径是:/system/bin/monkey
(3)Monkey 命令启动方式:
可以通过PC机CMD窗口中执行: adb shell monkey {+命令参数}来进行Monkey测试
在PC上adb shell 进入Android系统,通过执行 monkey {+命令参数} 来进行Monkey 测试
在Android机或者模拟器上直接执行monkey 命令,可以在Android机上安装Android终端模拟器
Monkey命令
1)执行monkey测试设备中所有app100次
adb shell monkey 100
2)执行monkey测试设备中所有app1000次输出到33.txt
adb shell monkey 1000 >D:\log\33.txt
3)执行monkey测试指定app
adb shell monkey -p 包名 测试次数
例如:
执行monkey测试应用百度10000次
adb shell monkey -p com.baidu.searchbox 10000
4)显示日志详细程度
日志仅提供启动提示,测试完成和最终结果的少量信息
adb shell monkey -p com.baidu.searchbox 1000 -v
日志较为详细,包括每个发送到Activity的事件信息
adb shell monkey -p com.baidu.searchbox 1000 -v -v
最详细的日志,包括测试中选中/未选中的Activity信息
adb shell monkey -p com.baidu.searchbox 1000 -v -v -v
5)将log信息输出到文档中
adb shell monkey -p com.baidu.searchbox 10000 -v-v-v >D:\log\888.txt
6)
忽略崩溃:–ignore-crashes
应用发生崩溃或异常时Monkey会停止运行
设置–ignore(忽略)-crashes(崩溃)将忽略崩溃或异常继续发送事件给系统,直到事件计数完成
执行monkey测试10000次忽略异常输出到44.txt
adb shell monkey --ignore-crashes 10000 >D:\log\44.txt
7)
忽略超时:–ignore-timeouts
应用程序发生任何超时错误(如:Application Not responding)Monkey会停止运行
设置 --ignore-timeouts(超时)忽略超时错误将继续发送事件给系统,直到事件计数完成
adb shell monkey --ignore-timeouts 1000 >D:\log\7979.txt
8)
随机数:-s
https://blog.csdn.net/u011436666/article/details/53998332[Monkey随机数种子事件]
随机数种子,用于指定伪随机数生成器的seed值,如果seed相同,则两次Monkey测试所产生的事件序列也相同的(经常用到bug的复现上)
adb shell monkey -s 26 -v 200 >D:\log\123.txt
adb shell monkey -v -s 26 200 >D:\log\456.txt
9)
时延:–throttle(毫秒)
用于指定操作事件间的时延,单位是毫秒,如果不指定这个参数,monkey会尽可能快的生成和发送消息
adb shell monkey -p com.baidu.searchbox --throttle 300 -v 100在这里插入图片描述
10)
触摸事件: --pct-touch 占比数
调整触摸事件百分比(触摸事件是指在屏幕中的一个down-up事件,即在屏幕某处按下并抬起的操作)
执行10个伪随机用户事件流,并调整其中触摸事件的百分比为80%
adb shell monkey --pct-touch 80 -v 100 >D:\log\11.txt
11)
手势事件: --pct-motion 占比数
调整motion事件百分比(motion事件是由屏幕上某处一个down事件、一系列伪随机的移动事件和一个up事件组成)
adb shell monkey --pct-motion 70 -v 100 >D:\log\99.txt
0:–pct-touch//touch
events percentage触摸事件百分比(触摸事件是一个在屏幕单一位置的按下-抬起事件)
1:–pct-motion//motion
events percentage手势事件百分比(手势事件是由一个在屏幕某处的按下事件、一系列的伪随机移动、一个抬起事件组成)即一个滑动操作,但是是直线的,不能拐弯
2:–pct-pinchzoom//pinch
zoom events percentage二指缩放百分比,即智能机上的放大缩小手势操作
3:–pct-trackball//trackball 即单纯的Move(ACTION_MOVE)
events percentage轨迹球事件百分比(轨迹球事件包括一个或多个随机移动,有时还伴有点击。轨迹球现在智能手机上已经没有了,就是类似手柄的方向键一样)
4:–pct-rotation//screen
rotation events percentage屏幕旋转百分比,横屏竖屏
5:–pct-nav//nav
基本导航事件。即来自于方向输入设备的上下左右操作。
events percentage”基本”导航事件百分比(导航事件包括上下左右,如方向输入设备的输入)老手机的上下左右键,智能机上没有
6:–pct-majornav//major
即Navigation Bar的确认,菜单,返回键等
nav events percentage”主要”导航事件百分比(这些导航事件通常会引发UI的事件,例如5-way pad的中间键、回退键、菜单键)
7:–pct-syskeys//system(key)
operations percentage”系统”按钮事件百分比(这些按钮一般专供系统使用,如Home, Back, Start Call, End Call,音量控制)
8:–pct-appswitch//app
switch events percentage启动activity事件百分比。在随机的间隔里,Monkey会执行一个startActivity()调用,作为最大程度覆盖包中全部Activity的一种方法
9:–pct-flip//keyboard
flip percentage键盘轻弹百分比,如点击输入框,键盘弹起,点击输入框以外区域,键盘收回
10:–pct-anyevent//anyevents
该事件可能包含其他上述事件。
percentage其他类型事件百分比。包括了其他所有的类型事件,如按键、其他不常用的设备上的按钮等等。
monkey -p com.baidu.searchbox -s 23 --throttle2000 --ignore-crashes --ignore-timeouts -v -v -v 100000>D:/log/log.txt 2>&1 &
-p后面接着的对应的包名,如果是整机测试,就不需要 -p 包名
-s后面是对应的种子数,一般种子数在23,同步测试的结果,一般种子的个数固定为23,和选择的操作步骤就是同步的。
–ignore-crashes --ignore-timeouts 这里是在monkey测试的过程中遇到carash(崩溃)或者timeout(超时)的情况时忽略掉,一般不设置时,出现carash或者timeout时,Monkey测试会终止。这里是防止Monkey测试终止。
-v 指的是Monkey测试时打印log级别。
100000 这里是指点击的次数,对于单个应用程序这个次数设置在100000次就可以了;如果是整机,一般设置在500000次.D:/log/log.txt测试的log记录在手机上D:/log/下面的log.txt里面。
2>&1 固定的写法,代表的意思是中间忽略的东西的日志一并输入到指定的文件中。
最后单独的一个"&" 是一旦Monkey测试开始了,之后可以拔掉数据线,不会影响Monkey测试。
测试所有模块 monkey -s 23 --ignore-crashes --ignore-timeouts -v-v -v 100000> /data/local/tmp/log.txt 2>&1 &
测试所有模块忽略崩溃,超时,设置时延200毫秒,23的伪随机数种子 最详细的log日志 测试运行10000次,最后将日志输出到test.txt文件 中,中间忽略的东西也一并输入到指定的文件中,可以拔掉数据线,不会影响Monkey测试
adb shell monkey --ignore-crashes --ignore-timeouts --throttle 200 -s 23 -v-v-v 10000 >D:/log/test.txt 2>&1