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