1.  命令使用

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

Ø        基本配置选项,如设置测试的事件数量。

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

Ø        事件类型和频率。

Ø        调试选项。

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

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

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

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

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

类别

选项

说明

常规

--help

列出简单的用法。

-v

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

一般,一个v就足够了

事件

-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还可以执行脚本:官网上没有详细介绍,在网络上有简单介绍

http://groups.google.com/group/android-developers/browse_thread/thread/44522b92a6796d3

http://programfeelings.blogspot.com/2010/04/monkey-script-test.html

一般此命令用的很少。

简而言之,Helen_Fu的方法可作为一般测试的常用方法。

Focus AP:
$ adb shell monkey  --throttle 1000 -p your.package.name -v 45001
adb shell monkey  -p com.risingsun.ktool  --throttle 10 -s 100  -v 45001  
 
Full Monkey Test:
$ adb shell monkey  --throttle 1000 -v 90001

但是对于时间的测试方法,我觉得不是很合理例如:

$ adb shell monkey  --throttle 1000 -v 90001
1000:事件产生的时间间隔。
90001:产生事件的数量。

共90001个事件,每个事件发生后休息一秒,再产生下一事件,相当于测试时间= 1000 × 90001ms=90001s

指定每次事件后的延迟时间(--throttle 1000)实际上加入了人为的假定,即假设Monkey内建的事件产生间隔也为1s。我认为应该采用Monkey默认的事件间隔,指定一个较大的事件产生个数,是足以满足测试时间的。难点在于这个测试时间比较难估计,我想多测试几次,应该能有结果。例如:

我先指定测试500次,看看monkey几秒执行完毕。假设执行500次事件,monkey耗时n秒。那么测试时间12h,测指定测试事件个数为(12*3600*500*impact_factor))/n,其中impact_facor为影响因子(或安全系数),保证测试时长>=12h。

其次Full Monkey Test,指的是对所有应用的package进行测试,而不应该认为Monkey能测试系统。

2.  Debug分析

网上有比较多的测试结果分析

推荐:http://www.cnblogs.com/wfh1988/archive/2010/11/16/1878224.html

monkey -pcom.example.android.apis  -v -v -v 100

:Monkey: seed=0 count=100

:AllowPackage: com.example.android.apis

IncludeCategory:android.intent.category.LAUNCHER

IncludeCategory:android.intent.category.MONKEY

//种事件所占的比例。

//各数字分别表示:

[--pct-touch PERCENT]

[--pct-motion PERCENT]

[--pct-trackball PERCENT]

[--pct-syskeys PERCENT]

[--pct-nav PERCENT]

[--pct-majornav PERCENT]

[--pct-appswitch PERCENT]

[--pct-flip PERCENT]

[--pct-anyevent PERCENT]

// 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:

//表示跳转到com.example.android.apis里面的ApiDemos这一个Activity里。

#Intent;action=android.intent.action.MAIN;category=android.intent.category.LAUNCHER;launchFlags=0x10000000;component=com.example.android.apis/.ApiDemos;end

//允许此Intent跳转,

// Allowing start ofIntent { act=android.intent.action.MAIN

//cat=[android.intent.category.LAUNCHER]cmp=com.example.android.apis/.ApiDemos } in

//packagecom.example.android.apis

//发送的一些动作,如点击按下,点击放开,移动。

: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=207.0y=282.0

:Sending Pointer ACTION_UP x=189.0 y=289.0

079 :Sending Pointer ACTION_DOWN x=95.0y=259.0

080 :Sending Pointer ACTION_UP x=95.0y=259.0

081 :Sending Pointer ACTION_DOWN x=295.0y=223.0

082 :Sending Pointer ACTION_UP x=290.0y=213.0

083 :Sending Pointer ACTION_MOVE x=-5.0y=3.0

084 :Sending Pointer ACTION_MOVE x=0.0y=-5.0

//拒绝此跳转,因为它是跳转到非它自己的包的Activity,本测试中是指写测试它程序所在的包,此跳转是跳出本程序,进入到桌面。

// Rejecting start ofIntent { act=android.intent.action.MAIN cat=[android.intent.category.HOME]

//cmp=com.android.launcher/.Launcher} in package com.android.launcher

//继续发送动作。

:Sending Pointer ACTION_DOWN x=74.0 y=201.0

:Sending Pointer ACTION_UP x=74.0 y=201.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

Events injected: 100

//丢弃的,键=0,指针=0,轨迹球=0,翻转=0。

:Dropped: keys=0 pointers=0 trackballs=0flips=0

//网络统计经过时间为4202ms,其中4202ms是用于在手机上的,0ms用于无线网络上,没

//有连接的时间为0ms。

## Network stats: elapsed time=4202ms(4202ms mobile, 0ms wifi, 0ms not connected)

//monkey测试完成。

// Monkey finished

05-11 17:42