APP性能测试之monkey

1 monkey 是做什么的 

monkey 是 Android 中的一个命令行工具,由 java 编写,可以运行在模拟器里或实 际设备中。 
它向系统发送伪随机的用户事件流(如按键输入、触摸屏输入、手势输入等),实现 对 APP 进行压力测试。

monkey 测试是一种为了测试软件的稳定性、健壮性的快速有效的方法。 

安装好SDK和avd模拟器,就直接可以允许monkey命令

monkey工具能测试ios app测试monkey命令_android

2 monkey 的优劣 

优势

脱离 Case 的依赖 
可封装自动化执行 
可封装后作为客户端性能测试的驱动 

缺陷

完全随机,不可控 

3 monkey 命令 

adb shell monkey -p 包名 1 -p 包名 2 … 事件数  

-p
如果用此参数指定了一个或几个包,monkey 将只允许系统启动这些包里 的 Activity。
如果你的应用程序还需要访问其它包里的 Activity,那些包也 需要在此同时指定。
如果不指定任何包,monkey 将允许系统启动全部包
里的 Activity。

要指定多个包,需要使用多个 -p 选项,每个-p 选项只能 用于一个包。 

-v
指定打印信息的详细级别,一个 -v 增加一个级别。 
日志级别 Level 0,缺省值,仅提供启动提示、测试完成和最终结果等少 量信息,-v; 
日志级别 Level 1,提供较为详细的日志,包括每个发送到 Activity 的事 件信息,-v -v; 
日志级别 Level 2,最详细的日志,包括了测试中选中/未选中的 Activity 信息,-v -v -v。 

adb shell monkey -p welab.bank.mobile.stage -v -v -v 100

将log保存至本地文件:adb shell monkey -p welab.bank.mobile.stage -v -v -v 500 > D:/monkey.txt

测试结果如下图所示,显示了一些参数

monkey工具能测试ios app测试monkey命令_Android_02

显示事件的百分比

monkey工具能测试ios app测试monkey命令_Monkey_03

操作了哪100个事件

monkey工具能测试ios app测试monkey命令_monkey工具能测试ios_04

花费时间,总共事件统计,网络连接状态,Monkey finished

monkey工具能测试ios app测试monkey命令_压力测试_05

4 monkey 结果分析 

adb shell monkey -p –v -v –v > log.txt  可以将结果存储起来 

正常情况,如果 monkey 测试顺利执行完成,在 log 最后,会打印出当前执行事件 的次数和所花费的时间 

Monkey finished 

打开 LOG,查看 log 的最下端,是否有类似以下字段: 
Network stats: elapsed time=5123ms (5123ms mobile, 0ms wifi, 0ms not connected) 
Monkey finished  这个字段表明本次的 Monkey 没有异常,测试通过。 

CRASH 

如果搜索到有结果,则表明有进程出现问题,测试不通过。 
CRASH: com.onekchi.downloadmanager (pid 12919) 

ANR 

如果有搜索结果,则表示测试过程中,测试对象出现了无响应的现象,因 此测试不通过

一、Monkey介绍
顾名思义,Monkey就是猴子,  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 命令启动方式:    
a、可以通过PC机CMD窗口中执行: adb shell monkey {+命令参数}来进行Monkey测试          
b、在PC上adb shell 进入Android系统,通过执行 monkey {+命令参数} 来进行Monkey 测试          
c、在Android机或者模拟器上直接执行monkey 命令,可以在Android机上安装Android终端模拟器

四、Monkey 命令 基本参数介绍
1、使用monkey测试手机所有程序
命令:adb shell monkey 100(执行100次)

2、 -p <允许的包名列表>
命令:
获取手机中所有的第三方包名:adb shell pm list packages -3
执行该包名:adb shell monkey -p com.kmxs.reader 1000

3、 显示日志详细程度
命令:adb shell monkey -p com.kmxs.reader -v 30        // 缺省值,仅提供启动提示、测试完成和最终结果等少量信息
命令:adb shell monkey -p com.kmxs.reader -v -v 30        // 提供较为详细的日志,包括每个发送到Activity的事件信息
命令:adb shell monkey -p com.kmxs.reader -v -v -v 30        // 最详细的日志,包括了测试中选中/未选中的Activity信息

4、Monkey日志分析
命令:adb shell monkey -p com.kmxs.reader -v -v 30 >D:/日志/1.txt
正常情况,  如果Monkey测试顺利执行完成, 在log的最后, 会打印出当前执行事件的次数和所花费的时间; // Monkey finished 代表执行完成\

5、-s 随机数种子
命令:adb shell monkey -s 10 100
用亍指定伪随机数生成器的seed值,如果seed相同,则两次Monkey测试所产生的事件序列也相同的

6、--throttle <毫秒>
命令:adb shell monkey -p com.kmxs.reader --throttle 300 100

7、--pct-touch 触摸事件 和  --pct-motion 手势事件
命令:adb shell monkey -v --pct-touch 70 20
调整触摸事件的百分比。(触摸事件是指在屏幕中的一个down-up事件,即在屏幕某处按下并抬起的操作)
–pct-touch:触摸事件。即在某一位置的Down-Up(手指的放下和抬起)事件。Down(ACTION_DOWN)和Up(ACTION_UP)的坐标临近,但并非相同
如:adb shell monkey --pct-touch 67 -v 10
表示执行10个伪随机用户事件流,并调整其中触摸事件的百分比为67%。
注:此参数设置要适应当前被测应用程序的操作,比如一个应用80%的操作都是触摸,那就可以将此参数的百分比设置成相应较高的百分比
命令:adb shell monkey --pct-motion 67 -v 10
调整手势事件motion事件百分比。(motion事件是由屏幕上某处一个down事件、一系列伪随机的移动事件和一个up事件组成)
–pct-motion:动作事件。以Down(ACTION_DOWN)开始,Up(ACTION_UP)结尾,中间至少有一次Move(ACTION_MOVE)
如:adb shell monkey --pct-motion 67 -v 10
表示执行10个伪随机用户事件流,并调整其中动作事件的百分比为67%。
注:这里的移动是直线滑动

Event percentages:
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其他类型事件百分比。包括了其他所有的类型事件,如按键、其他不常用的设备上的按钮等等

8、 --ignore-crashes

正常操作,不忽略异常
命令:adb shell monkey -p com.kmxs.reader 100 >D:/日志/2.txt

忽略异常
命令:adb shell monkey -p com.kmxs.reader --ignore-crashes 1000 >D:\日志\4.txt

9、 --ignore-timeouts(ANR)
命令:adb shell monkey --ignore-timeouts –v 10

10、Monkey 实例
命令:adb shell monkey -p com.kmxs.reader -s 23  --throttle 2000 --ignore-crashes --ignore-timeouts -v -v -v 10000 >D:/日志/log.txt

11、Monkey异常分析
一般我们可以一次发送5万次随机事件的请求,每个请求之间的间隔为150毫秒,测试大约会进行40min,完成以后就可以查看日志。 

日志中可能的错误:
1.程序奔溃,crash (ctrl+f搜索)
2.程序无响应,ApplicationNo Response(ctrl+f搜索‘ANR ’,加空格是为了屏蔽掉一些无效信息)
3.其他问题:在日志中搜索”Exception”。
Monkey 执行中断, 在log最后也能看到当前执行次数