一、monkey介绍;
1、 monkey是什么?
Monkey就是SDK中附带的一个工具。
2、 monkey测试的目的?
该工具用于进行压力测试,然后开发人员结合monkey打印的日志和系统打印的日志,解决测试中出现的问题。
3、 monkey测试简介;
monkey测试是android平台自动化测试的一种手段,通过monkey程序模拟用户触摸屏幕、滑动Trackball、按键等操作来多设备上的程序进行压力测试,检测程序多久的时间会发生异常。
Monkey 命令可简单分为如下四类:
基本配置选项,如设置尝试的事件数量
运行约束选项,如设置只对单独的一个包进行测试
事件类型和频率,如设置触摸屏事件的发生频率
调试选项,如设置忽略应用程序异常,继续向系统发送事件,直到计数完成
二、环境配置;
1、 先安装JDK1.6以上版本。
根据自己电脑系统选择相应的JDK安装版本,安装比较简单我就不说了,直接环境变量配置。
1.1、JDK安装成功后 计算机右键“属性”-“高级系统配置“-“环境变量”
新建 输入变量名:classpath 变量值输入”c:program filesjavajdk1.6.0jrelib”,根据个人安装路径填写,比如我的安装在F盘
现在进行“path”的配置,同上在“classpath”设定时类似,变量名输入:path 变量值输入:”c:program filesjavajdk1.6.0in” 确定。
JDK环境已经配置完成,可以通过打开命令提示窗口,输入命令“java –version”看到java版本的信息,来确定安装是否成功。首先点击“开始”或者快捷键 进行运行
然后出现如图所示界面,输入“cmd ”按“Enter”键。
这个时候进入了dos命令提示窗口,这个时候输入“java –version”java后面有空格。
JDK版本信息全部显示出来,也就表示JDK已安装和配置完成。
2、 Eclipse+sdk的安装和配置:
安装:解压即可 有SDK和Eclipse是配置好的无序配置
把压缩文件解压到指定目录,然后我的电脑“属性”打开点击“高级系统配置”如图
跳转到高级页面 点击“环境变量”如图
在系统变量中找到Path 选择path点击下面的“编辑”
在变量值里输入android SDK中platform-tool的目录路径作为全局变量。
配置完成 检测是否配置完成 点击运行
然后出现如图所示界面,输入“cmd ”按“Enter”键。
这个时候进入了dos命令提示窗口,输入adb 出现如图就成功了。
Monkey的环境到此已准备完成。
三、monkey命令详解。
1、 如果没有配置sdk的全局变量;
点击“运行”输入“cmd” 进入dos命令窗口页面,要先进入到SDK中的platform-too目录下 另外手机和电脑数据线连接正常 如图
接下来输入 adb shell 回车
输入:monkey [options] <event –count> 命令
比如:我的app包名是:com.epsoft.jobhunting.quick 要测试
输入:monkey –p com.epsoft.jobhunting.quick 50000 就可以了看程序在随机50000次事件中,能不能正常运行下去。
如果有错误后台有log可以随时查看。
另外为了查看运行的log 可以输入这样的命令:
Monkey –p com.epsoft.jobhunting.quick 50000 > monkey50000.txt 将输出结果放到一个文本里面方便查看。
四、Monkey命令参数介绍
1) 参数: -p
参数-p用于约束限制,用此参数指定一个或多个包(Package,即App)。指定
包之后,Monkey将只允许系统启动指定的APP。如果不指定包,Monkey将允许系统启动设备中的所有APP。
* 指定一个包: adb shell monkey -p com.htc.Weather 100
说明:com.htc.Weather为包名,100是事件计数(即让Monkey程序模拟100次随机用户事件)。
* 指定多个包:adb shell monkey -p com.htc.Weather –p com.htc.pdfreader -p com.htc.photo.widgets 100
* 不指定包:adb shell monkey 100
说明:Monkey随机启动APP并发送100个随机事件。
* 要查看设备中所有的包,在CMD窗口中执行以下命令:
>adb shell
#cd data/data
#ls
2) 参数: -v
用于指定反馈信息级别(信息级别就是日志的详细程度),总共分3个级别,分别对应的参数如下表所示:
日志级别 Level 0
示例 adb shell monkey -p com.htc.Weather –v 100
说明 缺省值,仅提供启动提示、测试完成和最终结果等少量信息
日志级别 Level 1
示例 adb shell monkey -p com.htc.Weather –v -v 100
说明 提供较为详细的日志,包括每个发送到Activity的事件信息
日志级别 Level 2
示例 adb shell monkey -p com.htc.Weather –v -v –v 100
说明 最详细的日志,包括了测试中选中/未选中的Activity信息
3)参数: -s
用于指定伪随机数生成器的seed值,如果seed相同,则两次Monkey测试所产生的事件序列也相同的。
* 示例:
Monkey测试1:adb shell monkey -p com.htc.Weather –s 10 100
Monkey 测试2:adb shell monkey -p com.htc.Weather –s 10 100
两次测试的效果是相同的,因为模拟的用户操作序列(每次操作按照一定的先后顺序所组成的一系列操作,即一个序列)是一样的。操作序
列虽 然是随机生成的,但是只要我们指定了相同的Seed值,就可以保证两次测试产生的随机操作序列是完全相同的,所以这个操作序列伪随
机的;
4) 参数: --throttle <毫秒>
用于指定用户操作(即事件)间的时延,单位是毫秒;
* 示例:adb shell monkey -p com.htc.Weather –throttle 3000 100
5) 参数: --ignore-crashes
用于指定当应用程序崩溃时(Force & Close错误),Monkey是否停止运行。如果使用此参数,即使应用程序崩溃,Monkey依然会发送事件,直到事件计数完成。
* 示例1:adb shell monkey -p com.htc.Weather --ignore-crashes 1000
测试过程中即使Weather程序崩溃,Monkey依然会继续发送事件直到事件数目达到1000为止;
* 示例2:adb shell monkey -p com.htc.Weather 1000
测试过程中,如果Weather程序崩溃,Monkey将会停止运行。
6) 参数: --ignore-timeouts
用于指定当应用程序发生ANR(Application No Responding)错误时,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事件,它发生在屏幕上的某单一位置)
adb shell monkey -p com.htc.Weather --pct-touch 10 1000
--pct-motion {+百分比}
调整动作事件的百分比(动作事件由屏幕上某处的一个down事件、一系列的伪随机事件和一个up事件组成)adb shell monkey -p
com.htc.Weather --pct-motion 20 1000
--pct-trackball {+百分比}
调整轨迹事件的百分比(轨迹事件由一个或几个随机的移动组成,有时还伴随有点击)
adb shell monkey -p com.htc.Weather --pct-trackball 30 1000
--pct-nav {+百分比}
调整“基本”导航事件的百分比(导航事件由来自方向输入设备的up/down/left/right组成)
adb shell monkey -p com.htc.Weather --pct-nav 40 1000
--pct-majornav {+百分比}
调整“主要”导航事件的百分比(这些导航事件通常引发图形界面中的动作,如:5-way键盘的中间按键、回退按键、菜单按键)
adb shell monkey -p com.htc.Weather --pct-majornav 50 1000
--pct-syskeys {+百分比}
调整“系统”按键事件的百分比(这些按键通常被保留,由系统使用,如Home、Back、Start Call、End Call及音量控制键)
adb shell monkey -p com.htc.Weather --pct-syskeys 60 1000
--pct-appswitch {+百分比}
调整启动Activity的百分比。在随机间隔里,Monkey将执行一个startActivity()调用,作为最大程度覆盖包中全部Activity的一种方法
adb shell monkey -p com.htc.Weather --pct-appswitch 70 1000
--pct-anyevent {+百分比}
调整其它类型事件的百分比。它包罗了所有其它类型的事件,如:按键、其它不常用的设备按钮、等等
adb shell monkey -p com.htc.Weather
--pct -anyevent 100 1000* 指定多个类型事件的百分比:
adb shell monkey -p com.htc.Weather --pct-anyevent 50 --pct-appswitch 50 1000
注意:各事件类型的百分比总数不能超过100%;
六、Monkey命令模板代码:
直接输入adb命令:
adb shell monkey -p com.cmri.ercs -s 3156 --ignore-crashes --ignore-timeouts --ignore-security-exceptions --monitor-native-crashes --ignore-native-crashes --hprof --pct-touch 18 --pct-anyevent 0 --pct-motion 18 --pct-trackball 18 --pct-majornav 10 --pct-nav 0 --pct-syskeys 18 --pct-flip 0 --pct-pinchzoom 0 --pct-appswitch 18 -v -v -v --throttle 800 250000 > D:/MonkeyLog/monkey_test.log
命令停止:adb reboot
七、Monkey日志分析:
Null指针异常:空指针异常主要是有NullPointerException异常提示
debug异常:出现的是IllegalStateException异常
低内存异常:出现的是OutOfMemoryError异常
操作无响应异常:TimerOut(KeyDispatchingTimedOut提示)
RuntimeException异常(操作无响应或应用的服务无法启动或连接)
StaleDataException/readException异常(android数据库出现异常)
IllegalArgumentException异常(向函数传递了一个不正确或不合法的参数)
关键词:ANR、Exception、Null、Error、crash(Fatal)