APP压力稳定性测试-Monkey
一、Monkey工具简介
1、monkey的来源:
Monkey是一个命令行工具,使用安卓调试桥(adb)来运行它,模拟用户:触摸屏幕、滑动Trackball、按键等随机事件流来对设备上的程序进行压力测试,检测程序多久的时间会发生异常,可以根据获取的log信息进行修复。
注:运行adb服务,需要搭建android sdk的环境
二、adb下载与环境变量配置
Adb--> Android Debug Bridge(安卓调试桥)
Adb下载地址:https://link.zhihu.com/?target=https%3A//adbshell.com/upload/adb.zip
下载adb.zip成功后,解压到任意盘符,配置环境变量
第一步:选择此电脑---->右键---->属性---->高级系统设置--->
第二步:查看是否安装成功:进入cmd中后输入:adb version命令
如果显示如下,表示你的环境变量已经配置成功:
三、adb常用命令与.apk文件下载安装
(1)adb devices --->查看设备命令:
(2) adb -s 设备号-----链接到具体设备:
(3) 查看设备中已安装程序的命令:
adb shell pm list packages -----查看设备中所有已安装程序
adb shell pm list packages -s----查看设备中系统安装的程序
adb shell pm list packages -3----列出第三方安装的程序
(4) 如何对以安装程序进行过滤
adb shell pm list packages |findstr包名中字符串(windows操作系统命令)
adb shell pm list packages |grep 包名中字符串(Linux操作系统命令)
命令:adb shell pm list packages | findstr kyk
(5) 如何查看日志(日志默认大小为256KB)
adb logcat -----查看全部日志 (退出 ctrl+c)
adb logcat -c --->清空日志
adb logcat >logcat.log ---保存日志到logcat.log (退出 ctrl+c)
四、Monkey的一般使用步骤
1.先确认设备(模拟器或者真机)是否连接成功。命令:adb devices,出现设备号则表示连接成功
2.确定待测应用的包名,输入命令:adb shell dumpsys activity | find "mFocusedActivity"
3.执行monkey测试命令:adb shell monkey -p com.funny.kyk -v -v 200
意思就是:向有趣生活app发送200次随机事件流操作,且打印日志
五、Monkey的常见命令:
1、常用参数:
(1) -help 查看monkey用法
命令格式:adb shell monkey [限制命令 参数值][事件名 百分比] 事件次数
(2) -p --->用于约束限制,用此参数指定一个或多个包。指定包之后,Monkey将只允许系统启动指定的APP。如果不指定包,Monkey将允许系统启动设备中的所有APP。指定多个包,使用多个-p,一个-p后面接一个包名。
eg: adb shell monkey -p com.funny.kyk -p com.tencent.edu -v 100
(3) -v 用于指定反馈信息级别(信息级别就是日志的详细程度),总共分3个级别
-v,日志级别 Level0;
-v -v,日志级别 Level 1;
-v -v -v,日志级别 Level 2;
要查看级别最高的日志,例:adb shell monkey -p com.funny.kyk -v -v -v 100
(4) -s 用于指定伪随机数生成器的seed值,如果seed相同,则两次Monkey测试所产生的事件序列也相同的。一般测试过程中出现崩溃,可以通过seed值来完成复现。
(5) --throttle <毫秒> 用于指定用户操作(即事件)间的时延,单位是毫秒;
(6) --randomize-throttle 用这个参数必须与--throttle 绑定使用。用于在事件之间插入随机延迟,随机延迟范围为0到throttle设置的时间,单位为毫秒;
例:adb shell monkey -p com.funny.kyk --throttle 500 --randomize-throttle 100
(7) --pkg-whitelist-file 白名单,后面接txt文件,指定白名单参数后只测试白名单的应用程序
(8) --pkg-blacklist-file 黑名单,后面接txt文件,指定黑名单参数后,避开黑名单的应用程序
例:adb shell monkey --pkg-whitelist-file /data/local/tmp/whitelist.txt 100
2、常用命令:
adb shell monkey -p com.funny.kyk --throttle 100 --ignore-crashes --ignore-timeouts --ignore-security-exceptions --ignore-native-crashes --monitor-native-crashes -v -v -v 1000000 > d:\mylog.log
(1) 操作与操作之间如何加思考时间(延迟时间):
--throttle 300 表示延迟300毫秒 注意:throttle 前面两个“-”
adb shell monkey -p com.funny.kyk -v -v -v --throttle 300 10 -->表示每次运行之间间隔300毫秒
(2) 忽略报错、忽略超时:
--ignore-crashes 忽略错误 注意前面两个“-”不能省略
eg: adb shell monkey -p com.funny.kyk --throttle 300 --ignore-crashes -v -v -v 10
--ignore-crashes --ignore-timeouts 表示忽略错误与忽略超时,注意两个之间有空格
eg:adb shell monkey -p com.funny.kyk --throttle 300 --ignore-crashes --ignore-timeouts -v -v -v 10
(3) 指定操作事件:
--pct-touch 100 表示10次都执行触摸事件:
adb shell monkey -p com.funny.kyk --throttle 300 --ignore-crashes -v -v -v --pct-touch 100 10
(4) 保存日志
adb shell monkey -p com.funny.kyk --throttle 300 --ignore-crashes -v -v -v --pct-touch 100 10 >d:\test.log
(5) 如何将日志保存到PC端?
adb shell monkey -v -v -v 1000 > 本机地址
例:adb shell monkey -v -v -v 1000 > d:\monkey.txt
(6) 日志查看补充
---->先把日志输出到本地
---->注意观察switch后面的内容,一般错误都会显示在这个后面
---->ANR问题:日志中搜索ANR关键字
---->奔溃问题:在日志中搜索Exception问题
六、Monkey百分比事件
0:点击事件百分比,即参数--pct-touch
1:滑动事件百分比,即参数--pct-motion
2:缩放事件百分比,即参数--pct-pinchzoom
3:轨迹球事件百分比,即参数--pct-trackball
4:屏幕旋转事件百分比,即参数--pct-rotation
5:基本导航事件百分比,即参数--pct-nav
6:主要导航事件百分比,即参数--pct-majornav
7:系统按键事件百分比,即参数--pct-syskeys
8:Activity启动事件百分比,即参数--pct-appswitch
9:键盘唤出隐藏事件百分比,即参数--pct-flip
10:其他事件百分比,即参数--pct-anyevent
例:adb shell monkey -p com.funny.kyk --pct-touch 10 -v -v 100
七、monkey日志分析报告
1、monkey出现错误后,一般的分析步骤:
(1) 找到出现错误的位置
(2) 找到出现错误前面两个Switch之间的activity
(3) 手动执行操作,复现问题
(4) 若上述步骤不能找出产生的错误,输入相同的seed值,重复安装之前的命令跑monkey
2、在日志中搜索关键词&分析:
ANR | 有无应用无响应事件 |
crash | 有无奔溃事件 |
exception |
有无其他异常事件 若出现空指针nullpointerexception,需格外重视 |
GC | 内存泄漏问题 |
本文来自博客园,作者:刑之风,转载请注明原文链接:https://www.cnblogs.com/xingzhifeng/p/17123154.html