如何进行MonkeyTest
目录
一 简介
二测试准备
三 基本命令格式
四 测试Log获取
五Monkey命令参数介绍
六 保存monkey log以及手机log到sdcard(新增)
一、简介
Monkey是Android中的一个命令行工具,可以运行在模拟器里或实际设备中。它向系统发送伪随机的用户事件流(如按键输入、触摸屏输入、手势输入等),实现对正在开发的应用程序进行压力测试。Monkey包括许多选项,它们大致分为四大类:
- 基本配置选项,如设置尝试的事件数量
- 运行约束选项,如设置只对单独的一个包进行测试
- 事件类型和频率
- 调试选项
在Monkey运行的时候,它生成事件,并把它们发给系统。同时,Monkey还对测试中的系统进行监测,对下列三种情况进行特殊处理(自动停止):
- 如果限定了Monkey运行在一个或几个特定的包上,那么它会监测试图转到其它包的操作,并对其进行阻止。
- 如果应用程序崩溃或接收到任何失控异常,Monkey将停止并报错。
- 如果应用程序产生了应用程序不响应(applicationnotresponding)的错误,Monkey将会停止并报错。
按照选定的不同级别的反馈信息,在Monkey中还可以看到其执行过程报告和生成的事件
二、测试准备
Monkeytest前必须先进入android设备的adbshell(AndroidSDK环境配置不在此描述,网上有很多)步骤如下:
1.开始—>运行—>cmd
2.usb连接手机,输入adbshell命令,待出现即可输入以下内容
3.进入手机后,输入相应的monkey命令即可测试
三、基本命令格式
adbshellmonkey–p程序包–v测试次数
比如“adbshellmonkey–pcom.htc.Weather–v20000”意思是对com.htc.Weather这个程序包单独进行一次20000次的monkey测试
其中程序包名称可以在串口终端这句命令获得:lsdata/data显示所有程序包
四、测试Log获取
用Monkeytest测试,为了方便分析问题,可以在命令monkey命令后面加上“|logcat-vtime”,这样就能边测试边打印Log(记得用终端保存Log文本)例如:
adbshellmonkey–pcom.htc.Weather–v20000|logcat-vtime
但是这个组合在monkey测试完成后,logcat仍然在执行,测试时需要注意。
如果测试monkey碰到crash或者anr(程序强制性退出或不响应)现象时,在抓取log的同时需要提供traces.txt,步骤如下:
1.测试版本需要具备root权限
2.进入data/anr目录下面
3.将traces.txt文件拷贝到TF卡中,然后拷贝出来发给软件分析即可
五、Monkey命令参数介绍
1)参数:-p
参数-p用于约束限制,用此参数指定一个或多个包(Package,即App)。指定
包之后,Monkey将只允许系统启动指定的APP。如果不指定包,Monkey将允许系统启动设备中的所有APP。
*指定一个包:adbshellmonkey-pcom.htc.Weather100
说明:com.htc.Weather为包名,100是事件计数(即让Monkey程序模拟100次随机用户事件)。
*指定多个包:adbshellmonkey-pcom.htc.Weather–pcom.htc.pdfreader-pcom.htc.photo.widgets100
*不指定包:adbshellmonkey100
说明:Monkey随机启动APP并发送100个随机事件。
*要查看设备中所有的包,在CMD窗口中执行以下命令:
>adbshell
#cddata/data
#ls
2)参数:-v
用于指定反馈信息级别(信息级别就是日志的详细程度),总共分3个级别,分别对应的参数如下表所示:
日志级别Level0
示例adbshellmonkey-pcom.htc.Weather–v100
说明缺省值,仅提供启动提示、测试完成和最终结果等少量信息
日志级别Level1
示例adbshellmonkey-pcom.htc.Weather–v-v100
说明提供较为详细的日志,包括每个发送到Activity的事件信息
日志级别Level2
示例adbshellmonkey-pcom.htc.Weather–v-v–v100
说明最详细的日志,包括了测试中选中/未选中的Activity信息
3)参数:-s
用于指定伪随机数生成器的seed值,如果seed相同,则两次Monkey测试所产生的事件序列也相同的。
*示例:
Monkey测试1:adbshellmonkey-pcom.htc.Weather–s10100
Monkey测试2:adbshellmonkey-pcom.htc.Weather–s10100
两次测试的效果是相同的,因为模拟的用户操作序列(每次操作按照一定的先后顺序所组成的一系列操作,即一个序列)是一样的。操作序列虽然是随机生成的,但是只要我们指定了相同的Seed值,就可以保证两次测试产生的随机操作序列是完全相同的,所以这个操作序列伪随机的;
4)参数:--throttle<毫秒>
用于指定用户操作(即事件)间的时延,单位是毫秒;
*示例:adbshellmonkey-pcom.htc.Weather–throttle3000100
5)参数:--ignore-crashes
用于指定当应用程序崩溃时(Force&Close错误),Monkey是否停止运行。如果使用此参数,即使应用程序崩溃,Monkey依然会发送事件,直到事件计数完成。
*示例1:adbshellmonkey-pcom.htc.Weather--ignore-crashes1000
测试过程中即使Weather程序崩溃,Monkey依然会继续发送事件直到事件数目达到1000为止;
*示例2:adbshellmonkey-pcom.htc.Weather1000
测试过程中,如果Weather程序崩溃,Monkey将会停止运行。
6)参数:--ignore-timeouts
用于指定当应用程序发生ANR(ApplicationNoResponding)错误时,Monkey是否停止运行。如果使用此参数,即使应用程序发生ANR错误,Monkey依然会发送事件,直到事件计数完成。
7)参数:--ignore-security-exceptions
用于指定当应用程序发生许可错误时(如证书许可,网络许可等),Monkey是否停止运行。如果使用此参数,即使应用程序发生许可错误,Monkey依然会发送事件,直到事件计数完成。
8)参数:--kill-process-after-error
用于指定当应用程序发生错误时,是否停止其运行。如果指定此参数,当应用程序发生错误时,应用程序停止运行并保持在当前状态(注意:应用程序仅是静止在发生错误时的状态,系统并不会结束该应用程序的进程)。
9)参数:--monitor-native-crashes
用于指定是否监视并报告应用程序发生崩溃的本地代码。
10)参数:--pct-{+事件类别}{+事件类别百分比}
用于指定每种类别事件的数目百分比(在Monkey事件序列中,该类事件数目占总事件数目的百分比)
参数:
使用说明:
示例:
--pct-touch{+百分比}
调整触摸事件的百分比(触摸事件是一个down-up事件,它发生在屏幕上的某单一位置)
adbshellmonkey-pcom.htc.Weather--pct-touch101000
--pct-motion{+百分比}
调整动作事件的百分比(动作事件由屏幕上某处的一个down事件、一系列的伪随机事件和一个up事件组成)adbshellmonkey-pcom.htc.Weather--pct-motion201000
--pct-trackball{+百分比}
调整轨迹事件的百分比(轨迹事件由一个或几个随机的移动组成,有时还伴随有点击)
adbshellmonkey-pcom.htc.Weather--pct-trackball301000
--pct-nav{+百分比}
调整“基本”导航事件的百分比(导航事件由来自方向输入设备的up/down/left/right组成)
adbshellmonkey-pcom.htc.Weather--pct-nav401000
--pct-majornav{+百分比}
调整“主要”导航事件的百分比(这些导航事件通常引发图形界面中的动作,如:5-way键盘的中间按键、回退按键、菜单按键)
adbshellmonkey-pcom.htc.Weather--pct-majornav501000
--pct-syskeys{+百分比}
调整“系统”按键事件的百分比(这些按键通常被保留,由系统使用,如Home、Back、StartCall、EndCall及音量控制键)
adbshellmonkey-pcom.htc.Weather--pct-syskeys601000
--pct-appswitch{+百分比}
调整启动Activity的百分比。在随机间隔里,Monkey将执行一个startActivity()调用,作为最大程度覆盖包中全部Activity的一种方法
adbshellmonkey-pcom.htc.Weather--pct-appswitch701000
--pct-anyevent{+百分比}
调整其它类型事件的百分比。它包罗了所有其它类型的事件,如:按键、其它不常用的设备按钮、等等
adbshellmonkey-pcom.htc.Weather
--pct-anyevent1001000*指定多个类型事件的百分比:
adbshellmonkey-pcom.htc.Weather--pct-anyevent50--pct-appswitch501000
注意:各事件类型的百分比总数不能超过100%;
六 保存monkey log以及手机log到sdcard
最近很多同学在问如何保存log到sdcard,下面介绍下如何实现:
一、首先在cmd或终端中输入adb shell
二、再执行monkey,比如
monkey -p com.storm.smart --throttle 500 --ignore-crashes --ignore-timeouts --ignore-security-exceptions --ignore-native-crashes --monitor-native-crashes -v -v -v 100 >/mnt/sdcard/monkey.txt & logcat -v time >/mnt/sdcard/logcat.txt
NOTE:如果不想生成logcat文件,删除红色标记(&logcat -v time >/mnt/sdcard/logcat.txt)中即可