Monkey测试详解「建议收藏」

Monkey测试详解「建议收藏」概念:monkeytest,也有人叫做搞怪测试,一般指用毫无规律的指令或操作去测试被测系统,观察被测系统的稳定性和容错性。这种测试方式在产品周期中的早期阶段会找到很多很好的bug,为用户节省不少的时

大家好,又见面了,我是你们的朋友全栈君。

概念:
monkey test,也有人叫做搞怪测试,一般指用毫无规律的指令或操作去测试被测系统,观察被测系统的稳定性和容错性。这种测试方式在产品周期中的早期阶段会找到很多很好的bug,为用户节省不少的时间。

介绍:
Monkey是Android系统自带一个命令行工具,可以运行在模拟器里或者真实设备中运行。monkey向系统发送伪随机的用户事件流,实现对正在开发的应用程序进行压力测试。
monkey包括很多选项,大致四大类:
1.基本配置选项,如设置尝试的事件数量。
2.运行约束选项,如设置只对单独的一个包进行测试。
3.事件类型和频率。
4.调试选项

Monkey 命令启动方式:
a. 可以通过PC机CMD窗口中执行: adb shell monkey {+命令参数}来进行Monkey测试
b. 在PC上adb shell 进入Android系统,通过执行monkey {+命令参数} 来进行Monkey 测试
c. 在Android机或者模拟器上直接执行monkey 命令,可以在Android机上安装Android终端模拟器

monkey命令特性:
不可能使用monkey来指定做一样测试,重复做很多次。因为monkey产生的是伪随机的事件流。但是我们可以通过添加命令选项将操作限制在一定的范围内。

一、首先你要先搭建环境
1.先下载jdk具体安装流程请参考:JDK教程
2.再下载sdk 具体安装流程请参考:SDK教程
二、在开发者选项里打开手机的usb调试,用usb数据线连接手机,允许电脑连接手机。
三、monkey前的准备命令
1.windows+R 输入cmd进入dos命令行;
2.输入adb devices 下面出现类似下图的组合你就成功了;
3.输入 adb shell pm list packages查看手机所有的包名,输入 adb shell pm list packages -3 查看手机上所有的第三方包名。
四、参数介绍
1.参数-p
用于约束限制,用此参数指定一个或多个package,指定包之后,monkey将只允许系统启动指定的APP,如果不指定包,monkey将允许启动设备中所有APP。
不指定包:adb shell monkey 100
指定一个包:adb shell monkey -p com.tencent.news 100
指定多个包:adb shell monkey -p com.tencent.news 100 -p com.tencent.news 100*
-p空格后面是软件包名;100表示测试事件次数。
2. 参数-v
用于指定反馈日志的详细程度,总共范围内3个级别
日志级别 level 0
adb shell monkey -p com.tencent.news -v 100
说明:仅提供启动提示,测试完成和最终结果等少量信息
日志级别 level 1
adb shell monkey -p com.tencent.news -v -v 100
说明:提供较为详细的日志,包括每个发送到Activity的事件信息
日志级别 level 2
adb shell monkey -p com.tencent.news -v -v -v 100
说明:提供最详细的日志,包括测试中选中(未选中的)Activity的事件信息
3. 参数-s
用于指定伪随机数生成器的send值,如果send相同则两次monkey测试所产生的事件序列也相同。
Monkey测试 1
adb shell monkey -p com.tencent.news -s 10 100
Monkey 测试 2
adb shell monkey -p com.tencent.news -s 10 100
说明:两次测试的效果是相同的,因为模拟的用户操作序列(每次操作按照一定的先后顺序所组成的一系列操作,即一个序列)是一样的。操作序列虽然是随机生成的,但是只要指定了相同的send值,就可以保证两次测试产生的随机操作序列是完全相同的,所以这个操作序列是伪随机的。
4. 参数–throttle<单位:毫秒>
说明:用于指定两个事件之间一个固定延迟,可以减缓monkey的执行速度。如果不指定,monkey将不会被延迟,事件将尽可能快地生成和发送消息。
adb shell monkey –throttle 3000 -p com.tencent.news 100
向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。
5. 参数–pct -{+事件类型}{+事件类型的百分比}
参数列表查看如下,参数后面紧接着是百分比 0-100,百分比的总量不能大于100
(1)–pct-touch 触摸事件
adb shell monkey –throttle 3000 –pct-touch 50 -p com.tencent.news 100
解释:向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定触摸的事件占比为50%
说明:触摸事件是指在屏幕某处按下并抬起的操作,就模拟日常手机使用中的点击操作。

(2)–pct-motion 滑动事件
adb shell monkey –throttle 3000 –pct-motion 50 -p com.tencent.news 100
解释: 向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定滑动的事件占比为50%
说明:滑动事件是指在屏幕某处按下、随机移动、抬起的操作。类似于我们日常的滑动屏幕翻页的操作。日志显示与触摸事件相似。

(3)–pct-pinchzoom 缩放事件
adb shell monkey –throttle 3000 –pct-pinchzoom 50 -p com.tencent.news 100
解释:向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定缩放的事件占比为50%
说明:缩放事件是指在屏幕上的两处同时按下,并同时移动,最后同时抬起。就是平时我们使用时的放大缩小操作。
(4)–pct-trackball 轨迹事件
adb shell monkey –throttle 3000 –pct-trackball 50 -p com.tencent.news 100
解释:向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定轨迹的事件占比为50%
说明:轨迹事件是由一个或多个随机的移动组成的,有时会伴随点击。早期的智能机带有轨迹球,这个时间就是轨迹球的操作。现在几乎没有轨迹球了,但这个轨迹事件包含了曲线滑动事件,如果被测应用程序需要曲线滑动才需要设置该事件百分比。
(5)–pct-rotation 屏幕旋转事件
adb shell monkey –throttle 3000 –pct-rotation 50 -p com.tencent.news 100
解释:向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定屏幕旋转的事件占比为50%
说明:这是一个隐藏事件,用于模拟手机的横竖屏切换。该事件由 rotation 事件组成, 其中 degree 表示选装方向, 顺时针旋转,
0 表示旋转 90 度
1 表示 180 度
2 表示旋转 270 度
3 表示旋转 360 度
(6)–pct-nav 基本导航事件
adb shell monkey –throttle 3000 –pct-nav 50 -p com.tencent.news 100
解释:向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定基本导航的事件占比为50%
说明:基本导航事件是指点击方向输入设备的上、下、左、右按键的操作,现在手机上很少有这样的方向键了。因此该事件用得相对很少。
(7)–pct-majornav 主要导航事件
adb shell monkey –throttle 3000 –pct-majornav 50 -p com.tencent.news 100
解释: 向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定主要导航的事件占比为50%
说明:主要导航事件是指点击“主要导航”按钮的操作。这些按键通常会导致 UI 界面的动作。如回退按键、菜单按键等。
(8)–pct-flip 键盘事件
adb shell monkey –throttle 3000 –pct-flip 50 -p com.tencent.news 100
解释:向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定键盘的事件占比为50%
说明: 调整键盘事件主要是指一些与键盘相关的操作。如点击输入框、键盘弹起、点击输入框以外区域、键盘收回等
(9)–pct-appswitch 切换 Activity 事件
adb shell monkey –throttle 3000 –pct-flip 50 -p com.tencent.news 100
解释:向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定切换Activity事件占比为50%
说明:切换 Activity 事件是指在手机上启动一个 Activity 的操作。 在随机的时间间隔中, Monkey 将执行一个 StartActivity 方法, 作为最大限度上覆盖被测包中全部 Activity 的一种方法。(Activity 这个概念简单但不准确的理解可以认为就是页面的意思)如果该事件比例偏低,你将会看到大部分时间的测试都停留在同一个页面上,因此适当设置该事件的比例是很有必要的。
(10)–pct-syskeys 系统按键事件
adb shell monkey –throttle 3000 –pct-ssyskeys 50 -p com.tencent.news 100
解释: 向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定系统按键的事件占比为50%
说明:系统按键事件是指点击系统保留使用的按键操作,如点击 HOME键、返回键、音量调节键等。
(11)–pct-anyevent 其它类型事件
adb shell monkey –throttle 3000 –pct-anyevent 50 -p com.tencent.news 100
解释:向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定其他类型的事件占比为50%
说明:其它类型事件除了上面的事件以外的其他事件。它包罗了所有其它类型的事件,如:按键、其它不常用的设备按钮、等等。

6. 参数–hprof 需root权限
adb shell monkey -p com.tencent.news –hprof –throttle 100 –pct-touch 50 –pct-motion 50 -v -v -v 1000 >c:\monkey.txt
指定了该参数,monkey会在发送事件的前后生成性能分析报告,通常会在data/misc目录下生成一个5MB左右大小的文件。
7. 参数–ignore-crashes(忽略应用程序崩溃)
用于指定当应用程序崩溃时(Force&Close错误)monkey是否停止运行。若使用此参数,即使应用程序崩溃,monkey依然会发送事件,直到事件计数完成。
adb shell monkey –throttle 3000 –pct-trackball 50 -p com.tencent.news –ignore-crashes 100
8. 参数–ignore-timeouts(忽略应用程序无响应)
通常情况下,当应用程序发生任何ANR(application not responding)错误时,monkey将停止运行。若指定了该参数,则monkey将会在产生错误信息后,继续向系统发送事件,直到指定事件全部运行完毕
adb shell monkey –throttle 3000 –pct-trackball 50 -p com.tencent.news –ignore-timeouts 100
9. 参数–ignore-security-exceptions(忽略权限问题异常)
通常情况下,指定应用程序发生许可错误时(如证书许可,网络许可等),monkey将停止运行。若指定了该参数,即使应用程序发生许可错误,monkey会继续向系统发送事件,直到指定事件全部运行完毕。
adb shell monkey –throttle 3000 –pct-trackball 50 -p com.tencent.news –ignore-security-exceptions 100
10. 参数–kill-process-after-error(发生错误后停止运行)
用于指定当应用程序发生错误时,是否停止其运行。如果指定此参数,当应用程序发生错误时,应用程序停止运行并保持在当前状态
(*注意:应用程序仅是静止在发生错误时的状态,系统并不会结束该应用程序的进程)。
adb shell monkey –throttle 3000 –pct-trackball 50 -p com.tencent.news –kill-process-after-error 100
11. 参数–monitor-native-crashes
用于指定是否监视并报告应用程序发生崩溃的本地代码。
adb shell monkey –throttle 3000 –pct-trackball 50 -p com.tencent.news –monitor-native-crashes 100
五、Monkey报告组成
第一部分:包含 seed值,执行次数、包名
第二部分:被测设备上的所有应用包名,本次测试使用到哪些包,未使用哪些包(建议测试某app时,杀掉其他应用进程)
第三部分:各个事件所占百分比,只显示了事件的代号,没有显示具体什么时间,可以查询monkey源代码中各代号对应的事件,所有事件包含: 第四部分:具体事件
第五部分:log 完成
如果Monkey测试顺利执行完成,在log的最后,会打印出当前执行事件的次数和所花费的时间;
// Monkey finished代表执行完成。
如果Monkey执行中断,在log的最后也能查看到当前已执行的次数。Monkey执行完成的log具体如下:
六、Monkey分析报告
1.在日志中搜索关键字:
1)搜索报告中的关键字“ANR”,看有无应用无响应的事件(Application Not Responding)
2)搜索报告中的关键字“crash”,看有无崩溃的事件
3)搜索报告中的关键字“exception”,看有无其他异常事件。(如果出现空指针NullPointerException,需格外重视)下面的属于monkey自己的问题。不用管。
4)内存泄露问题搜索”GC”(需进一步分析)
2. 初步分析法: monkey出现错误后,一般的分析步骤
1)先找到出现错误的位置
2)查看出现错误之前2个switch之间的activity
3)手动执行事件,复现问题
4)若以上步骤还不能找出,产生错误时,有会seed值,输入相同的seed值,重新按照之前命令跑monkey
3.详细分析法:
1) ANR问题:在日志中搜索“ANR”(“Application Not Responding”),说明有bug,出现ANR,一般是主线程的响应超过5秒,或者BroadcastReceiver没有在10秒内作出响应。这个就是一个比较严重的缺陷。把耗时的操作另起线程来处理就可以了。
2)分析log中的具体信息:查看log中第一个Switch,主要是查看Monkey执行的是哪一个Activity,譬如下面的log中,执行的是com.tencent.smtt.SplashActivity,在下一个swtich之间的,如果出现了崩溃或其他异常,可以在该Activity中查找问题的所在。
3)内存泄漏
1) 内存泄漏弹出out of memory对话框
2)对于有内存泄漏但是没有单出out of memory对话框的情况,可以通过logcat文件GC出信息,(GC:java的垃圾回收机制)
GC_FOR_ALLOC: 因为在分配内存时候内存不够引起的
GC_EXPLICIT 表明GC被显式请求触发的,如System.gc调用,
GC_CONCCURRENT: 表明GC在内存使用率达到一定的警戒值时候,自动触发
GC_BEFORE_OOM 表明在虚拟机抛出内存不够异常oom之前,执行最后一次回收内存垃圾
3)发现内存泄露–内存报告分析(利用hprof参数的内存快照生成内存报告)在发现内存泄露后,可以执行相同的monkey,只需多加一个参数–hprof
adb shell monkey -p 包名 –hprof –throttle 100 –pct-touch 50 –pct-motion 50 -v -v -v 1000 >c:\monkey.txt
说明:如果指定了这个选项,monkey会在发送时间的前后生成APP内存快照文件,一般会在手机设备的/data/misc目录下生成hprof的文件。(注:/data/misc需要root权限,可以在手机上安装个RE查看或通过手机助手查看)
ps:文件转换:配置monkey测试时的sdk-tools下查看是否hprof-conv命令,在命令行输入hprof-conv -help得知文件转化用法,直接转化就行,由.hprof转化成.conv格式。
转化后的文件用eclipse的Memory Analyzer tool(MAT)查看(此插件可以下载),可以点击 Reports->Leak Suspects链接来生成报告。
————————————————
版权声明:本文为CSDN博主「忆罗」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_49043031/article/details/107210575

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/155822.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月3日 上午8:36
下一篇 2022年7月3日 上午8:46


相关推荐

  • 接口和api_api接口入门

    接口和api_api接口入门API集成服务有助于提高开发人员的开发性能并节省大量时间。

    2025年11月20日
    3
  • 国内镜像源汇总

    国内镜像源汇总1 国内镜像源汇总清华大学 https pypi tuna tsinghua edu cn simple 北京理工大学 http mirror bit edu cn web 中国科技大学 https pypi mirrors ustc edu cn simple 中国科学院 http www opencas org mirrors 华中理工大学 http pypi hustunique com 山东理工大学 http pypi sdutlinux org 阿里云 htt

    2026年2月22日
    3
  • 1bit等于多少字节,换算方法??[通俗易懂]

    1bit等于多少字节,换算方法??[通俗易懂]1比特(bit)=0.125字节(b)1B就是1个字节。Byte、KB、B、MB、GB之间的关系是:Bit——比特B——字节KB——千字节MB——兆字节GB——吉字节TB——太字节1B=8Bit计算机64位的=8个字节…

    2022年5月26日
    87
  • 最火编程语言排行榜

    最火编程语言排行榜IEEESpectrum 发布了 2021 年编程语言排行榜 官方的标题是 Python 在新技术领域依然是主导地位 Python 近几年随着大数据 数据挖掘 人工智能等领域的发展 越来越受到大家的青睐 由于 Python 上手学习比较简单 除了很多专业的开发人员学习外 非专业的数据处理人员也开始慢慢的接触 Python 从 2018 年开始 Python 的关注度就在快速攀升 并且获得了 TIOBE 的 2018 与 2020 年的年度编程语言 国内关注度 参考了百度指数 也是逐年攀升 IE

    2026年3月17日
    2
  • linux将时间戳转换为时间_shell脚本获取时间戳

    linux将时间戳转换为时间_shell脚本获取时间戳虽然电脑已经很普遍了,但是一些年长的人对电脑的操作不是很熟悉,比如在使用win7系统时一旦遇到linux时间戳转换时就懵了,对于linux时间戳转换处理起来相对来说较简单,按照我们的步骤处理linux时间戳转换很容易上手,linux时间戳转换具体处理方法如下:Unix时间戳转换怎样在Excel批量修改答:Linux的时间戳其实就是从1970年1月1日0时0分0秒开始到对应时间的秒数,转换可以在当前…

    2022年10月2日
    5
  • 2022年 2月19运维面试题

    2022年 2月19运维面试题 

    2022年5月30日
    31

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号