[移动端]Monkey 日常随笔

adb shell monkey -p com.enhance.kmf.words.wordsapplication --throttle 300 --ignore-crashes --monitor-native-crashes --ignore-security-exceptions --ignore-timeouts --ignore-native-crashes --pct-syskeys 20 --pct-nav 40 --pct-majornav 20 --pct-anyevent 20 -v -v -v 10000 >D:\java_monkey_log.txt

 

adb shell monkey –p com.shjt.map –-throttle 100 –-pct-touch 50 –-pct-motion 50 –v –v 1000 >c:\monkey.txt

上海公交

 

seed参数(复现)

adb shell monkey -s<seed><event-count>

 

adb shell monkey -p com.android.calculator2 -s 100 50

 

adb install app-debug_crash.apk

app

 

 

adb shell monkey -p com.enhance.kmf.words.wordsapplication --throttle 600 --ignore-crashes --monitor-native-crashes --ignore-security-exceptions --ignore-timeouts --ignore-native-crashes --pct-touch 30 --pct-motion 20 --pct-syskeys 10 --pct-nav 10 --pct-majornav 10 --pct-anyevent 10 --pct-trackball 10 -v -v -v 80000 >D:\java_monkey_log.txt

 

 

试用版,增加触摸事件,滑动事件

 

adb shell dumpsys window w | findstr \/ | findstr name=

打开应用输入命令,可查看到包名(包名为前半截)

 

--throttle 降低系统压力,间隔时间

--ignore-crashes:忽略崩溃

--monitor-native-crashes:跟踪本地方法的崩溃问题

--ignore-security-exceptions:忽略安全异常

--ignore-native-crashes忽略本地崩溃

--pct-syskeys<percent> (系统按键事件 Home Back startCall  endCall、 volumeControl)

--pct-nav<percent> (导航事件 up/down/left/right)

--pct-majornav<percent> (主要导航事件 back key  menu key)

--pct-anyevent<percent>(任意事件)

pct-trackball(轨迹球事件)

-v 打印信息的详细级别

 

CRASH”字段,如果搜索到有结果,则表明有进程出现问题,测试不通过

ANR无响应现象

Error错误

 

adb shell monkey -p com.enhance.greapp -v --throttle 500 --ignore-crashes --monitor-native-crashes --ignore-security-exceptions --ignore-timeouts --ignore-native-crashes --pct-touch 30 --pct-motion 20 --pct-nav 20 --pct-majornav 15 --pct-appswitch 5 --pct-anyevent 5 --pct-trackball 0 --pct-syskeys 0 -p ‘%s’ 5000 >D:\java_monkey_hongmilog.txt

忽略异常

 

有约未忽略异常

adb shell monkey -p com.ns.yue -v --throttle 300 --pct-touch 30 --pct-motion 20 --pct-nav 20 --pct-majornav 15 --pct-appswitch 5 --pct-anyevent 5 --pct-trackball 0 --pct-syskeys 0 -p ‘%s’ 1000 >D:\java_monkey_huawei.txt

 

 

考满分词汇未忽略异常

adb shell monkey -p com.enhance.kmf.words.wordsapplication -v -s 100 --throttle 200 --pct-touch 30 --pct-motion 20 --pct-nav 20 --pct-majornav 15 --pct-appswitch 5 --pct-anyevent 5 --pct-trackball 0 --pct-syskeys 0 -p ‘%s’ 5000 >D:\java_monkey_huawei.txt

 

考满分GAMT未忽略异常

adb shell monkey -p com.manfen.kaogmat -v --throttle 300 --pct-touch 30 --pct-motion 20 --pct-nav 20 --pct-majornav 15 --pct-appswitch 5 --pct-anyevent 5 --pct-trackball 0 --pct-syskeys 0 -p ‘%s’ 5000 >D:\java_monkey_huawei.txt

 

考满分GRE未忽略异常

adb shell monkey -p com.enhance.greapp -v --throttle 300 --pct-touch 30 --pct-motion 20 --pct-nav 20 --pct-majornav 15 --pct-appswitch 5 --pct-anyevent 5 --pct-trackball 0 --pct-syskeys 0 -p ‘%s’ 5000 >D:\java_monkey_huawei.txt

 

 

 

间隔时间

触摸事件

滑动事件

导航事件

--pct-majornav 30

活动切换

任意事件

轨迹球事件

系统按键事件

-p指定app限制

随机指定事件

 

 

随机触摸操作百分之50,轨迹球操作百分之30,其它操作百分之20,总共进行10000次随机点击,事件之间间隔300ms

adb shell monkey -p com.tongbanjie.android -v -v -v -pct-touch 50 -pct-trackball 30 -throttle 300 10000

 

 

 

adb shell monkey -v -v -v -p [PackageName] --ignore-crashes --ignore-timeouts --ignore-security-exceptions --monitor-native-crashes --ignore-native-crashes --throttle 1000 100000 > monkey.txt

 

 

 

 

 

 

 

monkeymonkey命令详解

四大类—— 常用选项、事件选项、约束选项、调试选项

1、常用选项

--help:打印帮助信息

-v:指定打印信息的详细级别,一个-v增加一个级别 ,默认级别为 0 。用于指定反馈信息级别(信息级别就是日志的详细程度),总共分3个级别。

日志级别 Level 0

缺省值,仅提供启动提示、测试完成和最终结果等少量信息

日志级别 Level 1

提供较为详细的日志,包括每个发送到Activity的事件信息

日志级别 Level 2

最详细的日志,包括了测试中选中/未选中的Activity信息

2、事件选项

-s:指定产生随机事件种子值,相同的种子值产生相同的事件序列。如: -s 200

--throttle:每个事件结束后的间隔时间——降低系统的压力(如不指定,系统会尽快的发送事件序列)。如:--throttle 100

--pct-touch:指定触摸事件的百分比,如:--pct-touch 5% , 相关的还有以下option

--pct-motion <percent> (滑动事件)、 --pct-trackball <percent> (轨迹球事件) 、 --pct-nav<percent> (导航事件 up/down/left/right)、 --pct-majornav<percent> (主要导航事件 back key  menu key) --pct-syskeys<percent> (系统按键事件 Home Back startCall  endCall  volumeControl) --pct-appswitch<percent> activity之间的切换)、 --pct-anyevent<percent>(任意事件)

3、约束选项

-p:指定有效的package(如不指定,则对系统中所有package有效),一个-p 对应一个有效package, 如:-p com.ckt -p com.ckt.asura

参数-p用于约束限制,用此参数指定一个或多个包(Package,即App)。指定包之后,Monkey将只允许系统启动指定的APP。如果不指定包,Monkey将允许系统启动设备中的所有APP

-cactivity必须至少包含一个指定的category,才能被启动,否则启动不了。

4、调试选项

--dbg-no-events:初始化启动的activity,但是不产生任何事件。

--hprof:指定该项后在事件序列发送前后会立即生成分析报告  —— 一般建议指定该项。

--ignore-crashes:忽略崩溃

--ignore-timeouts:忽略超时

--ignore-security-exceptions:忽略安全异常

--kill-process-after-error:发生错误后直接杀掉进程

--monitor-native-crashes:跟踪本地方法的崩溃问题

--wait-dbg:知道连接了调试器才执行monkey测试。

5、一个简单的monkey命令:

adb shell monkey -p com.xy.android.junit -s 500 -v 10000

但是,工作中为了保证测试数量的完整进行,我们一般不会在发生错误时立刻退出压力测试。monkey 测试命令如下

adb shell monkey -p com.xy.android.junit -s 500 --ignore-crashes --ignore-timeouts --monitor-native-crashes -v -v 10000 > E:\monkey_log\java_monkey_log.txt

6monkey作用的包:com.ckt.android.junit

产生时间序列的种子值:500

忽略程序崩溃 忽略超时 监视本地程序崩溃 详细信息级别为 产生 10000个事件 。

 

 

Monkey测试的og分析,我们可以通过几个关键词来判断测试是否通过。

1Monkey finished
打开LOG,查看log的最下端,是否有类似以下字段:
## Network stats: elapsed time=5123ms (5123ms mobile, 0ms wifi, 0ms not connected)
// Monkey finished
这个字段表明本次的Monkey没有异常,测试通过。

2CRASH


同样,在得到LOG后,搜索”CRASH”字段,如果搜索到有结果,则表明有进程出现问题,测试不通过。
// CRASH: com.onekchi.downloadmanager (pid 12919)

3ANR
Log中搜素该字段,如果有搜索有结果,则表示测试过程中,测试对象出现了无响应的现象,因此测试不通过。--throttle <毫秒>值建议为500

4)无法搜索到上述信息
出现这种情况,一般都是外界原因而非程序本身原因。比如电脑异常测试中断,需要重新测试。

 [移动端]Monkey 日常随笔

[移动端]Monkey 日常随笔

 

[移动端]Monkey 日常随笔

上一篇:StringBuffer与StringBuilder有什么区别


下一篇:安卓ADB学习笔记