51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 787|回复: 1
打印 上一主题 下一主题

如何使用monkey工具进行稳定性测试?

[复制链接]
  • TA的每日心情
    无聊
    13 小时前
  • 签到天数: 1050 天

    连续签到: 1 天

    [LV.10]测试总司令

    跳转到指定楼层
    1#
    发表于 2023-2-13 10:13:37 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    回复可见
    首先了解monkey是什么
      monkey是Android系统自带一个命令行工具,可以运行在模拟器里或者真实设备中运行。monkey向系统发送伪随机的用户事件流,从而实现对正在开发的应用程序进行压力测试
      monkey包括很多选项,大致分为四大类:
      1.基本配置选项,如设置尝试的事件数量。
      2.运行约束选项,如设置只对单独的一个包进行测试。
      3.事件类型和频率。
      4.调试选项
      monkey的命令启动方式
      在启动monkey之前需要在本机准备好JDK以及SDK环境,安装好以后,可以通过下面三种方式来启动你的monkey。
      1.可以通过PC机CMD窗口中执行:adbshellmonkey{+命令参数}来进行Monkey测试。
      2.在PC上adbshell进入Android系统,通过执行monkey{+命令参数}来进行Monkey测试。
      3.在Android机或者模拟器上直接执行monkey命令,在Android机上安装Android终端模拟器。
      monkey前的准备命令
      1.windows+r输入cmd进入dos命令行。
      2.输入adbdevices下面出现类似下图的组合你就成功了。

      3.输入adbshellpmlistpackages查看手机所有的安装包。
      4.输入adbshellpmlistpackages-3查看手机上所有的第三方安装包。
      monkey常用参数介绍
      1、参数-p:用于约束限制,用此参数指定一个或多个package。-p空格后面是软件包名;100表示测试事件次数。
      指定包之后,monkey将只允许系统启动指定的APP,若不指定包,monkey将允许启动设备中所有APP。
      ·不指定包:adbshellmonkey100
      · 指定一个包:adbshellmonkey-pcom.tencent.news100
      · 指定多个包:adbshellmonkey-pcom.tencent.news100-pcom.tencent.news100*
      2、参数-v:用于指定反馈日志的详细程度,总共范围内3个级别。
      日志级别level0(说明:仅提供启动提示,测试完成和最终结果等少量信息)
      adbshellmonkey-pcom.tencent.news-v100
      日志级别level1(说明:提供较为详细的日志,包括每个发送到Activity的事件信息)
      adbshellmonkey-pcom.tencent.news-v-v100
      日志级别level2(说明:提供最详细的日志,包括测试中选中Activity的事件信息)
      adbshellmonkey-pcom.tencent.news-v-v-v100
      3、参数-s:用于指定伪随机数生成器的send值,如果send相同则两次monkey测试所产生的事件序列也相同。
      操作序列虽然是随机生成的,但指定了相同的send值,就可以保证两次测试产生的随机操作序列是完全相同的,因此操作序列是伪随机的。
      4、--throttle:设定两个事件之间一个固定延迟,可以减缓monkey的执行速度。如果不指定,monkey将不会被延迟,事件将尽可能快地生成和发送消息。单位:毫秒
      例:adbshellmonkey--throttle3000-pcom.baidu.news100
      向百度新闻发送1000次随机事件,每次事件间隔为3秒。
      5、--pct-touch:(空格后加数字)设定触屏事件生成的百分比。触屏事件是一个有手指按下,抬起事件的手势。
      例:adbshellmonkey--throttle3000--pct-touch50-pcom.baidu.news100
      向百度新闻发送1000次随机事件,每次事件间隔为3秒。其中设定触屏的事件占比为50%。
      6、--pct-motion:设定滑动事件生成的百分比。滑动事件是一个先在某一个位置手指按下,滑动一段距离后再抬起手指的手势。
      例:adbshellmonkey--throttle3000--pct-motion50-pcom.baidu.news100
      向百度新闻发送1000次随机事件,每次事件间隔为3秒。其中设定滑动的事件占比为50%。
      7、--pct-trackball:设定轨迹球事件生成的百分比。轨迹球事件是包含一系列随机移动和单击事件的事件
      例:adbshellmonkey--throttle3000--pct-trackball50-pcom.baidu.news100
      向百度新闻发送1000次随机事件,每次事件间隔为3秒。其中设定轨迹球的事件占比为50%。
      8、--pct-nav:设定基本导航事件生成的百分比。基本导航事件是模拟方向性在设备上输入向上、向下、向左、向右的事件。
      例:adbshellmonkey--throttle3000--pct-nav40-pcom.baidu.news100
      向百度新闻发送1000次随机事件,每次事件间隔为3秒。其中设定基本导航事件的占比为40%。
      9、--pct-majornav:设定主要导航事件生成的百分比。主要导航事件通常会导致UI产生回馈信息,如单击Back键、Home键、Menu键等、
      例:adbshellmonkey--throttle3000--pct-majornav40-pcom.baidu.news100
      向百度新闻发送1000次随机事件,每次事件间隔为3秒。其中设定主要导航事件的占比为40%。

      10、--hprof:指定该参数,Monkey会在发送事件序列的前、后,生成性能分析报告。通常会在data/misc目录下生成一个5MB左右大小的文件
      11、--ignore-crashes:monkey会在测试应用程序崩溃或者发生异常后停止运行,若指定了该参数,则monkey将会在产生异常后,继续向系统发送事件,直到指定事件全部运行完毕。
      12、--ignore-timeouts:当应用程序发生任何超时错误(applicationnotresponding)时,monkey将停止运行。若指定了该参数,则monkey将会在产生错误信息后,继续向系统发送事件,直到指定事件全部运行完毕
      13、--ignore-security-exceptions:指定应用程序发生许可错误时(如证书许可,网络许可等),monkey将停止运行。若指定了该参数,即使应用程序发生许可错误,monkey会继续向系统发送事件,直到指定事件全部运行完毕。
      例:adbshellmonkey--throttle3000--pct-trackball50-pcom.baidu.news--ignore-security-exceptions100
      五、Monkey报告组成
      第一部分:包含seed值,执行次数、包名。

      第二部分:被测设备上的所有应用包名,本次测试使用到哪些包,未使用哪些包。

      第三部分:各个事件所占百分比,只显示了事件的代号,没有显示具体什么时间,可以查询monkey源代码中各代号对应的事件,所有事件包含:

      Eventpercentages(事件百分比):
      0:触摸事件百分比,参数--pct-touch
      1:滑动事件百分比,参数--pct-motion
      2:缩放事件百分比,参数--pct-pinchzoom
      3:轨迹球事件百分比,参数--pct-trackball
      4:屏幕旋转事件百分比,参数--pct-rotation
      5:暂时不知道这个是什么
      6:基本导航事件百分比,参数--pct-nav
      7:主要导航事件百分比,参数--pct-majornav
      8:系统事件百分比,参数--pct-syskeys
      9:Activity启动事件百分比,参数--pct-appswitch
      10:键盘翻转事件百分比,参数--pct-flip
      11:其他事件百分比,参数--pct-anyevent
      第四部分:具体事件

      第五部分:log完成
      如果Monkey测试顺利执行完成,在log的最后,会打印出当前执行事件的次数和所花费的时间;
      //Monkeyfinished代表执行完成。
      如果Monkey执行中断,在log的最后也能查看到当前已执行的次数。
      Monkey执行完成的log具体如下:

      六、Monkey分析报告
      1.在日志中搜索关键字:
      1)搜索报告中的关键字“ANR”,看有无应用无响应的事件(ApplicationNotResponding)
      2)搜索报告中的关键字“crash”,看有无崩溃的事件
      3)搜索报告中的关键字“exception”,看有无其他异常事件。如果出现空指针NullPointerException,需要注意。
      4)内存泄露问题搜索"GC"
      2.初步分析法:monkey出现错误后,一般的分析步骤
      1)先找到出现错误的位置
      2)查看出现错误之前2个switch之间的activity
      3)手动执行事件,复现问题
      4)若以上步骤还不能找出,产生错误时,有会seed值,输入相同的seed值,重新按照之前命令跑monkey
      3.详细分析法:
      1)ANR问题:在日志中搜索“ANR”(“ApplicationNotResponding"),说明有bug,出现ANR,一般是主线程的响应超过5秒,或者BroadcastReceiver没有在10秒内作出响应。这个就是一个比较严重的缺陷。把耗时的操作另起线程来处理就可以了。
      2)分析log中的具体信息:查看log中第一个Switch,主要是查看Monkey执行的是哪一个Activity,譬如下面的log中,执行的是com.tencent.smtt.SplashActivity,在下一个swtich之间的,如果出现了崩溃或其他异常,可以在该Activity中查找问题的所在。

      3)内存泄漏
      1)内存泄漏弹出outofmemory对话框
      2)对于有内存泄漏,但是没有单出outofmemory对话框的情况,可以通过logcat文件GC出信息,(GC:java的垃圾回收机制)
      GC_FOR_ALLOC:因为在分配内存时候内存不够引起的
      GC_EXPLICIT:表明GC被显式请求触发的,如System.gc调用,
      GC_CONCCURRENT:表明GC在内存使用率达到一定的警戒值时候,自动触发
      GC_BEFORE_OOM:表明在虚拟机抛出内存不够异常oom之前,执行最后一次回收内存垃圾
      3)发现内存泄露–内存报告分析(利用hprof参数的内存快照生成内存报告),在发现内存泄露后,可以执行相同的monkey,只需多加一个参数–hprof
      adbshellmonkey-p包名--hprof--throttle100--pct-touch50--pct-motion50-v-v-v1000>c:\monkey.txt

      说明:如果指定了这个选项,monkey会在发送时间的前后生成APP内存快照文件,一般会在手机设备的/data/misc目录下生成hprof的文件。
      (/data/misc需要root权限,可以在手机上安装个RE查看或通过手机助手查看)
      文件转换:
      配置monkey测试时的sdk-tools下查看是否hprof-conv命令,在命令行输入hprof-conv-help得知文件转化用法,直接转化就行,由.hprof转化成.conv格式。
      转化后的文件用eclipse的MemoryAnalyzertool(MAT)查看,可以点击Reports->LeakSuspects链接来生成报告。

    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏1
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-21 22:38 , Processed in 0.064588 second(s), 22 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表