简介
Monkey是Android SDK提供的一个命令行工具,可以简单方便的发送伪随机的用户事件流,对Android APP做压力(稳定性)测试。主要是为了测试app是否存在无响应和崩溃的情况。
monkey命令
adb shell monkey -p com.xiwang.zaixian -s 12345 -v -v -v --throttle 300 --pct-touch 60 --pct-motion 38 --pct -rotation 1--pct -pinchzoom 1 --bugreport 100000
以上参数说明:
基础参数:-v 、-s 、-p 、--throttle等
调试选项:--ignore-crashes等
事件类型:--pct-touch等
(一)基础参数
1、最简单的monkey命令(adb shell monkey 100)
表示:在设备上,针对整个系统发送100个伪随机事件。
2、-v参数
用于指定反馈信息级别(信息级别就是日志的详细程度)总共分为3级,默认为-v(对应:level0)
-v:只提供启动提示、测试完成提示和最终结果等少量信息。
-v -v:较为详细的日志,包括每个发送到activity的时间信息。
-v -v -v:最详细的日志,包括测试中选中/未选中的activity信息。
注意:在monkey测试完成时,最后一定会有一个:monkey finished标识。
3、-p参数
在我们测试时,是针对具体的app进行测试的,所以在使用monkey测试时,我们需要提供具体的app包名给monkey,此时就需要用到参数-p。在-p后跟随app包名。
在测试时,可以不指定包名,此时monkey会在测试设备上随机启动app进行操作;如果只需要测试一个app,使用一个-p即可;如果有多个app同时测试,可以直接使用-p 包名1 -p 包名2指定具体要测试的app。
4、-s参数
种子值(seed),因为monkey是发送的是伪随机的事件流,但是如果两次seed值相同,那两次monkey测试所产生的事件序列也相同。(所以一般在测试时要记录seed值,以防出现无响应和crash,不容易验证。)-s 12345伪随机事件12345(12345是随便起的名字,也可以叫456,命名的好处是:如果发现了崩溃,开发解决之后,再以这个seed进行跑,步骤是和之前一样的)
注意:-s需要跟在包名后,次数前
5、--throttle参数
设置执行操作的延迟时间(毫秒)--是指两个事件之间的间隔,如果没有指定此参数,会尽可能快的生成和发送事件。注:实际用户操作的最快300毫秒左右一个动作事件
(二)调试选项
1、--ignore-crashes
用于指定当应用程序崩溃时,Monkey是否停止运行。如果使用此参数,即使应用程序崩溃,monkey依然会发送事件,直到事件计数完成。
2、---ignore-timeouts
用于指定当应用程序发生ANR(Application No Responding)错误时,Monkey是否停止运行。如果使用此参数,即使应用程序发生ANR错误,Monkey依然会发送事件,直到事件计数完成。
3、--ignore-security-exceptionss
用于指定当应用程序发生许可错误时(如证书许可,网络许可等),Monkey是否停止运行。如果使用此参数,即使应用程序发生许可错误,Monkey依然会发送事件,直到事件计数完成。
4、--kill-process-after-error
用于指定当应用程序发生错误时,是否停止其运行。如果指定此参数,当应用程序发生错误时,应用程序停止运行并保持在当前状态(注意:应用程序仅是静止在发生错误时的状态,系统并不会结束该应用程序的进程)。
5、--monitor-native-crashes
用于指定是否监视并报告应用程序发生崩溃的本地代码
6、--hprof
该选项设置后,将会在monkey事件序列前后立刻生成report,大小为大于5MB,存储在/data/misc
(三)事件类型
monkey在发送伪随机事件时,是有不同的类型的。默认随机分配比例,也可以指定其百分比。如果不设置会是--pct-anyevent为100%,也就是纯随机事件;如果配置了其他参数,但是不够100%,余下的百分比部分也是--pct-anyevent事件。
具体事件类型分别为:
1:触摸事件--pct-touch
调整touch触屏事件的百分比,触碰事件就是指在屏幕上的一个单独位置的一次点击/抬起的事件。
2:滑屏事件--pct-motion(手势事件)
(手势事件是由一个在屏幕某处的按下事件、一系列的伪随机移动、一个抬起事件组成)即一个滑动操作,但是是直线的,不能拐弯)
3:轨迹球--pct-trackball
(轨迹球事件包括一个或多个随机移动,有时还伴有点击。轨迹球现在智能手机上已经没有了,就是类似手柄的方向键一样)
4:旋转(--pct-rotation)
旋转屏幕
5:二指缩放事件(--pct-pinchzoom)
二指缩放事件是指在屏幕上的两处同时按下,并同时移动,最后同时抬起的操作,即智能机上的放大缩小手势操作。
6:导航--pct-nav
(导航事件包括上下左右,如方向输入设备的输入)老手机的上下左右键,智能机上没有)
7:主导航--pct-majornav
调整主要导航事件的百分比(如中间键、取消、确定或菜单引发的图形接口的动作)
8:系统按键--pct-syskeys
调整系统按键事件,如:home/back/startcall/endcall以及音量控制键等
9:app切换--pct-appswitch
调整启动activity的百分比,在随机间隔中,执行一个startActivity()方法调用,作为一种最大化的覆盖安装包的所有的activity的方法
10:键盘翻转(--pct-flip)
11:随机--pct-anyevent
调整其他类型的事件的百分比,比如按键或其他不太常用到的一些事件的百分比
12:bugreport {次数} 事件的次数
还有其他参数设置:需要可以搜索
monkey测试步骤+注意事项
- 连接WiFi,不连接代理,保证使用真实的线上返回
- 去掉SIM卡,以免断开WiFi的时候,使用过多流量
- 打开cmd,输入以上命令,保持cmd窗口不关闭,如遇到崩溃,cmd上的输出就会停止,把崩溃保存下来提交给开发,本地如果有崩溃日志保存,保存出现崩溃的界面,提交给开发
- 有的手机在跑monkey的时候,中间会和PC断开连接,重启手机或者使用ps命令找到monkey的进程号之后,kill掉该进程号,则能停止monkey
- 关闭锁屏及屏幕保护
- 需要开启手机开发者选项中的允许模拟位置
- 调整手机时区是中国时区(有的手机可能跑monkey或者人为使时区调整成非中国的,因为有的地方开发代码没有做异常处理)
- monkey避免wifi关闭,使用禁用系统通知栏,但是需要是root手机才行,参考链接: http://www.cnblogs.com/bravesnail/p/4819659.html
- 前提:需要先手机先root,获取到root权限,此方法可以隐藏状态栏
全屏状态 adb shell settings put global policy_control immersive.full=*
恢复:adb shell settings put global policy_control null
- 至于音量键可以在执行adb命令时候--pct-syskeys 0屏蔽掉
例如 adb shell monkey -p XXXX --pct-syskeys 0 1000
一些说明
- 想要monkey运行24小时,每100毫秒发送一个事件。246060*1000/100=864000(次)
adb shell monkey -p *** -v -v -v --ignore-crashes --ignore-timeoutss --throttle 100 864000 >D:\monkey.log
表示:此次monkey将会运行24小时
存在的问题
monkey无法指定页面,经常会点到外部的 App 无法回归原测试 App;或者点击到注销和退出,造成无法继续后面的测试;
有人Demons(守护程序)是自主研发的一套独立的手机应用监听的守护程序。主要作用是控制对指定页面进行Monkey测试。,待调研https://blog.csdn.net/liyu520131414/article/details/69357777
fastbot工具可指定activity白名单进行测试(待具体调研)
参考文档
Maxim 也是一款自动遍历工具,由国内的 zhangzhao 同学开发,官方给出的定义是:
An efficient Android Monkey Tester, available for emulators and real devices 基于遍历规则的高性能 Android Monkey,适用于真机/模拟器的 APP UI 压力测试。
我们来看看这款工具的优缺点:
优点:
- 基于Monkey二次开发,运行速度非常快
- 提供了多种遍历算法以提高覆盖度
- 提供了定制化功能,可以实现流程控制
缺点:
- 因为是基于 Monkey,所以不具备跨平台性,只能测试 Android,不能测试 iOS,Web 等;
这是一款很优秀的工具,可在一定程度上进行定制,如果只测试 Android 系统的话,可以考虑选用 Maxim 做稳定性测试。