Monkey Test 命令使用

1.  命令使用

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

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

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

Ø        事件类型和频率。api

Ø        调试选项。安全

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

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

Ø        若是应用程序崩溃或接收到任何失控异常,Monkey将中止并报错。 工具

Ø        若是应用程序产生了应用程序不响应(applicationnot responding)的错误,Monkey将会中止并报错。测试

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

 

 

 

类别

选项

说明

常规

--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  -p your.package.name -v 45001--throttle 1000
adb shell monkey -p com.risingsun.ktool  -v 45001   --throttle 10 -s 100  
 
Full Monkey Test:
$ adb shell monkey   -v 90001--throttle 1000

 

可是对于时间的测试方法,我以为不是很合理例如:

$ adb shell monkey   -v 90001--throttle 1000
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 

相关文章
相关标签/搜索