Android自动测试之Monkey工具

APP测试工作中经常会听到领导说,APP压力测试做了吗?刚入行时,不知道什么是 APP压力测试,找了半天没找到自己想要的。过了几年,回头想这个问题,发现牵扯了很多地方。下面我根据自己的理解说以下两点:

  • APP运行稳定性
  • 服务器高压情况下APP运行稳定性

 

APP运行稳定性

举个例子,我们打开APP,随便点两下,APP就停止运行,那么能说这个APP稳定吗?当然实际情况下,不会点两下就奔溃的。既然点两下不会奔溃,那么我点1万次,或者10万次呢?这个就不好做保证。当然我们既然提出这个需求,那么我们肯定

不会傻傻的用手去一次一次点击 APP。不用手有什么 好的办法呢?monkey是不错的选择!

服务器高压情况下APP运行稳定性

服务器高压这是前提条件。我们已经知道服务器是高压,那么客户端发送请求时,界面或者数据是否会出现错乱等情况?甚至是奔溃~当然今天我们讲的是monkey,所以这里不再多谈。

 

Monkey工具概述

 

Monkey是一个命令行工具,可以在任何仿真器实例或设备上运行。它将伪随机的用户事件流发送到系统中,作为您正在开发的应用程序软件的压力测试。

Monkey包含许多选项,但它们分为四个主要类别:

  • 基本配置选项,例如设置要尝试的事件数。
  • 操作约束,例如将测试限制为单个包。
  • 事件类型和频率。
  • 调试选项。

 

当Monkey运行时,它会生成事件并将它们发送到系统。它还可以监视 被测系统,并查找三种特殊情况:

  • 如果您已将Monkey限制为在一个或多个特定包中运行,则会监视尝试导航到任何其他包并阻止它们。
  • 如果您的应用程序崩溃或收到任何类型的未处理异常,Monkey将停止并报告错误。
  • 如果您的应用程序生成一个没有响应错误的应用程序,Monkey将停止并报告错误。

 

个人理解:monkey当然是猴子啦。我们上面提过一个需求,就是我想验证我点1万次或者10万次APP时,APP是否会出现运行异常。当然这1万次或者10万次是随机点击的。想象这样一个场景,把一个键盘放猴子面前,猴子是不是会乱敲键盘?所以我们把随机执行系统上的任何任务叫做monkey测试。不过我这里想了一下,把猴子变成其它动物不也是这样吗?难不成换成别的动物还能打出诗句不成~~哈哈,开玩笑了。我想应该是结合了猴子喜好乱动,但是二哈也喜欢啊。。。不纠结了。

monkey参数大全

类别

选项

描述

一般

--help

打印一个简单的使用指南。

-v

命令行上的每个-v都会增加详细级别。级别0(默认值)提供的信息除启动通知,测试完成和最终结果外几乎没有。级别1提供有关测试运行的更多详细信息,例如发送到您的活动的单个事件。级别2提供更详细的设置信息,例如选择或未选择用于测试的活动。

活动

-s <seed>

伪随机数发生器的种子值。如果您使用相同的种子值重新运行Monkey,它将生成相同的事件序列。

--throttle <milliseconds>

在事件之间插入固定的延迟。您可以使用此选项来减慢Monkey的速度。如果未指定,则没有延迟,并且事件尽可能快地生成。

--pct-touch <percent>

调整触摸事件的百分比。(触摸事件是屏幕上单个位置的下行事件。)

--pct-motion <percent>

调整运动事件的百分比。(运动事件包括屏幕上某处的向下事件,一系列伪随机运动和一个向上事件。)

--pct-trackball <percent>

调整轨迹球事件的百分比。(轨迹球事件由一个或多个随机动作组成,有时随后单击。)

--pct-nav <percent>

调整“基本”导航事件的百分比。(导航事件由上/下/左/右组成,作为来自方向输入设备的输入。)

--pct-majornav <percent>

调整“主要”导航事件的百分比。(这些导航事件通常会导致UI中的操作,例如5向键盘中的中心按钮,后退键或菜单键。)

--pct-syskeys <percent>

调整“系统”键事件的百分比。(这些是通常保留供系统使用的密钥,例如Home,Back,Start Call,End Call或Volume控件。)

--pct-appswitch <percent>

调整活动启动的百分比。在随机的时间间隔内,Monkey将发出一个startActivity()调用,作为最大化包中所有活动的覆盖范围的方法。

--pct-anyevent <percent>

调整其他类型事件的百分比。这是所有其他类型事件的全部功能,例如按键,设备上其他较少使用的按钮等等。

约束

-p <allowed-package-name>

如果以这种方式指定一个或多个包,Monkey将允许系统访问这些包中的活动。如果您的应用程序需要访问其他包中的活动(例如,选择联系人),您还需要指定这些包。如果您没有指定任何包,Monkey将允许系统在所有包中启动活动。要指定多个包,请多次使用-p选项 - 每个包一个-p选项。

-c <main-category>

如果以这种方式指定一个或多个类别,则Monkey将允许系统访问使用指定类别之一列出的活动。如果您未指定任何类别,Monkey将选择使用Intent.CATEGORY_LAUNCHER或Intent.CATEGORY_MONKEY类别列出的活动。要指定多个类别,请多次使用-c选项 - 每个类别一个-c选项。

调试

--dbg-no-events

指定后,Monkey将执行初始启动到测试活动,但不会生成任何其他事件。为了获得最佳效果,请结合-v,一个或多个程序包约束以及非零限制以使Monkey运行30秒或更长时间。这提供了一个环境,您可以在其中监视应用程序调用的包转换。

--hprof

如果设置,此选项将在Monkey事件序列之前和之后立即生成分析报告。这将在data / misc中生成大(~5Mb)文件,因此请小心使用。有关跟踪文件的更多信息,请参见 Traceview

--ignore-crashes

通常,当应用程序崩溃或遇到任何类型的未处理异常时,Monkey将停止。如果指定此选项,Monkey将继续向系统发送事件,直到计数完成。

--ignore-timeouts

通常,当应用程序遇到任何类型的超时错误(例如“应用程序无响应”对话框)时,Monkey将停止。如果指定此选项,Monkey将继续向系统发送事件,直到计数完成。

--ignore-security-exceptions

通常,当应用程序遇到任何类型的权限错误时,Monkey将停止,例如,如果它尝试启动需要某些权限的活动。如果指定此选项,Monkey将继续向系统发送事件,直到计数完成。

--kill-process-after-error

通常,当Monkey因错误而停止时,失败的应用程序将保持运行状态。设置此选项后,它将通知系统停止发生错误的进程。注意,在正常(成功)完成的情况下,启动的进程不会停止,并且设备在最终事件之后只是处于最后状态。

--monitor-native-crashes

观看和报告Android系统本机代码中发生的崩溃。如果设置了--kill-process-after-error,系统将停止。

--wait-dbg

阻止Monkey执行,直到调试器连接到它。

查看APP包名

使用包名查看器APP,链接:https://pan.baidu.com/s/1hx5JKlUiMWuTRz9AJ9xFpA 密码:d0gq

 

monkey常用命令介绍

-p        

用此参数指定一个或多个包。指定包之后,monkey将只允许系统启动指定的app。如果不指定包, monkey将允许系统启动设备中的所有app(包括系统自身功能,如:电话、短信等也就是说everything都将可能被启动)。  

指定一个包:

adb shell monkey -p xxx.xxx.xxx 100   //xxx.xxx.xxx为包名,100为次数

 

指定多个包

adb shell monkey -p  xxx.xxx.xxx  –p  xxx.xxx.xxx  10  //xxx.xxx.xxx为包名,10为次数

 

-v        

用于反馈日志级别,也就是详细程度,总共分3个级别,分别对应的参数如下 表所示: 

adb shell monkey -p xxx.xxx.xxx -v 10 // 缺省值,仅提供启动提示、测试完成和最终结果等少量信息  

adb shell monkey -p xxx.xxx.xxx -v -v 10 // 提供较为详细的日志,包括每个发送到Activity的事件信息 

adb shell monkey -p xxx.xxx.xxx -v -v -v 10 // 最详细的日志,包括了测试中选中/未选中的Activity信息

 

-s(随机数种子)            

用于指定伪随机数生成器的seed值,如果seed相同,则两次Monkey测试所产生的事件序列也相同的。  示例:指定seed值为1,运行次数为10

monkey测试1:adb shell monkey -p xxx.xxx.xxx –s 1 10      //指定seed值为1,运行次数为10          

monkey测试2:adb shell monkey -p xxx.xxx.xxx –s 1 10      //指定seed值为1,运行次数为10

 

--throttle

每个事件结束后的间隔时间——降低系统的压力(如不指定,系统会尽快的发送事件序列)。如:--throttle 100

adb shell monkey -p xxx.xxx.xxx --throttle 100 100       // 指定间隔时间为100ms,运行次数为100

 

--pct-touch <percent>

指定触摸事件的百分比

adb shell monkey -p xxx.xxx.xxx --pct-touch 5 100       // 指定触摸事件为5%,运行次数为100

 

--pct-motion <percent> (滑动事件)

adb shell monkey -p xxx.xxx.xxx --pct-motion 5 100       // 指定滑动事件为5%,运行次数为100

 

--pct-trackball <percent> (轨迹球事件) 

adb shell monkey -p xxx.xxx.xxx --pct-trackball 5 100       // 指定轨迹球为5%,运行次数为100

 

 up/down/left/right)

adb shell monkey -p xxx.xxx.xxx --pct-nav 5 100       // 指定基本导航事件为5%,运行次数为100

 

adb shell monkey -p xxx.xxx.xxx --pct-majornav 5 100       // 指定主要导航事件为5%,运行次数为100

 

--pct-syskeys<percent> (系统按键事件Back 、startCall 、

adb shell monkey -p xxx.xxx.xxx --pct-syskeys 5 100       // 指定系统按键事件为5%,运行次数为100

  

--ignore-crashes(忽略崩溃)

adb shell monkey -p xxx.xxx.xxx --ignore-crashes 100       // 忽略奔溃,运行次数为100

 

--ignore-timeouts(忽略超时)

adb shell monkey -p xxx.xxx.xxx --ignore-timeouts 100       // 忽略超时,运行次数为100

 

实例

1、事件、间隔时间、调试、输出日志整合

adb shell monkey -p xxx.xxx.xxx -s 1 --pct-touch 5 --throttle 100 --ignore-crashes --ignore-timeouts -v -v 10000 > D:\monkey_log.txt  

// 指定包、设置seed值为1,触摸事件5%,每个事件间隔时间100ms 忽略奔溃 忽略超时 日志级别为2级 10000次事件,保存日志到d盘monkey_log.txt

 

2、停止monkey运行

adb shell
ps | grep monkey

kill 5540

 

Androidx 测试dependency android app测试工具_触摸事件

 

monkey日志分析

 

日志分析呢,我们主要看异常。常见的异常为ANR Exception

1. 程序无响应的问题: 在日志中搜索 “ANR”
2. 崩溃问题:在日志中搜索 “Exception”   (如果出现空指针, NullPointerException)  

 

如下图所示:

Androidx 测试dependency android app测试工具_应用程序_02

 

monkey优缺点

 

 优点肯定是简单好用啦~缺点吗,硬说的话我觉得有一个,比如我想单独点击APP某个页面的某个区域,比如我只想点击登录按钮,那么就不好做了,不过好像是可以写脚本解决的。之前研究过,给忘掉了。后面再用的话再进行补充。