一、Monkey简介:
Monkey是Android SDK提供的一个命令行工具,可运行在任一版本上的模拟器里或真机上。Monkey可发送伪随机的用户事件流,适合对应用进行压力测试;只针对Activity做测试,不能对Service做测试。
二、质量要求:
版本release(发布)前,Monkey跑出来的结果中crash要为0,final release前,Monkey跑完的总次数应为25W,结果里不允许有nullPointException出现。
三、常用命令参数
1) -p 应用包名
用于约束限制,用此参数指定一个或者多个包,指定包之后,monkey将只允许启动指定app,如果不指定包,monkey将启动系统中所有的app 。
例:指定一个包 monkey -p com.htc.weather -v 1000
指定多个包 monkey -p com.htc.weather -p com.htc.pdfreader -p com.htc.photo.widgets -v 1000
不指定包 monkey -v 1000
2)-v
Monkey的日志输出有3个级别:默认的是level 0, -v -v日志级别为level 1, -v -v -v日志级别为level 2。日志的级别越高,越详细。为了方便问题的定位,将日志级别设置为level2。
3) -s
指定伪随机数生成器的seed值,如果seed相同,则两次monkey 测试产生的事件序列也相同。
例: monkey -p com.htc.weather -s 35 -v 1000
4) --throttle (毫秒)
指定操作之间的时间间隔,一方面是希望能更接近用户的操作场景,正常用户操作都会有一定的时间间隔;另一方面也是不希望因为过于频繁的操作而导致系统崩溃,尤其是在比较低端的手机上执行测试时。因此通过–throttle设置Monkey每个操作固定延迟0.5秒。
5) --pct-xxx
触摸事件和手势事件是用户最常见的操作,所以通过–pct-touch和–pct-motion将这两个事件的占比调整到40%与25%;
目标应用包含了多个Activity,为了能覆盖大部分的Activity,所以通过–pct-appswitch将Activity切换的事件占比调整到10%;
被测应用之前在测试中出现过不少横竖屏之间切换的问题,这个场景也必须关注,因此通过–pct-rotation把横竖屏切换事件调整到10%;
通过–pct-majornav,调整“主要”导航事件的百分比调整到10%(这些导航事件通常引发图形界面中的动作,如:5-way键盘的中间按键、回退按键、菜单按键)。
注意: 各类事件的百分比总和不能超过100%
6) --ignore-xxx
运行中忽略项,设置后遇到该类问题将继续执行monkey指令;未设置则会停止monkey指令。
--ignore-crashes:忽略崩溃
通常,应用发生崩溃或异常时Monkey会停止运行。如果设置此项,Monkey将继续发送事件给系统,直到事件计数完成。
--ignore-timeouts:忽略超时
设置此项后,当应用程序发生任何超时错误(如ANR,即Application Not Responding)时,monkey将继续运行直到计数完成。如果不设置此项,monkey遇到此类超时将停止运行
--ignore-security-exceptions:忽略安全异常
通常,当程序发生许可错误(例如启动一些需要许可的Activity)导致的异常时,Monkey将停止运行。设置此项,Monkey将继续发送事件给系统,直到事件计数完成。
--ignore-native-crashes:忽略本地代码导致的崩溃
设置忽略后,Monkey将执行完所有的事件,不会因此停止
7) 其他
--monitor-native-crashes:用于指定是否监视并报告应用程序发生崩溃的本地代码
--kill-process-after-error:用于指定当应用程序发生错误时,是否停止其运行。如果指定此参数,当应用程序发生错误时,应用程序停止运行并保持在当前状态。(注意:应用程序仅是静止在发生错误时的状态,系统并不会结束该应用程序的进程)
–hprof:
使用–hprof在出现内存问题时,存储一份内存“快照”
四、实操流程
1.获取应用包名
1).adb logcat | find "包名关键字" 或其他指令
2).adb shell pm list packages -3 显示所有第三方应用
2.连接真机,执行adb devices,确认连接成功.
3.执行monkey指令
4.同时获取更多信息
1)记录logcat日志信息:
adb shell logcat -v time > logcat.txt
2)获取内存信息:
adb shell dumpsys meminfo $package_name or $pid
3)获取CPU信息:
adb shell top -n 1 |findstr $package_name or $pid
4)获取电量信息:
adb shell dumpsys battery
5)获取GPU信息:
GPU信息命令:adb shell dumpsys gfxinfo $package_name or $pid
要获取GPU信息,在“开发者选项”中打开“GPU呈现模式分析”,如图3所示:
图3 GPU呈现模式分析
6)获取流量信息:
adb shell cat/proc/uid_stat/$uid/tcp_rcv
adb shell cat/proc/uid_stat/$uid/tcp_snd
4.分析log
一般的测试结果分析:
1)、 ANR问题:在日志中搜索“ANR”
2)、崩溃问题:在日志中搜索“Exception”