Monkey日志分析

测试检测到的应用程序错误类型

1、ANR问题(程序无响应):在日志中搜索“ANR"(application no response)
2、闪退问题:在日志中搜索"crash"
3、异常:搜索"exception"
4、强制退出:搜索"force closed"

算术异常类:ArithmeticExecption
空指针异常类:NullPointerException
类型强制转换异常:ClassCastException
数组负下标异常:NegativeArrayException
数组下标越界异常:ArrayIndexOutOfBoundsException
违背安全原则异常:SecturityException
文件已结束异常:EOFException
文件未找到异常:FileNotFoundException
字符串转换为数字异常:NumberFormatException
操作数据库异常:SQLException
输入输出异常:IOException
违法访问错误:IllegalAccessError
内存不足错误:OutOfMemoryError
堆栈溢出错误:StackOverflowError 1

Monkey命令使用:

1、-p:约束限制,指定一个包或多个包
指定一个包(跑10次):
adb shell monkey -p 包名 10
指定多个包(跑100次):
adb shell monkey -p 包名1 -p 包名2 100

2、-v:用于指定信息反馈级别(日志详情程度),总共3级
日志级别Leve0:提供启动提示、测试完成和最终结果等少量信息
adb shell monkey -p 包名 -v 100
日志级别Leve1:较为详细的日志,包括每个发送到Activity的事件信息
adb shell monkey -p 包名 -v -v 100
日志级别Leve2:说明最详细的日志,包括了测试中选中/未选中的Activity信息
adb shell monkey -p 包名 -v -v -v 100

3、-s:指定伪随机数生成器的seed值,如果seed相同,则两次Monkey测试所产生的事件序列也相同
adb shell monkey -p 包名 -s 10 100
*注:*两次测试的效果是相同的,因为模拟的用户操作序列是一样的。

4、–throttle:指定用户操作(即事件)间的时延,单位是毫秒
adb shell monkey -p 包名 --throttle 5000 100

5、–ignore-crashes:指定当应用程序崩溃时(Force& Close错误),Monkey是否停止运行。使用此参数,即使应用程序崩溃,Monkey依然会发送事件,直到事件计数完成。
adb shell monkey -p 包名 --ignore-crashes 1000
*注:*测试过程中即使程序崩溃,Monkey依然会继续发送事件直到事件数目达到1000为止

6、–ignore-timeouts:指定当应用程序发生ANR(Application No Responding)错误时,Monkey是否停止运行。如果使用此参数,即使应用程序发生ANR错误,Monkey依然会发送事件,直到事件计数完成。
adb shell monkey -p 包名 --ignore-timeouts 1000

7、–ignore-security-exceptions:用于指定当应用程序发生许可错误时(如证书许可,网络许可等),Monkey是否停止运行。如果使用此参数,即使应用程序发生ANR错误,Monkey依然会发送事件,直到事件计数完成。
adb shell monkey -p 包名 --ignore-security-exceptions 1000

8、–kill-process-after-error:用于指定当应用程序发生错误时,是否停止其运行。如果指定此参数,当应用程序发生错误时,应用程序停止运行并保持在当前状态(注意:应用程序仅是静止在发生错误时的状态,系统并不会结束该应用程序的进程)
adb shell monkey -p 包名 --kill-process-after-error 1000

9、–monitor-native-crashes:用于指定是否监视并报告应用程序发生崩溃的本地代码。
adb shell monkey -p 包名 --monitor-native-crashes 1000

10、–pct-{+事件类别}{+事件类别百分比}
指定每种类别事件的数目百分比(在Monkey事件序列中,该类事件数目占总事件数目的百分比)
–pct-touch{+百分比}
调整触摸事件的百分比(触摸事件是一个down-up事件,它发生在屏幕上的某单一位置)
adb shell monkey -p 包名 --pct-touch 10 100

–pct-motion {+百分比}
调整动作事件的百分比(动作事件由屏幕上某处的一个down事件、一系列的伪随件机事和一个up事件组成)
adb shell monkey -p 包名 --pct-motion 20 1000

–pct-trackball {+百分比}
调整轨迹事件的百分比(轨迹事件由一个或几个随机的移动组成,有时还伴随有点击)
adb shell monkey -p 包名 --pct-trackball 30 1000

–pct-nav {+百分比}
调整“基本”导航事件的百分比(导航事件由来自方向输入设备的up/down/left/right组成)
adb shell monkey -p 包名 --pct-nav 40 1000

–pct-majornav {+百分比}
调整“主要”导航事件的百分比(这些导航事件通常引发图形界面中的动作,如:5-way键盘的中间按键、回退按键、菜单按键)
adb shell monkey -p 包名 --pct-majornav 50 1000

实例:

adb shell monkey -p 包名 --ignore-crashes --ignore-timeouts --pct-motion 60 -v -v --throttle 200 -s 200 1000 "2>/sdcard/error.txt 1>/sdcard/verbose.txt"

说明:
–ignore-crashes:应用程序崩溃,Monkey依然会发送事件,直到事件计数完成
–ignore-timeouts:应用程序发生ANR错误,Monkey依然会发送事件,直到事件计数完成。
–pct-motion:调整动作事件的百分比
level2级别的日志重定向至 d:/error.txt 文件中
level1级别的日志重定向至 d:/verbose.txt 文件中
若是使用PC运行monkey命令并保存在PC端,则在monkey命令的重定向处不需加" “,但是若是需要将monkey命令运行产生的日志信息保存在手机文件夹中,需要添加” "将monkey命令行中的重定向到日志文件的部分引起来

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值