Monkey系列之02--命令详解


本文主要介绍Monkey的相关命令,具体Monkey的操作,详见本系列的第一篇文章

1、包名指定:

可以指定一个,可以指定多个,也可以不指定,随机去操作

不指定包名:adb shell monkey   -v 500  >F:/monkeylog2018.txt,随机500个事件执行,没有具体的包,在手机上随机操作各种app或系统功能,下图日志里,using了各种app的activity,相当于是对整机进行测试

不指定包

指定一个包名的命令:adb shell monkey -p com.aaa.aaaaaaaa  -v 500 >F:/monkeylog2018.txt,直接对aaa这个app进行500次随机事件并写入txt

指定多个包名的命令:adb shell monkey -p com.aaa.aaaaaaaa  -p com.bbb.bbbbb -v 500 >F:/monkeylog2018.txt  两次指定两个包名,合计执行500次随机事件,写入日志文档。在log里可以看到using两个activity

指定两个包

2、日志级别:

分为Level0-Level2三个级别,0仅提供启动提示、测试完成和最终结果等少量信息,1提供较为详细的日志,包括每个发送到Activity的事件信息,2最详细的日志,包括了测试中选中/未选中的Activity信息。用-v表示,想用几级就指定几个-v

Level0:adb shell monkey   -v 500  >F:/monkeylog2018.txt

Level1:adb shell monkey   -v  -v  500  >F:/monkeylog2018.txt

Level2:adb shell monkey   -v  -v  -v  500  >F:/monkeylog2018.txt

上图也是level2级别的日志效果,会详细显示哪些包被using了,哪些被拒绝using了,如果是0级别的,则看不到这些信息

3、SEED值:

用于指定伪随机数生成器的seed值,如果seed相同,则两次Monkey测试所产生的事件序列也相同的,用-s参数。

Monkey测试1:adb shell monkey -p com.htc.Weather –s 10 100

Monkey测试2:adb shell monkey -p com.htc.Weather –s 10 100

-s 10 前后两条命令相同,那么其随机的内容也是相同的,这样可以在对比测试的时候用到

4、时延控制:

用于指定用户操作间的时延,单位是毫秒,用--throttle参数,注意是两个减号

adb shell monkey -p com.huawei.Weather –throttle 3000 100,此命令是随机100次事件,但是每次需要延迟3秒做下一个动作,这样可以给app留有响应时间,连网时间,加载时间,否则事件发送太快,来不及响应就要执行下一个事件,会导致结果不准确,类似LR里面的思考时间

上面的命令执行后,在日志里会看到这样的记录:Sleeping for 3000 milliseconds,同时在手机界面上也会有直观的感应,各种点击操作都会有3秒的延时

5、忽略执行:

--ignore-crashes:

忽略崩溃:用于指定当应用程序崩溃时(Force & Close错误),Monkey是否停止运行。如果使用此参数,即使应用程序崩溃,Monkey依然会发送事件,直到事件计数完成。

示例1:adb shell monkey -p com.huawei.Weather --ignore-crashes 1000     测试过程中即使Weather程序崩溃,Monkey依然会继续发送事件直到事件数目达到1000为止;

示例2:adb shell monkey -p com.huawei.Weather 1000      测试过程中,如果Weather程序崩溃,Monkey将会停止运行。

--ignore-timeouts:

忽略超时:用于指定当应用程序发生ANR(Application No Responding)错误时,Monkey是否停止运行。如果使用此参数,即使应用程序发生ANR错误,Monkey依然会发送事件,直到事件计数完成。adb shell monkey -p com.huawei.Weather --ignore-timeouts 1000

--ignore-security-exceptions:

忽略安全异常:用于指定当应用程序发生许可错误时(如证书许可,网络许可等),Monkey是否停止运行。如果使用此参数,即使应用程序发生许可错误,Monkey依然会发送事件,直到事件计数完成。adb shell monkey -p com.huawei.Weather --ignore-security-exceptions 1000

--kill-process-after-error:

发生错误后直接杀掉进程:用于指定当应用程序发生错误时,是否停止其运行。如果指定此参数,当应用程序发生错误时,应用程序停止运行并保持在当前状态(注意:应用程序仅是静止在发生错误时的状态,系统并不会结束该应用程序的进程)。adb shell monkey -p com.huawei.Weather --kill-process-after-error 1000

--monitor-native-crashes:

跟踪本地方法崩溃问题:用于指定是否监视并报告应用程序发生崩溃的本地代码,adb shell monkey -p com.huawei.Weather --kill-process-after-error  --monitor-native-crashes 1000

6、指定事件百分比:

用于指定每种类别事件的数目百分比(在Monkey事件序列中,该类事件数目占总事件数目的百分比),虽然事件是随机的,但是你可以指定其中某种动作的比例,根据app的特点而进行设置,某些app滑动多,某些app点击多,这样可以更贴近app应用场景的设置随机事件进行测试

--pct-{+事件类别} {+事件类别百分比}:

--pct-touch {+百分比}:触摸事件:adb shell monkey -p com.huawei.Weather --pct-touch 10 1000

--pct-motion {+百分比}:动作事件:adb shell monkey -p com.huawei.Weather --pct-motion10 1000

--pct-trackball {+百分比}:轨迹事件:adb shell monkey -p com.huawei.Weather --pct-trackball 10 1000

--pct-nav {+百分比}:基本导航:adb shell monkey -p com.huawei.Weather --pct-nav 10 1000

--pct-majornav {+百分比}:主要导航:adb shell monkey -p com.huawei.Weather --pct-majornav 10 1000

--pct-syskeys {+百分比}:系统按键:adb shell monkey -p com.huawei.Weather --pct-syskeys 10 1000

--pct-appswitch {+百分比}:启动activity(日志里见过这个switch吧):adb shell monkey -p com.huawei.Weather --pct-appswitch  10 1000

--pct-anyevent {+百分比}:其他事件:

指定单个类型事件的百分比:

adb shell monkey -p com.huawei.Weather --pct -anyevent 20  1000

指定多个类型事件的百分比:

adb shell monkey -p com.huawei.Weather --pct-anyevent 30  --pct-appswitch 30   1000

注意:各事件类型的百分比总数不能超过100%

总结:

本文中所举的栗子都是单个参数的命令,实际使用过程中,大部分是组合命令,比如指定包,日志级别,忽略报错等参与组合放在一条命令里执行的

adb shell monkey -p com.aaa.aaaaa -v -v -v --throttle 500 --pct-anyevent 100 5000 >F:/monkeylog.txt

adb shell monkey -p com.aaa.aaaaa -s 23  --throttle 2000 --ignore-crashes --ignore-timeouts -v -v -v 100000 >F:/monkeylog.txt

Monkey架构图



最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,847评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,208评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,587评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,942评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,332评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,587评论 1 218
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,853评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,568评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,273评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,542评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,033评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,373评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,031评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,073评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,830评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,628评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,537评论 2 269

推荐阅读更多精彩内容