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
四大类—— 常用选项、事件选项、约束选项、调试选项
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。
-c:activity必须至少包含一个指定的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
6、monkey作用的包:com.ckt.android.junit
产生时间序列的种子值:500
忽略程序崩溃 、 忽略超时 、 监视本地程序崩溃 、 详细信息级别为2 , 产生 10000个事件 。
Monkey测试的og分析,我们可以通过几个关键词来判断测试是否通过。
1)Monkey finished
打开LOG,查看log的最下端,是否有类似以下字段:
## Network stats: elapsed time=5123ms (5123ms mobile, 0ms wifi, 0ms not connected)
// Monkey finished
这个字段表明本次的Monkey没有异常,测试通过。
2)CRASH
同样,在得到LOG后,搜索”CRASH”字段,如果搜索到有结果,则表明有进程出现问题,测试不通过。
// CRASH: com.onekchi.downloadmanager (pid 12919)
3)ANR
在Log中搜素该字段,如果有搜索有结果,则表示测试过程中,测试对象出现了无响应的现象,因此测试不通过。--throttle <毫秒>值建议为500
4)无法搜索到上述信息
出现这种情况,一般都是外界原因而非程序本身原因。比如电脑异常测试中断,需要重新测试。