Monkey 工具之使用

来源:互联网 发布:知有儿童挑促织的意思 编辑:程序博客网 时间:2024/05/18 09:07

      公司由于在android的投入加大,很多android下的app项目,以前版本发布后发现存在一定的性能瓶颈,因此性能测试研究提上了议事日程。

      一、android性能测试理论:

        android性能测试和web性能测试有很大的区别,Web性能测试目前很大一部分都是在一定的并发量的情况下,验证软件是否存在性能瓶颈;android平台下app的性能测试主要是对app输入的事件流,验证app在多事件流时是否正常,里面包含的稳定性比较大。手机终端软件的性能测试,主要针对手机终端软件本身的性能测试,终端软件性能测试主要分为终端软件运行速度、终端软件运行资源消耗、终端功耗、终端网络流量等方面,运用第三方的一些工具,监控软件在运行特定的业务的场景时手机资源消耗情况,现在重点介绍一下市场主流测试工具Monkey。


    二、Monkey基本用法:

      Monkey是一个命令行工具,可以运行在模拟器里或实际设备中,它是一种轻量级的性能测试工具。它向系统发送伪随机的事件流,实现对正在运行的应用程序进行压力测试。Monkey包括许多选项,它们大致分为四类:

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

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

      3、事件类型和频率

      4、调试选项


在Monkey运行的时候,它生成事件,并把它们发给系统。同时,Monkey还对测试中的系统进行监测,对下列三种情况进行特殊处理:

· 如果限定了Monkey运行在一个或几个特定的包上,那么它会监测试图转到其它包的操作,并对其进行阻止。

· 如果应用程序崩溃或接收到任何失控异常,Monkey将停止并报错。

· 如果应用程序产生了应用程序不响应(application not responding)的错误,Monkey将会停止并报错。

按照选定的不同级别的反馈信息,在Monkey中还可以看到其执行过程报告和生成的事件。


Monkey基本用法:

可以通过开发机器上的命令行或脚本来启动Monkey。由于Monkey运行在模拟器/设备环境中,所以必须用其环境中的shell来进行启动。可以通过在每条命令前加上adb shell来达到目的,也可以进入Shell后直接输入Monkey命令。基本语法如下:

$ adb shell monkey [options]

如果不指定options,Monkey将以无反馈模式启动,并把事件任意发送到安装在目标环境中的全部包。下面是一个更为典型的命令行示例,它启动指定的应用程序,并向其发送500个伪随机事件:

$ adb shell monkey -p your.package.name -v 500

 

命令选项参考

下表中列出了Monkey命令行可用的全部选项。

类别
选项
说明

常规
--help
列出简单的用法。

-v
命令行的每一个-v将增加反馈信息的级别。Level 0(缺省值)除启动提示、测试完成和最终结果之外,提供较少信息。Level 1提供较为详细的测试信息,如逐个发送到Activity的事件。Level 2提供更加详细的设置信息,如测试中被选中的或未被选中的Activity。

事件
-s <seed>
伪随机数生成器的seed值。如果用相同的seed值再次运行Monkey,它将生成相同的事件序列。

--throttle <milliseconds>
在事件之间插入固定延迟。通过这个选项可以减缓Monkey的执行速度。如果不指定该选项,Monkey将不会被延迟,事件将尽可能快地被产成。

--pct-touch <percent>
调整触摸事件的百分比(触摸事件是一个down-up事件,它发生在屏幕上的某单一位置)。

--pct-motion <percent>
调整动作事件的百分比(动作事件由屏幕上某处的一个down事件、一系列的伪随机事件和一个up事件组成)。

--pct-trackball <percent>
调整轨迹事件的百分比(轨迹事件由一个或几个随机的移动组成,有时还伴随有点击)。

--pct-nav <percent>
调整“基本”导航事件的百分比(导航事件由来自方向输入设备的up/down/left/right组成)。

--pct-majornav <percent>
调整“主要”导航事件的百分比(这些导航事件通常引发图形界面中的动作,如:5-way键盘的中间按键、回退按键、菜单按键)

--pct-syskeys <percent>
调整“系统”按键事件的百分比(这些按键通常被保留,由系统使用,如Home、Back、Start Call、End Call及音量控制键)。

--pct-appswitch <percent>
调整启动Activity的百分比。在随机间隔里,Monkey将执行一个startActivity()调用,作为最大程度覆盖包中全部Activity的一种方法。

--pct-anyevent <percent>
调整其它类型事件的百分比。它包罗了所有其它类型的事件,如:按键、其它不常用的设备按钮、等等。

约束限制
-p <allowed-package-name>
如果用此参数指定了一个或几个包,Monkey将只允许系统启动这些包里的Activity。如果你的应用程序还需要访问其它包里的Activity(如选择取一个联系人),那些包也需要在此同时指定。如果不指定任何包,Monkey将允许系统启动全部包里的Activity。要指定多个包,需要使用多个 -p选项,每个-p选项只能用于一个包。

-c <main-category>
如果用此参数指定了一个或几个类别,Monkey将只允许系统启动被这些类别中的某个类别列出的Activity。如果不指定任何类别,Monkey将选 择下列类别中列出的Activity: Intent.CATEGORY_LAUNCHER或Intent.CATEGORY_MONKEY。要指定多个类别,需要使用多个-c选项,每个-c选 项只能用于一个类别。

调试
--dbg-no-events
设置此选项,Monkey将执行初始启动,进入到一个测试Activity,然后不会再进一步生成事件。为了得到最佳结果,把它与-v、一个或几个包约 束、以及一个保持Monkey运行30秒或更长时间的非零值联合起来,从而提供一个环境,可以监视应用程序所调用的包之间的转换。

--hprof
设置此选项,将在Monkey事件序列之前和之后立即生成profiling报告。这将会在data/misc中生成大文件(~5Mb),所以要小心使用它。

--ignore-crashes
通常,当应用程序崩溃或发生任何失控异常时,Monkey将停止运行。如果设置此选项,Monkey将继续向系统发送事件,直到计数完成。

--ignore-timeouts
通常,当应用程序发生任何超时错误(如“Application Not Responding”对话框)时,Monkey将停止运行。如果设置此选项,Monkey将继续向系统发送事件,直到计数完成。

--ignore-security-exceptions
通常,当应用程序发生许可错误(如启动一个需要某些许可的Activity)时,Monkey将停止运行。如果设置了此选项,Monkey将继续向系统发送事件,直到计数完成。

--kill-process-after-error
通常,当Monkey由于一个错误而停止时,出错的应用程序将继续处于运行状态。当设置了此选项时,将会通知系统停止发生错误的进程。注意,正常的(成功的)结束,并没有停止启动的进程,设备只是在结束事件之后,简单地保持在最后的状态。

--monitor-native-crashes
监视并报告Android系统中本地代码的崩溃事件。如果设置了--kill-process-after-error,系统将停止运行。

--wait-dbg
停止执行中的Monkey,直到有调试器和它相连接


实例,通过上面的讲解后,使用命令行来运行,结果如下:

monkey -p com.android.easou -c android.intent.category.LAUNCHER -v 500
:Monkey: seed=0 count=500
:AllowPackage: com.android.easou
:IncludeCategory: android.intent.category.LAUNCHER
// Event percentages:
//   0: 15.0%
//   1: 10.0%
//   2: 15.0%
//   3: 25.0%
//   4: 15.0%
//   5: 2.0%
//   6: 2.0%
//   7: 1.0%
//   8: 15.0%
:Switch: #Intent;action=android.intent.action.MAIN;category=android.intent.category.LAUNCH
ER;launchFlags=0x10000000;component=com.android.easou/.EasouSearchActivity;end
    // Allowing start of Intent { act=android.intent.action.MAIN cat=[android.intent.categ
ory.LAUNCHER] cmp=com.android.easou/.EasouSearchActivity } in package com.android.easou
:Sending Pointer ACTION_MOVE x=-4.0 y=2.0
:Sending Pointer ACTION_UP x=0.0 y=0.0
:Sending Pointer ACTION_DOWN x=47.0 y=122.0
:Sending Pointer ACTION_UP x=29.0 y=129.0
:Sending Pointer ACTION_DOWN x=15.0 y=99.0
:Sending Pointer ACTION_UP x=15.0 y=99.0
:Sending Pointer ACTION_DOWN x=55.0 y=63.0
    // Rejecting start of Intent { act=android.intent.action.VIEW dat=http://ad3.easou.com
:8080/j10ad/ea2.jsp?channel=2&cid=bkcn3510_&key=jarw.+%E8%BD%BD%E6%89%8B+AT%27s+a%3A%28..%
E6%9C%BA%E7%94%B5%E8%A7%86+x cmp=com.android.browser/.BrowserActivity } in package com.and
roid.browser
:Sending Pointer ACTION_UP x=50.0 y=53.0
:Sending Pointer ACTION_MOVE x=-5.0 y=3.0
:Sending Pointer ACTION_MOVE x=0.0 y=-5.0
    // Rejecting start of Intent { act=android.intent.action.MAIN cat=[android.intent.cate
gory.HOME] cmp=com.android.launcher/.Launcher } in package com.android.launcher
:Sending Pointer ACTION_DOWN x=74.0 y=41.0
:Sending Pointer ACTION_UP x=74.0 y=41.0
:Sending Pointer ACTION_MOVE x=3.0 y=-2.0
:Sending Pointer ACTION_UP x=0.0 y=0.0
:Sending Pointer ACTION_MOVE x=-4.0 y=2.0
    // Sending event #100
:Sending Pointer ACTION_MOVE x=4.0 y=2.0
:Sending Pointer ACTION_DOWN x=69.0 y=310.0
:Sending Pointer ACTION_UP x=82.0 y=-10.0
:Sending Pointer ACTION_MOVE x=0.0 y=-1.0
:Sending Pointer ACTION_DOWN x=54.0 y=79.0
:Sending Pointer ACTION_UP x=54.0 y=79.0
:Sending Pointer ACTION_DOWN x=118.0 y=197.0
:Sending Pointer ACTION_UP x=119.0 y=193.0
:Sending Pointer ACTION_DOWN x=137.0 y=38.0
:Sending Pointer ACTION_UP x=124.0 y=49.0
:Sending Pointer ACTION_DOWN x=18.0 y=83.0
:Sending Pointer ACTION_UP x=33.0 y=83.0
:Sending Pointer ACTION_MOVE x=-5.0 y=-5.0
    // Sending event #200
    // Sending event #200
:Sending Pointer ACTION_MOVE x=3.0 y=2.0
:Sending Pointer ACTION_UP x=0.0 y=0.0
:Sending Pointer ACTION_DOWN x=146.0 y=307.0
:Sending Pointer ACTION_UP x=146.0 y=307.0
:Sending Pointer ACTION_DOWN x=58.0 y=305.0
:Sending Pointer ACTION_UP x=58.0 y=305.0
:Switch: #Intent;action=android.intent.action.MAIN;category=android.intent.category.LAUNCH
ER;launchFlags=0x10000000;component=com.android.easou/.EasouSearchActivity;end
    // Allowing start of Intent { act=android.intent.action.MAIN cat=[android.intent.categ
ory.LAUNCHER] cmp=com.android.easou/.EasouSearchActivity } in package com.android.easou
:Sending Pointer ACTION_DOWN x=163.0 y=3.0
:Sending Pointer ACTION_UP x=163.0 y=3.0
:Sending Pointer ACTION_MOVE x=0.0 y=4.0
:Sending Pointer ACTION_DOWN x=131.0 y=305.0
:Sending Pointer ACTION_UP x=131.0 y=305.0
:Sending Pointer ACTION_MOVE x=1.0 y=0.0
    // Allowing start of Intent { cmp=com.android.easou/.SetActivity } in package com.andr
oid.easou
:Sending Pointer ACTION_DOWN x=0.0 y=293.0
    // Allowing start of Intent { cmp=com.android.easou/.SearchSetActivity } in package co
m.android.easou
:Sending Pointer ACTION_UP x=0.0 y=293.0
:Sending Pointer ACTION_MOVE x=1.0 y=-1.0
:Sending Pointer ACTION_MOVE x=-4.0 y=-1.0
    // Rejecting start of Intent { act=android.intent.action.CALL_BUTTON cmp=com.android.c
ontacts/.DialtactsActivity } in package com.android.contacts
:Sending Pointer ACTION_DOWN x=188.0 y=34.0
:Sending Pointer ACTION_UP x=188.0 y=34.0
:Sending Pointer ACTION_MOVE x=2.0 y=-4.0
    // Sending event #300
    // Rejecting start of Intent { act=android.intent.action.MAIN cat=[android.intent.cate
gory.HOME] cmp=com.android.launcher/.Launcher } in package com.android.launcher
:Sending Pointer ACTION_MOVE x=-3.0 y=4.0
:Sending Pointer ACTION_DOWN x=164.0 y=211.0
:Sending Pointer ACTION_UP x=164.0 y=211.0
:Sending Pointer ACTION_DOWN x=83.0 y=258.0
:Sending Pointer ACTION_UP x=83.0 y=258.0
:Sending Pointer ACTION_MOVE x=-2.0 y=3.0
:Sending Pointer ACTION_MOVE x=2.0 y=-1.0
:Sending Flip keyboardOpen=false
:Sending Pointer ACTION_DOWN x=193.0 y=137.0
:Sending Pointer ACTION_UP x=178.0 y=139.0
:Sending Pointer ACTION_DOWN x=215.0 y=131.0
:Sending Pointer ACTION_UP x=215.0 y=131.0
:Sending Pointer ACTION_MOVE x=2.0 y=-3.0
:Sending Pointer ACTION_DOWN x=9.0 y=305.0
:Sending Pointer ACTION_UP x=9.0 y=305.0
:Sending Pointer ACTION_DOWN x=233.0 y=176.0
:Sending Pointer ACTION_UP x=232.0 y=185.0
:Sending Pointer ACTION_DOWN x=225.0 y=316.0
:Sending Pointer ACTION_UP x=225.0 y=316.0
    // Sending event #400
:Sending Pointer ACTION_MOVE x=4.0 y=3.0
:Sending Pointer ACTION_DOWN x=12.0 y=310.0
:Sending Pointer ACTION_UP x=12.0 y=310.0
:Sending Pointer ACTION_MOVE x=2.0 y=-1.0
:Sending Pointer ACTION_DOWN x=129.0 y=234.0
:Sending Pointer ACTION_UP x=129.0 y=234.0
:Sending Pointer ACTION_DOWN x=45.0 y=292.0
:Sending Pointer ACTION_UP x=45.0 y=292.0
:Sending Pointer ACTION_MOVE x=2.0 y=2.0
:Sending Pointer ACTION_DOWN x=219.0 y=139.0
:Sending Pointer ACTION_UP x=219.0 y=139.0
:Sending Pointer ACTION_MOVE x=-4.0 y=1.0
:Sending Pointer ACTION_DOWN x=217.0 y=224.0
:Sending Pointer ACTION_UP x=217.0 y=224.0
:Sending Pointer ACTION_DOWN x=64.0 y=5.0
:Sending Pointer ACTION_UP x=64.0 y=6.0
:Sending Pointer ACTION_MOVE x=1.0 y=3.0
:Sending Pointer ACTION_MOVE x=-2.0 y=-3.0
Events injected: 500
:Dropped: keys=0 pointers=2 trackballs=0 flips=0
## Network stats: elapsed time=21118ms (0ms mobile, 0ms wifi, 21118ms not connected)
// Monkey finished