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值要一样。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容