一,Monkey参数详解:
adb shell -help 查看monkey命令参数
-p
指定要进行monkey测试的包,若不指定,将随机选择一个应用测试
-c
指定activity的category类别
-v
指定日志级别
-v : 表示一级
-v-v :表示二级
-v-v-v:表示三级
-s
伪随机的事件seed值,可以通过-s参数复现问题,不指定就会随机生成
--ignore-crashes
忽略异常崩溃
--ignore-timeouts
忽略ANR
--ignore-native-crashes
忽略native层代码的崩溃
--ignore-security-exceptions
忽略一些许可错误,比如证书许可,网络许可
--monitor-native-crashes
是否监视并报告native层发送的崩溃代码
--kill-procress-after-error
用于在发送错误后杀死进程
--hprof
设置后,在Monkey事件序列之前和之后立即生产分析报告,保存于data/mic目录,不过将会生成大量几兆文件,谨慎使用
--throttle
设置每个事件结束后延迟多少时间再继续下一个事件,降低cpu压力;如果不设置,事件与事件之间将不会延迟,事件将会尽快生成;一般设置300ms,因为人最快300ms左右一个动作
--pct-touch
设置触摸事件的百分比,即手指对屏幕进行点击抬起(down-up)的动作
--pct-motion
设置移动事件百分比,这种事件类型是由屏幕上某处的一个down事件-一系列伪随机的移动事件-一个up事件,即点击屏幕,然后直线运动,最后抬起这种运动
--pct-trackball
设置轨迹球事件百分比,这种事件类型是一个或者多个随机移动,包含点击事件,这里可以是曲线运动,不过现在手机很多不支持,这个参数不常用
--pct-syskeys
设置系统物理按键事件百分比,比如home键,音量键,返回键,拨打电话键,挂电话键等
--pct-nav
设置基本的导航按键事件百分比,比如输入设备上的上下左右四个方向键
--pct-appswitch
设置monkey使用startActivity进行activity跳转事件的百分比,保证界面的覆盖情况
--ptc-anyevent
设置其它事件百分比
--ptc-majornav
设置主导航事件的百分比
二、部分参数的具体使用
1) 参数:-p
参数-p用于约束限制,用此参数指定一个或多个包(Package,即App)。指定包之后,Monkey将只允许系 统启动指定的APP。如果不指定包,Monkey将允许系统启动设备中的所有APP。
* 指定一个包:adb shell monkey -p Package 100
说明:com.htc.Weather为包名,100是事件计数(即让Monkey程序模拟100次随机用户事件)。
* 指定多个包:adb shell monkey -p Package1 –p Package2 -p Package3 100
* 不指定包:adb shell monkey 100
说明:Monkey随机启动APP并发送100个随机事件。
* 要查看设备中所有的包,在CMD窗口中执行以下命令:
>adb shell
#cd datahttps://img.qb5200.com/download-x/data
#ls
2) 参数: -v
用于指定反馈信息级别(信息级别就是日志的详细程度),总共分3个级别,分别对应的参数如下表所示:
日志级别 Level 0
示例 adb shell monkey -p Package –v 100
说明 缺省值,仅提供启动提示、测试完成和最终结果等少量信息
日志级别 Level 1
示例 adb shell monkey -p Package –v -v 100
说明 提供较为详细的日志,包括每个发送到Activity的事件信息
日志级别 Level 2
示例 adb shell monkey -p Package –v -v –v 100
说明 最详细的日志,包括了测试中选中/未选中的Activity信息
3)参数: -s
用于指定伪随机数生成器的seed值,如果seed相同,则两次Monkey测试所产生的事件序列也相同的。
* 示例:
Monkey测试1:adb shell monkey -p Package –s 10 100
Monkey 测试2:adb shell monkey -p Package –s 10 100
两次测试的效果是相同的,因为模拟的用户操作序列(每次操作按照一定的先后顺序所组成的一系列操作,即一个序列)是一样的。操作序列虽然是随机生成的,但是只要我们指定了相同的Seed值,就可以保证两次测试产生的随机操作序列是完全相同的,所以这个操作序列伪随机的;
4) 参数: --throttle <毫秒>
用于指定用户操作(即事件)间的时延,单位是毫秒;
* 示例:adb shell monkey -p Package –throttle 3000 100
5) 参数: --ignore-crashes
用于指定当应用程序崩溃时(Force & Close错误),Monkey是否停止运行。如果使用此参数,即使应用程序崩溃,Monkey依然会发送事件,直到事件计数完成。
* 示例1:adb shell monkey -p Package --ignore-crashes 1000
测试过程中即使Weather程序崩溃,Monkey依然会继续发送事件直到事件数目达到1000为止;
* 示例2:adb shell monkey -p Package 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 Package --pct-touch 10 1000
--pct-motion {+百分比}
调整动作事件的百分比(动作事件由屏幕上某处的一个down事件、一系列的伪随机事件和一个up事件组成)
adb shell monkey -p Package --pct-motion 20 1000
--pct-trackball {+百分比}
调整轨迹事件的百分比(轨迹事件由一个或几个随机的移动组成,有时还伴随有点击)
adb shell monkey -p Package --pct-trackball 30 1000
--pct-nav {+百分比}
调整“基本”导航事件的百分比(导航事件由来自方向输入设备的uphttps://img.qb5200.com/download-x/down/left/right组成)
adb shell monkey -p Package --pct-nav 40 1000
--pct-majornav {+百分比}
调整“主要”导航事件的百分比(这些导航事件通常引发图形界面中的动作,如:5-way键盘的中间按键、回退按键、菜单按键)
adb shell monkey -p Package --pct-majornav 50 1000
--pct-syskeys {+百分比}
调整“系统”按键事件的百分比(这些按键通常被保留,由系统使用,如Home、Back、Start Call、End Call及音量控制键)
adb shell monkey -p Package --pct-syskeys 60 1000
--pct-appswitch {+百分比}
调整启动Activity的百分比。在随机间隔里,Monkey将执行一个startActivity()调用,作为最大程度覆盖包中全部Activity的一种方法
adb shell monkey -p Package --pct-appswitch 70 1000
--pct-anyevent {+百分比}
调整其它类型事件的百分比。它包罗了所有其它类型的事件,如:按键、其它不常用的设备按钮、等等
adb shell monkey -p Package
--pct -anyevent 100 1000* 指定多个类型事件的百分比:
adb shell monkey -p Package --pct-anyevent 50 --pct-appswitch 50 1000
注意:各事件类型的百分比总数不能超过100%;
附加:
用Monkey test测试,为了方便分析问题,可以在命令monkey命令后面加上 “|logcat -v time”,这样就能边 测试边打印Log(记得用终端保存Log文本)
例如:
adb shell monkey –p Package –v 20000|logcat -v time
但是这个组合在monkey测试完成后,logcat仍然在执行,测试时需要注意。
或者:adb shell monkey -p Package -v 20000 > log.txt(记得保存新建一个log.txt)
如果测试monkey碰到crash或者anr(程序强制性退出或不响应)现象时,在抓取log的同时需要提供traces.txt,步骤如下:
1. 测试版本需要具备root权限
2. 进入data/anr目录下面
3. 将traces.txt文件拷贝到TF卡中,然后拷贝出来发给软件分析即可
4. adb shell cat https://img.qb5200.com/download-x/data/anr/traces.txt> d:\traces.txt 复制文件到电脑
adb pull https://img.qb5200.com/download-x/data/anr/traces.txt c:\ 复制文件到电脑
备注:提示read-only file system
mount当前挂载情况
mount -o remount -o rw /system重新挂载需要修改权限的目录
三、日志分析
1.初步看日志信息:
seed=20 count=100:随机种子和运行次数
AllowPackage:指定的测试包
Event percentages:操作事件
事件0 为touch事件
事件1 为motion,相当于说从起始点到终点有移动了多少步,就是步骤数量
事件2 为pinchzoom,为两个手指有同时按下去后,都向中间移动后up起来,相当于一个缩放的动作
事件3 为trackball,为轨迹球事件
事件4 为rotation 为屏幕旋转百分比隐藏事件
事件5 为nav导航事件,就是上下左右
事件6 为majornav主导航事件,会产生一些窗口的事件
事件7 为系统按键
事件8,app应用的打开就是用的这个事件
事件9,键盘的开,关
事件10,按键按下在弹起等动作
2.详细分析:
1.注意swith的日志信息:log中的Switch,主要是查看Monkey执行的是那一个Activity,两个swtich之间如果出现了崩溃或其他异常,可以在该Activity中查找问题的所在
2.查看程序无响应的问题:在日志中搜索 “ANR”
3.查看程序崩溃问题:在日志中搜索 “Exception”
4.查看程序闪退问题:在日志中搜素 crash
5.ForceClosed和程序异常退出问题:在日志中搜索“致命”或搜素 forceclose
注:崩溃问题:在日志中搜索 “Exception” ,提一下常见的Java异常:
- 算术异常类:ArithmeticExecption
- 空指针异常类:NullPointerException
- 类型强制转换异常:ClassCastException
- 数组负下标异常:NegativeArrayException
- 数组下标越界异常:ArrayIndexOutOfBoundsException
- 违背安全原则异常:SecturityException
- 文件已结束异常:EOFException
- 文件未找到异常:FileNotFoundException
- 字符串转换为数字异常:NumberFormatException
- 操作数据库异常:SQLException
- 输入输出异常:IOException
- 违法访问错误:IllegalAccessError
- 内存不足错误:OutOfMemoryError
- 堆栈溢出错误:StackOverflowError