赞
踩
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:后接测试脚本名
# 简单的测试 -p 指定包,-s 指定测试id号, -v日志打印详细程度
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 #进程号3344
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前后的日志事件;
如图:
然后把相应的日志发给开发即可。
日志的分析
bug的定位
bug编写规范
anr日志提取
adb logcat的使用
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。