解决方案

Monkey测试详解

seo靠我 2023-09-25 18:31:26

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

介绍

Monkey是Android系统自带一个命令行工具,可以运行在模拟器里或者真实设备中运行。monkey向系统发送伪随机的用户事件流,实现对正在开发的应用程序进行压力测试。

monkey包括很多SEO靠我选项,大致四大类:

1.基本配置选项,如设置尝试的事件数量。

2.运行约束选项,如设置只对单独的一个包进行测试。

3.事件类型和频率。

4.调试选项

Monkey 命令启动方式:

a. 可以通过PC机CMD窗口中SEO靠我执行: adb shell monkey {+命令参数}来进行Monkey测试

b. 在PC上adb shell 进入Android系统,通过执行monkey {+命令参数} 来进行Monkey 测试

cSEO靠我. 在Android机或者模拟器上直接执行monkey 命令,可以在Android机上安装Android终端模拟器

monkey命令特性

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

一、首先你要先搭建环境

1.先下载jdk具体安装流程请参考:JDK教程

2.再下载sdk 具体安装流程请参考:SDK教程SEO靠我

二、在开发者选项里打开手机的usb调试,用usb数据线连接手机,允许电脑连接手机。

三、monkey前的准备命令

1.windows+R 输入cmd进入dos命令行;

2.输入adb devices 下面出SEO靠我现类似下图的组合你就成功了;

3.输入 adb shell pm list packages查看手机所有的包名,输入 adb shell pm list packages -3 查看手机上所有的第三方包SEO靠我名。

四、参数介绍

1.参数-p

用于约束限制,用此参数指定一个或多个package,指定包之后,monkey将只允许系统启动指定的APP,如果不指定包,monkey将允许启动设备中所有APP。

不指定包:aSEO靠我db shell monkey 100

指定一个包:adb shell monkey -p com.tencent.news 100

指定多个包:adb shell monkey -p com.tenceSEO靠我nt.news 100 -p com.tencent.news 100*

-p空格后面是软件包名;100表示测试事件次数。

2. 参数-v

用于指定反馈日志的详细程度,总共范围内3个级别

日志级别 levelSEO靠我 0

adb shell monkey -p com.tencent.news -v 100

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

日志级别 level 1

adb shell monkey -SEO靠我p com.tencent.news -v -v 100

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

日志级别 level 2

adb shell monkey -p com.tenSEO靠我cent.news -v -v -v 100

说明:提供最详细的日志,包括测试中选中(未选中的)Activity的事件信息

3. 参数-s

用于指定伪随机数生成器的send值,如果send相同则两次monkSEO靠我ey测试所产生的事件序列也相同。

Monkey测试 1

adb shell monkey -p com.tencent.news -s 10 100

Monkey 测试 2

adb shell monkey SEO靠我-p com.tencent.news -s 10 100

说明:两次测试的效果是相同的,因为模拟的用户操作序列(每次操作按照一定的先后顺序所组成的一系列操作,即一个序列)是一样的。操作序列虽然是随机生SEO靠我成的,但是只要指定了相同的send值,就可以保证两次测试产生的随机操作序列是完全相同的,所以这个操作序列是伪随机的。

4. 参数–throttle<单位:毫秒>

说明:用于指定两个事件之间一个固定延迟,可SEO靠我以减缓monkey的执行速度。如果不指定,monkey将不会被延迟,事件将尽可能快地生成和发送消息。

adb shell monkey --throttle 3000 -p com.tencent.neSEO靠我ws 100

向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。

5. 参数–pct -{+事件类型}{+事件类型的百分比}

参数列表查看如下,参数后面紧接着是百分比 0-100,百分比的总量不能大于1SEO靠我00

(1)–pct-touch 触摸事件

adb shell monkey --throttle 3000 --pct-touch 50 -p com.tencent.news 100

解释:向腾讯新闻发SEO靠我送1000次随机事件,每次事件间隔为3秒。其中设定触摸的事件占比为50%

说明:触摸事件是指在屏幕某处按下并抬起的操作,就模拟日常手机使用中的点击操作。

(2)–pct-motion 滑动事件

adb shSEO靠我ell monkey --throttle 3000 --pct-motion 50 -p com.tencent.news 100

解释: 向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设SEO靠我定滑动的事件占比为50%

说明:滑动事件是指在屏幕某处按下、随机移动、抬起的操作。类似于我们日常的滑动屏幕翻页的操作。日志显示与触摸事件相似。

(3)–pct-pinchzoom 缩放事件

adb shelSEO靠我l monkey --throttle 3000 --pct-pinchzoom 50 -p com.tencent.news 100

解释:向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设SEO靠我定缩放的事件占比为50%

说明:缩放事件是指在屏幕上的两处同时按下,并同时移动,最后同时抬起。就是平时我们使用时的放大缩小操作。

(4)–pct-trackball 轨迹事件

adb shell monkeSEO靠我y --throttle 3000 --pct-trackball 50 -p com.tencent.news 100

解释:向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定轨迹的事件占SEO靠我比为50%

说明:轨迹事件是由一个或多个随机的移动组成的,有时会伴随点击。早期的智能机带有轨迹球,这个时间就是轨迹球的操作。现在几乎没有轨迹球了,但这个轨迹事件包含了曲线滑动事件,如果被测应用程序需要曲SEO靠我线滑动才需要设置该事件百分比。

(5)–pct-rotation 屏幕旋转事件

adb shell monkey --throttle 3000 --pct-rotation 50 -p com.tencSEO靠我ent.news 100

解释:向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定屏幕旋转的事件占比为50%

说明:这是一个隐藏事件,用于模拟手机的横竖屏切换。该事件由 rotation 事件SEO靠我组成, 其中 degree 表示选装方向, 顺时针旋转,

0 表示旋转 90 度

1 表示 180 度

2 表示旋转 270 度

3 表示旋转 360 度

(6)–pct-nav 基本导航事件

adb shellSEO靠我 monkey --throttle 3000 --pct-nav 50 -p com.tencent.news 100

解释:向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定基本导航的事SEO靠我件占比为50%

说明:基本导航事件是指点击方向输入设备的上、下、左、右按键的操作,现在手机上很少有这样的方向键了。因此该事件用得相对很少。

(7)–pct-majornav 主要导航事件

adb shellSEO靠我 monkey --throttle 3000 --pct-majornav 50 -p com.tencent.news 100

解释: 向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定SEO靠我主要导航的事件占比为50%

说明:主要导航事件是指点击“主要导航”按钮的操作。这些按键通常会导致 UI 界面的动作。如回退按键、菜单按键等。

(8)–pct-flip 键盘事件

adb shell monkSEO靠我ey --throttle 3000 --pct-flip 50 -p com.tencent.news 100

解释:向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定键盘的事件占比为50SEO靠我%

说明: 调整键盘事件主要是指一些与键盘相关的操作。如点击输入框、键盘弹起、点击输入框以外区域、键盘收回等

(9)–pct-appswitch 切换 Activity 事件

adb shell monkeSEO靠我y --throttle 3000 --pct-flip 50 -p com.tencent.news 100

解释:向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定切换Activity事SEO靠我件占比为50%

说明:切换 Activity 事件是指在手机上启动一个 Activity 的操作。 在随机的时间间隔中, Monkey 将执行一个 StartActivity 方法, 作为最大限度上覆盖SEO靠我被测包中全部 Activity 的一种方法。(Activity 这个概念简单但不准确的理解可以认为就是页面的意思)如果该事件比例偏低,你将会看到大部分时间的测试都停留在同一个页面上,因此适当设置该事件SEO靠我的比例是很有必要的。

(10)–pct-syskeys 系统按键事件

adb shell monkey --throttle 3000 --pct-ssyskeys 50 -p com.tencent.nSEO靠我ews 100

解释: 向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定系统按键的事件占比为50%

说明:系统按键事件是指点击系统保留使用的按键操作,如点击 HOME键、返回键、音量调节键等SEO靠我

(11)–pct-anyevent 其它类型事件

adb shell monkey --throttle 3000 --pct-anyevent 50 -p com.tencent.news 100

SEO靠我释:向腾讯新闻发送1000次随机事件,每次事件间隔为3秒。其中设定其他类型的事件占比为50%

说明:其它类型事件除了上面的事件以外的其他事件。它包罗了所有其它类型的事件,如:按键、其它不常用的设备按钮、SEO靠我等等。

6. 参数–hprof

需root权限

adb shell monkey -p com.tencent.news --hprof --throttle 100 --pct-touch 50 --pcSEO靠我t-motion 50 -v -v -v 1000 >c:\monkey.txt

指定了该参数,monkey会在发送事件的前后生成性能分析报告,通常会在data/misc目录下生成一个5MB左右大小的文SEO靠我件。

7. 参数–ignore-crashes(忽略应用程序崩溃)

用于指定当应用程序崩溃时(Force&Close错误)monkey是否停止运行。若使用此参数,即使应用程序崩溃,monkey依然会发送事SEO靠我件,直到事件计数完成。

adb shell monkey --throttle 3000 --pct-trackball 50 -p com.tencent.news --ignore-crashes SEO靠我100

8. 参数–ignore-timeouts(忽略应用程序无响应)

通常情况下,当应用程序发生任何ANR(application not responding)错误时,monkey将停止运行。若指定SEO靠我了该参数,则monkey将会在产生错误信息后,继续向系统发送事件,直到指定事件全部运行完毕

adb shell monkey --throttle 3000 --pct-trackball 50 -p SEO靠我com.tencent.news --ignore-timeouts 100

9. 参数–ignore-security-exceptions(忽略权限问题异常)

通常情况下,指定应用程序发生许可错误时(SEO靠我如证书许可,网络许可等),monkey将停止运行。若指定了该参数,即使应用程序发生许可错误,monkey会继续向系统发送事件,直到指定事件全部运行完毕。

adb shell monkey --throtSEO靠我tle 3000 --pct-trackball 50 -p com.tencent.news --ignore-security-exceptions 100

10. 参数–kill-process-SEO靠我after-error(发生错误后停止运行)

用于指定当应用程序发生错误时,是否停止其运行。如果指定此参数,当应用程序发生错误时,应用程序停止运行并保持在当前状态

(*注意:应用程序仅是静止在发生错误时的SEO靠我状态,系统并不会结束该应用程序的进程)。

adb shell monkey --throttle 3000 --pct-trackball 50 -p com.tencent.news --kill-pSEO靠我rocess-after-error 100

11. 参数–monitor-native-crashes

用于指定是否监视并报告应用程序发生崩溃的本地代码。

adb shell monkey --throtSEO靠我tle 3000 --pct-trackball 50 -p com.tencent.news --monitor-native-crashes 100

五、Monkey报告组成

第一部分:包含 seedSEO靠我值,执行次数、包名

第二部分:被测设备上的所有应用包名,本次测试使用到哪些包,未使用哪些包(建议测试某app时,杀掉其他应用进程)

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

第五部分:log 完成

如果Monkey测试顺利执行完成,在log的最后,会打印出当前执行事件的次数和所花费的时间;

// SEO靠我Monkey finished代表执行完成。

如果Monkey执行中断,在log的最后也能查看到当前已执行的次数。Monkey执行完成的log具体如下:

六、Monkey分析报告

1.在日志中搜索关键字:

1SEO靠我)搜索报告中的关键字“ANR”,看有无应用无响应的事件(Application Not Responding)

2)搜索报告中的关键字“crash”,看有无崩溃的事件

3)搜索报告中的关键字“exceptSEO靠我ion”,看有无其他异常事件。(如果出现空指针NullPointerException,需格外重视)下面的属于monkey自己的问题。不用管。

4)内存泄露问题搜索"GC"(需进一步分析)

2. 初步分析SEO靠我法: monkey出现错误后,一般的分析步骤

1)先找到出现错误的位置

2)查看出现错误之前2个switch之间的activity

3)手动执行事件,复现问题

4)若以上步骤还不能找出,产生错误时,有会seeSEO靠我d值,输入相同的seed值,重新按照之前命令跑monkey

3.详细分析法:

1) ANR问题:在日志中搜索“ANR”(“Application Not Responding"),说明有bug,出现ANRSEO靠我,一般是主线程的响应超过5秒,或者BroadcastReceiver没有在10秒内作出响应。这个就是一个比较严重的缺陷。把耗时的操作另起线程来处理就可以了。

2)分析log中的具体信息:查看log中第一SEO靠我个Switch,主要是查看Monkey执行的是哪一个Activity,譬如下面的log中,执行的是com.tencent.smtt.SplashActivity,在下一个swtich之间的,如果出现了SEO靠我崩溃或其他异常,可以在该Activity中查找问题的所在。

3)内存泄漏

1) 内存泄漏弹出out of memory对话框

2)对于有内存泄漏但是没有单出out of memory对话框的情况,可以通过lSEO靠我ogcat文件GC出信息,(GC:java的垃圾回收机制)

GC_FOR_ALLOC: 因为在分配内存时候内存不够引起的

GC_EXPLICIT 表明GC被显式请求触发的,如System.gc调用,

GC_SEO靠我CONCCURRENT: 表明GC在内存使用率达到一定的警戒值时候,自动触发

GC_BEFORE_OOM 表明在虚拟机抛出内存不够异常oom之前,执行最后一次回收内存垃圾

3)发现内存泄露–内存报告分析(SEO靠我利用hprof参数的内存快照生成内存报告)在发现内存泄露后,可以执行相同的monkey,只需多加一个参数–hprof

adb shell monkey -p 包名 --hprof --throttle SEO靠我100 --pct-touch 50 --pct-motion 50 -v -v -v 1000 >c:\monkey.txt

说明:如果指定了这个选项,monkey会在发送时间的前后生成APP内存快照SEO靠我文件,一般会在手机设备的/data/misc目录下生成hprof的文件。(注:/data/misc需要root权限,可以在手机上安装个RE查看或通过手机助手查看)

ps:文件转换:配置monkey测试时SEO靠我的sdk-tools下查看是否hprof-conv命令,在命令行输入hprof-conv -help得知文件转化用法,直接转化就行,由.hprof转化成.conv格式。

转化后的文件用eclipse的MSEO靠我emory Analyzer tool(MAT)查看(此插件可以下载),可以点击 Reports->Leak Suspects链接来生成报告。
“SEO靠我”的新闻页面文章、图片、音频、视频等稿件均为自媒体人、第三方机构发布或转载。如稿件涉及版权等问题,请与 我们联系删除或处理,客服邮箱:html5sh@163.com,稿件内容仅为传递更多信息之目的,不代表本网观点,亦不代表本网站赞同 其观点或证实其内容的真实性。

网站备案号:浙ICP备17034767号-2