• Monkey Test 命令使用


    引用:http://blog.csdn.net/gzh0222/article/details/6631988

    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  

  • 相关阅读:
    第四次作业--项目选题报告(团队)
    第三次作业--团队展示(团队)
    第二次作业——个人项目实战
    2017软件工程实践
    Unity3D游戏开发——显示物品的仓库UI
    Unity3D游戏开发——物品存储:List与Dictionary
    Unity3D游戏开发——编程实现游戏管理器
    Unity3D游戏开发——访问集中式共享模块的设计模式
    Unity3D游戏开发——收集当前关卡游戏中分散的物件
    福州大学软工1816 K 班助教总结
  • 原文地址:https://www.cnblogs.com/sode/p/2844337.html
Copyright © 2020-2023  润新知