Monkey命令详解

命令:adb shell monkey +命令参数

所有的参数都需要放在monkey和设置的次数之间;参数的顺序可以调整,若带了-p ,-p必须放在monkey之后,参数必须在-p和次数之间

2.monkey基础命令

adb shell monkey -p 包名 -v -s seed值 压测次数

参数-p:

此命令用于指定要测试的包,若不指定则在整个系统中执行

a)指定一个包执行10次:adb shell monkey -p 包名 10

如下出现事件执行次数和所耗时间,则算是执行成功;

b)指定多个包执行10次:adb shell monkey -p 包名 –p 包名 10

参数 -v:

用于指定反馈日志的详细程度级别(共3个级别)

1.Level 0: adb shell monkey -p 包名 -v 10

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

2.Level 1: adb shell monkey -p 包名 -v -v 10

提供较为详细的日志,包括每个发送到Activity的事件信息

3.Level 2: adb shell monkey -p 包名 -v -v -v 10

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

参数 -s:

用于指定伪随机数生成器的seed值

命令:adb shell monkey -p 包名 –s seed值 执行次数

作用:如果seed值相同,则两次Monkey测试所产生的事件序列也相同的。

示例

测试1:adb shell monkey -p com.qq –s 15888 100

测试2:adb shell monkey -p com.qq –s 15888 100

说明

两次测试的效果是相同的,因为模拟的用户操作序列(每次操作按照一定的先后顺序所组成的一系列操作,即一个序列)是一样的。(也就是说,重复执行上次的随机操作)

操作序列虽然是随机生成的,但是只要我们指定了相同的Seed值,就可以保证两次测试产生的随机操作序列是完全相同的,所以这个操作序列伪随机的;

运行:

>>不间断操作500次              adb shell monkey -p 包名 -v 500  

>>每个操作间隔500ms,共执行100次             adb shell  monkey -p 包名  -v-v --throttle  500 100

>>每个操作间隔100ms,共执行1000次 ,其中点击事件占比50%,轨迹50%                 adb shell monkey  -p  包名  -v-v --pct-touch  50  --pct-trackball 50 --throttle 100 1000

>>日志重定向到桌面文件夹                               adb shell monkey  -p  包名  -v-v --pct-touch  50  --pct-trackball 50 --throttle 100 1000>C:\Users\xyp\Desktop\Android脚本\1.log

>>每个操作间隔500ms、崩溃、超时、许可错误继续执行                       adb shell  monkey -p  包名   --throttle  500 --ignore-crashes --ignore-timeouts --ignore-security-exceptions --ignore-native-crashes --monitor-native-crashes -v-v-v  1000000>C:\Users\xyp\Desktop\Android脚本\1.log

停止monkey测试           

重新打开一个cmd窗口>>进入adb shell>>ps | grep monkey查找monkey进程>>kill  进程号结束monkey

日志分析

1. 查找出差步骤:

a)找到monkey里哪个地方出错

查看Monkey执行的是哪一个Activity,在switch后面找,两个swtich之间如果出现了崩溃或其他异常,可以在该Activity中查找问题的所在。

b)查看Monkey里面出错前的一些事件动作,手动执行该动作

>>Sleeping for XX milliseconds这是执行Monkey测试时,throttle设定的间隔时间,每出现一次,就代表一个事件

>>Sending XX 就是代表一个操作,如下图的两个操作 应该就是一个点击事件。

c)若以上步骤还不能找出,则可以使用之前一样的seed,再执行monkey命令一遍,便于复现

2.测试结果分析:

>>程序无响应,ANR问题:在日志中搜索“ANR”

>>崩溃问题:在日志中搜索“CRASH”

>>其他问题:在日志中搜索”Exception”

monkey说明

--throttle   时间间隔

--ignore-crashes    忽略崩溃

--ignore-timeouts  忽略超时

--ignore-security-exceptions   忽略许可错误

--ignore-native-crashes  忽略本地崩溃

--monitor-native-crashes   监控本地崩溃

--pct-touch  触摸、点击

--pct-motion 调整动作事件的百分比(动作事件由屏幕上某处的一个down事件、一系列的伪随机事件和一个up事件组成)

--pct-trackball  调整轨迹事件的百分比(轨迹事件由一个或几个随机的移动组成,有时还伴随有点击)

--pct-nav 调整“基本”导航事件的百分比(导航事件由来自方向输入设备的up/down/left/right组成)

--pct-majornav 调整“主要”导航事件的百分比(这些导航事件通常引发图形界面中的动作,如:5-way键盘的中间按键、回退按键、菜单按键)

--pct-syskeys 调整“系统”按键事件的百分比(这些按键通常被保留,由系统使用,如Home、Back、Start Call、End Call及音量控制键)

--pct-appswitch 调整启动Activity的百分比。在随机间隔里,Monkey将执行一个startActivity()调用,作为最大程度覆盖包中全部Activity的一种方法

--pct-flip 调整“键盘翻转”事件的百分比。

--pct-anyevent 调整其它类型事件的百分比。它包罗了所有其它类型的事件,如:按键、其它不常用的设备按钮、等等

注意:各事件类型的百分比总数不能超过100%

下一篇博文,小博会专门说一下monkey测试中错误日志分析哦~

你可能感兴趣的