Monkey测试

一、简介

monkey testing,也有人叫做搞怪测试。就是用一些稀奇古怪的操作方式去测试被测试系统,以测试系统的稳定性。monkey test,一般指这样的测试活动,用毫无规律的指令或操作使用被测系统,观察系统的稳定性和容错性能

二、原理

Monkey测试是Android自动化测试的一种手段,Monkey测试本身非常简单,就是模拟用户的按键输入,触摸屏输入,手势输入等,看设备多长时间会出异常。

当Monkey程序在模拟器或设备运行的时候,如果用户触发了比如点击,触摸,手势或一些系统级别的事件的时候,它就会产生随机脉冲,所以可以用Monkey用随机重复的方法去负荷测试你开发的软件.

三、特点

  1. 基于Android测试开发环境
  2. 需要获取对应程序包
  3. 一般是产品稳定后,或者首轮功能测试完成后进行Monkey测试
  4. Monkey测试的操作事件是随机进行,而不是刻意指定
  5. 主要测试产品是否存在崩溃问题和ANR问题

四、获取包名的方法

  1. 向开发人员索取应用程序包名

  2. adb命令获取包名

    直接获取当前开启应用的包名

adb shell dumpsys activity | find "mFocusedActivity"

结果:

mFocusedActivity: ActivityRecord{15300bd2 u0 com.tencent.mm/.ui.LauncherUI t3}

注意:改命令在Android 8.0之下可以使用,8.0以上会存在问题,修改命令如下即可:

adb shell dumpsys activity | find "mResumeActivity"
  1. adb logcat获取包名,命令如下:
adb shell "logcat | grep START"

如果,无法获取,首先,检查设备是否连接成功,然后命令进入shell,再获取包名

adb shell

接着,输入命令:

# logcat | grep START

然后,在手机或者模拟器中打开想要获取的应用程序,接着在adb命令行中会自动获取到对应的程序包名。

  1. 从data数据中获取包名

首先,是进行shell

adb shell

然后,再找到shell中的data文件夹

root@shamu:/ # cd data
root@shamu:/data # ls

再找到data文件夹下的data文件

root@shamu:/data # cd data
root@shamu:/data/data # ls

结果,就可以查看到手机中安装的所有应用程序包名:

五、基本语法

# -p:packageName
# -v:日志级别,显示程序的执行测试反馈信息
# 100:事件数

adb shell monkey -p 包名 -v 100

六、日志级别

参数: -v 用于指定反馈信息级别(信息级别就是日志的详细程度),总共分3个级别。

分别对应的参数如下表所示:

  1. 日志级别 Level0
adb shell monkey -p 包名 –v 100

说明 缺省值,仅提供启动提示、测试完成和最终结果等少量信息

  1. 日志级别 Level 1
adb shell monkey -p 包名 –v -v 100

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

  1. 日志级别 Level 2
adb shell monkey -p 包名 –v -v –v 100

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

七、伪随机数生成器

应用场景:在测试时,发现程序有bug,那么可以通过此方法,复现bug。因为加-s后,monkey执行的操作将会固定,若不加-s那么monkey的操作将会随机进行。

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

Monkey测试1:

adb shell monkey -p 包名 –s 10 1000

Monkey 测试2:

adb shell monkey -p 包名 –s 10 1000

两次测试的效果是相同的,因为模拟的用户操作序列(每次操作按照一定的先后顺序所组成的一系列 操作,即一个序列)是一样的。

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

八、事件类型

  • --pct-touch:指定触摸事件的百分比,如:--pct-touch 5
  • --pct-motion (滑动事件)
  • --pct-trackball (轨迹球事件)
  • --pct-nav (导航事件 up/down/left/right)
  • --pct-majornav (主要导航事件 back key 、 menu key)
  • --pct-syskeys (系统按键事件 Home 、Back 、startCall 、 endCall 、 volumeControl)
  • --pct-appswitch (activity之间的切换)
  • --pct-anyevent (任意事件)

九、ANR日志导出

Android系统的ANR日志存放在/data/anr/traces.txt中,其中包含应用程序每个线程堆栈信息。测试人员或者开发人员可以根据这个信息定位bug。ANR日志文件traces.txt导出手机操作如下:

  • 首先进入shell
adb shell
  • 然后,复制ANR日志文件traces.txt至具有读写操作的文件中
cp /data/anr/traces.txt  /sdcard/traces.txt  
  • 最后,pull命令导出至计算机
adb pull /sdcard/traces.txt

十、Crash日志导出

执行压力测试,并且生成monkey_test.log日志文件。

adb shell monkey -p cn.besttest.crashtest -v 100 >D:\monkey\monkey_crash.log

查看E盘文件夹下已经生成了monkey_crash.log。

十一、结果分析

  • 按关键字进行搜索,ANR、Exception、Crash、Error。

ANR问题(程序无响应):在日志中搜索“ANR"(application no response)

闪退问题:在日志中搜索"crash"

异常:搜索"exception"

强制退出:搜索"force closed"

  • 找到有问题的地方,查看上下文信息。注意第一个switch上下文信息。
  • 查看monkey里面出错前的一些事件动作,可以手动执行该动作。
  • 进行问题复现,可以使用之前执行的monkey命令在执行一遍,注意seed值要一样。
posted @ 2020-02-25 21:35  xyztank  阅读(157)  评论(0编辑  收藏  举报