安卓monkey简介
-
Monkey是一款安卓自带的、java编写的app自动化测试工具,monkey是猴子的意思,所以从原理上说,它的自动化测试就类似猴子一样在软件上乱敲按键,猴子什么都不懂,就爱捣乱。Monkey原理也是类似,通过向系统发送伪随机的用户事件流(如按键输入、触摸屏输入、滑动Trackball、手势输入等操作),来对设备上的程序进行测试,检测程序长时间的稳定性,多久的时间会发生异常。 -
主要目的:测试 app 是否会是否会 Crash。模拟器:夜神,逍遥
路径地址
通过adb shell 进入路径:/system/framework可以找到monkey.jar;/system/bin可以找到monkey
C:\Users\duxiaowei>adb shell pm list packages|findstr tyjh package:com.tyjh.lightchain
查看安卓手机包路径 :pm list packages -f
获取所有包名:adb shell pm list package
获取第三方包名:adb shell pm list package -3
adb logcat | findstr START 输入该命令,然后点击要启动的app,即可获取到包名和activity
调试
-
配置 1.开发者模式:关于设备 —> MIUI版本,连续点击5-7次,开发者模式 2.USB调试:开发者模式—>打开USB调试 ? oppo、华为:选项长时间不操作手机,自动断开USB调试 3.链接手机,USB/WIFI(adb-connecter)同一个局域网 4.cmd:adb devices回撤 ? devices:表示正常 ? offline:插拔USB即可 模拟器–>模拟器升级到最新版本 ? no device: 驱动 ? unauthorized:表示未授权,允许授权即可
-
端口占用:netstat -ano |findstr “5037” 360/手机助手,容易出现占用端口 USB线:数据传输,adb驱动
操作命令
-
参数
1.count 事件数,必填
2.[][][–ignore-crashes] [–ignore-timeouts] [–ignore-security-exceptions]
crashes:崩溃,闪退;
timeouts: 超时,无响应
如果使用这个参数,发生崩溃或者无响应的时候,会结束应用进程,从新打开继续执行,直到事件次数结束
不使用该参数:发生上述问题,monkey测试停止在问题界面–缺乏稳定性测试的意义
一般是使用该参数的
-
参数
基础参数:
-p 指定包名
-v 表示反馈信息的级别,打印 log 级别,-v 越多日志信息越详细,最多支持 3 个 -v -v -v ,例如:华为手机100万次 -v -v -v
-s 如果用相同的seed值再次运行monkey,将生成相同的事件序列;每个seed可能发生N个bug,不利于测试稳定性,所以要唯一指定!
–throttle 在事件之间插入固定的时间(毫秒)延迟,你可以使用这个设置来减缓Monkey的运行速度,如果你不指定这个参数,则事件之间将没有延迟,事件将以最快的速度生成。
-f:后接测试脚本名
adb shell monkey -p com.tyjh.lightchain -s 110 -v -v -v 500
usage: monkey [-p ALLOWED_PACKAGE [-p ALLOWED_PACKAGE] …] [-c MAIN_CATEGORY [-c MAIN_CATEGORY] …] [–ignore-crashes] [–ignore-timeouts] [–ignore-security-exceptions] [–monitor-native-crashes] [–ignore-native-crashes] [–kill-process-after-error] [–hprof] [–match-description TEXT] [–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] [–pct-pinchzoom PERCENT] [–pct-permission PERCENT] [–pkg-blacklist-file PACKAGE_BLACKLIST_FILE] [–pkg-whitelist-file PACKAGE_WHITELIST_FILE] [–wait-dbg] [–dbg-no-events] [–setup scriptfile] [-f scriptfile [-f scriptfile] …] [–port port] [-s SEED] [-v [-v] …] [–throttle MILLISEC] [–randomize-throttle] [–profile-wait MILLISEC] [–device-sleep-time MILLISEC] [–randomize-script] [–script-log] [–bugreport] [–periodic-bugreport] [–permission-target-system] COUNT
–pct-事件类别 11 个事件百分比控制
–pct-touch
作用:调整触摸事件的百分比。(触摸事件是指在屏幕中的一个down-up事件,即在屏幕某处按下并抬起的操作)
注:常用参数,此参数设置要适应当前被测应用程序的操作,比如一个应用80%的操作都是触摸,那就可以将此参数的百分比设置成相应较高的百分比。
0:点击事件百分比,即参数–pct-touch
1:滑动事件百分比,即参数–pct-motion
2:缩放事件百分比,即参数–pct-pinchzoom
3:轨迹球事件百分比,即参数–pct-trackball
4:屏幕旋转事件百分比,即参数–pct-rotation
5:基本导航事件百分比,即参数–pct-nav
6:主要导航事件百分比,即参数–pct-majornav
7:系统按键事件百分比,即参数–pct-syskeys
8:Activity启动事件百分比,即参数–pct-appswitch
9:键盘唤出隐藏事件百分比,即参数–pct-flip
10:其他事件百分比,即参数–pct-anyevent
–throttle <毫秒> 延时
指定,用户才做延时,单位:毫秒
adb shell monkey -p com.tyjh.lightchain -s 110 -v -v -v --throttle 3000 100
– randomize-throttle
在事件之间插入随机延迟,随机延迟范围从0到throttle 设置的事件,单位毫秒
adb shell monkey -p com.tyjh.lightchain -s 110 -v -v -v --throttle 5000 --randomize-throttle 100
adb shell monkey -p com.tyjh.lightchain -s 110 -v -v -v --throttle 5000 --randomize-throttle 100 > D:\apk\monkey_log.txt ;日志保存文件
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-CsHtLvl7-1631843439385)(C:\Users\duxiaowei\AppData\Roaming\Typora\typora-user-images\image-20210805173117040.png)]
黑名单不扫描的包;白名单,扫描的包
adb shell monkey -p com.tyjh.lightchain -s 110 -v -v -v --pct-touch 100 300 #全是点击事件
adb shell monkey -p com.tyjh.lightchain -s 110 -v -v -v --pct-touch 50 --pct-rotation 50 300 #百分之50点击,百分之50旋转
关闭monkey进程:
adb shell
ps
kill 3344
exit
adb?shell?monkey?-p?com.tyjh.lightchain?-s?500?--ignore-crashes?--ignore-timeouts?? --monitor-native-crashes?-v?-v?10000?>?E:\monkey_log\java_monkey_log.txt
说明:monkey作用的包:com.tyjh.lightchain?产生时间序列的种子值:500? 忽略程序崩溃?、?忽略超时?、?监视本地程序崩溃、详细信息级别为2?,?产生?10000个事件? 所产生的日志保存在:E:\monkey_log\java_monkey_log.txt
注:测试产生了日志,最重要的是要学会分析日志? 在log中搜索4种关键字加以分析:?1、crash?闪退??2、exception?异常?3、force?closed?强制退出?? 4、anr(application?no?response)?程序无响应。
实际使用
Monkey测试参数建议
间隔时间:500毫秒;
种子数:指定;
遇到错误:不停止;
执行时长:每机型不小于12小时或点击次数:100万次;
机型覆盖建议:覆盖高中低端机型
不同芯片平台(高通、海思、MTK等)
不同分辨率(480*800以上主流分辨率)
不同安卓版本(安卓4.0以上主流安卓版本);
Monkey参考命令
adb shell monkey -p com.tyjh.lightchain --throttle 500 --ignore-crashes --ignore-timeouts --ignore-security-exceptions --ignore-native-crashes -v -v -v 1000000>D:\monkey_log\monkeyScreenLog.log
测试可以发现的问题**
Android平台应用程序可能产生以下两种问题:
1、Crash
2、ANR (响应延时)
Monkey日志定位问题**
//主要Log文件说明
anr目录:从手机/data/anr导出的日志,保存发生anr crash 时的相关信息;
(1)在MonkeyScreen.Log日志文件搜索关键词“Fatal”、“Crash”、“ANR”定位到发生Crash的详细堆栈信息,或分析发生Crash前后的日志事件;
如图:
然后把相应的日志发给开发即可。
工作中monkey的使用:
日志的分析
bug的定位
bug编写规范
anr日志提取
adb logcat的使用
|