一、Monkey 是什么? Monkey 就是SDK中附带的一个工具。
二、Monkey 测试的目的? :该工具用于进行压力测试。 然后开发人员结合monkey 打印的日志 和系统打印的日志,结局测试中出现的问题。
三、Monkey 测试的特点? Monkey 测试,所有的事件都是随机产生的,不带任何人的主观性。
四、Monkey 命令详解
1).标准的monkey 命令 [adb shell] monkey [options] <eventcount> , 例如: adb shell monkey -v 500 --------产生500次随机事件,作用在系统中所有activity(其实也不是所有的activity,而是包含 Intent.CATEGORY_LAUNCHER 或Intent.CATEGORY_MONKEY 的activity)。 上面只是一个简单的例子,实际情况中通常会有很多的options 选项 2).四大类—— 常用选项 、 事件选项 、 约束选项 、 调试选项 1:常用选项
2:事件选项
3:约束选项
4:调试选项
五、一个简单的monkey命令:
但是,工作中为了保证测试数量的完整进行,我们一般不会在发生错误时立刻退出压力测试。monkey 测试命令如下:
例如:
adb shell monkey -p com.xy.android.junit -s 500 --ignore-crashes --ignore-timeouts --monitor-native-crashes -v -v -v 10000 > E:\monkey_log\java_monkey_log.txt
说明:monkey作用的包:com.xy.android.junit 产生时间序列的种子值:500 忽略程序崩溃 、 忽略超时 、 监视本地程序崩溃、详细信息级别为3 , 产生 10000个事件 所产生的日志保存在:E:\monkey_log\java_monkey_log.txt
注:测试产生了日志,最重要的是要学会分析日志 在log中搜索4种关键字加以分析: 1、crash 闪退 2、exception 异常 3、force closed 强制退出 4、anr(application no response) 程序无响应
monkey 脱离PC 独立运行
1 连接设备和PC
2 adb shell 命令进入命令行模式
3 输入 logcat 命令(日志文件的地址使用> /sdcard/logcat_x.log),最后带上& 符号,回车
如:logcat -v time >/sdcard/logcat_x.log &
4 输入 monkey 命令(日志文件的地址使用> /sdcard/monkey_x.txt),最后也带上&符号,回车
如:monkey -p packageName --throttle 500 -v -v -v 1000000 >/sdcard/monkey.log &
--throttle 500 //每一次的事件延迟为500毫秒
1000000 //执行1000000次
对于其余的monkey命令的参数可以自己再进行添加
5 此时monkey开始运行,拔掉设备和PC的数据线
6 同时需确认logcat和monkey的日志记录ok(重新连接设备和PC,通过adb shell,进入sdcard,使用 ls –l查看,logcat和monkey日志文件的大小不断变化即ok)
来源:https://www.cnblogs.com/Peng-study/p/12304750.html