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 内存泄漏问题
posted @ 2023-02-15 16:19  刑之风  阅读(260)  评论(0编辑  收藏  举报