您的位置:首页 > 移动开发

App压力稳定性测试之Monkey

2020-04-04 11:29 916 查看

一、Monkey简介

Android系统自带monkey程序,模拟用户触摸屏幕、滑动Trackball、按键等操作来对设备上的程序进行压力测试,检测程序多久的时间会发生异常。

Monkey的使用是在产品稳定了,没有特别多的Bug时候。用monkey去测试待测应用的稳定性、健壮性(是否会发生闪退、崩溃),手机出厂前的整机测试。Monkey犹如其猴子的译名,就是杂乱无章的乱点,通过指定执行点击次数,不断的点击安卓系统,或者指定的App,给系统产生压力。

注意:在使用Monkey之前,需要利用adb将PC端与安卓设备连接。

二、monkey常见命令

1.1、调出说明手册

命令:adb shell monkey –help或者-h

这个命令可以查看monkey使用的说明,如下:

 

1.2、monkey基本命令格式:adb shell monkey {+命令参数} [执行事件次数]   

例如:adb shell monkey -v 100

命令参数例如:-p,-v,-c   事件:一个点击、一个回退,等就是一个事件

1.3、命令参数

注意:所有的参数都需要放在monkey和设置的事件次数之间,参数的顺序可以调整;若带了-p ,-p最好放在monkey之后。

例:adb shell monkey -p <包名> --throttle 1000 --ignore-crashes --ignore-timeouts --ignore-security-exceptions --ignore-native-crashes --monitor-native-crashes -v -v -v -s 300 500

1.3.1、打印日志等级

-v: 用于指定反馈信息级别(信息级别就是日志的详细程度)。

总共分3个级别;

一级:-v                //默认级别,仅提供启动、测试完成和最终结果等少量信息

二级:-v –v          //提供较为详细的日志,包括每个发送到Activity的事件信息

三级:-v -v -v      //提供最详细的日志,包括了测试中选中/未选中的Activity信息

例如:adb shell monkey -v -v -v 100

1.3.2、指定测试App

-p <App包名> :增加App的包名时,可以只针对该App进行压力测试;

包名可同时添加多个,同时对多个App测试;

不加"-p <App包名>"时,则对安卓系统进行测试。

例:1)对一个App测试

adb shell monkey -p com.tecent mobileqq -v -v -v 300

2)对两个App进行测试

adb shell monkey -p com.lemon.lemon -p com.tecent mobileqq -v -v -v 300

1.3.3、seed值

-s  用于指定随机数生成器的seed值;

如果前后两次使用monkey时seed值相同,测两次monkey测试所产生的事件序列也相同。用于问题重现;

seed值相当于执行顺序,可以是300、400等。但是遇到问题,需要再次使用monkey复现问题时,seed必须相同。可以直接运行上一次的命令。

格式:adb shell monkey -p <包名> -v -v -v -s <seed值> [执行事件次数]

例:adb shell monkey -p com.tecent mobileqq -v -v -v -s 400 1000

【400:seed的值,1000:执行事件次数】  【复现同一问题时,将此命令重新输一遍】

1.3.4、操作时延

--throttle <毫秒> 用于指定用户操作(即事件)间的时延,单位是毫秒。

例如:时延为1秒,在执行点击事件后等1秒在进行回退事件。

格式:adb shell monkey -v -v -v -p <包名> -s <seed值> --throttle 1000 [执行事件次数]

例:adb shell monkey -v -v -v -p com.tecent mobileqq -s 300 --throttle 1000 500      【--throttle 1000指时间间隔为一秒】

1.3.5、忽略超时和崩溃

monkey测试的过程中遇到crash(崩溃)或者timeout(超时)的情况时,会停止测试。如果想在遇到crash或者timeout时继续运行指令,需要加--ignore-crashes --ignore-timeouts将crash和timeout忽略掉。

格式:adb shell monkey -p <包名> --throttle 1000 --ignore-crashes --ignore-timeouts -v -v -v -s 300 500

三、日志导出

Monkey执行过程中产生异常时,需要把日志导出,将异常信息找出。

1、直接将日志打印至PC端

命令:adb shell monkey -p <包名> -v -v -v [执行事件次数] > <PC端存放目录>

可以在执行monkey过程中,直接将日志存放至PC端。

例:adb shell monkey -p <包名> -v -v -v 200 D:\log.txt

2、执行完monkey之后导出日志

命令:adb logcat –v time > D:\ log.txt  拉取的日志自带时间

3、日志定位

当日志生成后,我们需要进入日志当中查看是否有APP崩溃记录或者无响应记录。

查找关键字:

A、崩溃记录查找”CRASH”;

B、无响应记录查找”ANR”;

C、内存泄露问题搜索"GC"(需进一步分析);

D、异常问题搜索“Exception”;

 

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: