【APP】Monkey、logcat命令

Monkey是Android平台上的一个自动化测试工具,主要用于测试应用的稳定性和健壮性。它通过随机生成用户事件来模拟用户操作。文章详细介绍了Monkey测试的参数用法,如指定测试包、日志级别、事件类型比例以及如何处理异常。同时,提到了如何通过adbshell命令行进行Monkey测试,以及如何分析测试结果和使用logcat查看日志来诊断问题。
摘要由CSDN通过智能技术生成

monkey

monkey主要用于app稳定性、健壮性测试,原理出发随机事件

adb shell monkey -v -v -p com.mobil.onsesa -s 12345 5000

参数 -p

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

指定一个包: adb shell monkey -p cn.emoney.acg 10
指定多个包:adb shell monkey -p cn.emoney.acg –p cn.emoney.wea -p cn.emoney.acg 100
不指定包:adb shell monkey 100
参数 -v

用于指定反馈信息级别(信息级别就是日志的详细程度),总共分3个级别,分别对应的参数如下表所示

日志级别 Level0 
示例 adb shell monkey -p cn.emoney.acg –v 100
说明 缺省值,仅提供启动提示、测试完成和最终结果等少量信息

日志级别 Level 1
示例 adb shell monkey -p cn.emoney.acg –v -v 100
说明 提供较为详细的日志,包括每个发送到Activity的事件信息

日志级别 Level 2
示例 adb shell monkey -p cn.emoney.acg –v -v –v 100
说明 最详细的日志,包括了测试中选中/未选中的Activity信息
参数 -s

用于指定伪随机数生成器的seed值,如果seed相同,则两次Monkey测试所产生的事件序列也相同的
用于复现bug

Monkey 测试1:adb shell monkey -p cn.emoney.acg –s 10 100
Monkey 测试2:adb shell monkey -p cn.emoney.acg –s 10 100
事件类别参数 ptc

–pct-touch {+百分比}触摸
调整触摸事件的百分比(触摸事件是一个down-up事件,它发生在屏幕上的某单一位置)

db shell monkey -p cn.emoney.acg --pct-touch 10 1000

–pct-motion {+百分比}滑动
调整动作事件的百分比(动作事件由屏幕上某处的一个down事件、一系列的伪随机事件和一个up事件组成)

adb shell monkey -p cn.emoney.acg --pct-motion 20 1000

–pct-trackball {+百分比}轨迹球,现在没有了
调整轨迹事件的百分比(轨迹事件由一个或几个随机的移动组成,有时还伴随有点击)

adb shell monkey -p cn.emoney.acg --pct-trackball 30 1000

–pct-nav {+百分比} 手机上的导航按钮,返回 home之类
调整“基本”导航事件的百分比(导航事件由来自方向输入设备的up/down/left/right组成

adb shell monkey -p cn.emoney.acg --pct-nav 40 1000
忽略–ignore

–ignore-crashes 忽略奔溃事件

adb shellmonkey -p cn.emoney.acg --ignore-crashes 1000
测试过程中即使acg程序崩溃,Monkey依然会继续发送事件直到事件数目达到1000为止

adb shellmonkey -p cn.emoney.acg 1000
测试过程中,如果acg程序崩溃,Monkey将会停止运行

–ignore-timeouts 忽略超时事件

adb shellmonkey -p cn.emoney.acg --ignore-timeouts 1000

–ignore-security-exceptions 用于指定当应用程序发生许可错误时(如证书许可,网络许可等),Monkey是否停止运行。如果使用此参数,即使应用程序发生许可错误,Monkey依然会发送事件,直到事件计数完成

adb shellmonkey -p cn.emoney.acg --ignore-security-exception 1000
黑白名单

添加白名单,可实现交叉测试
–pkg-blacklist-file 黑名单:不测试的应用
–pkg-whitelist-file 白名单:只测试这部分应用(注意的是,黑名单跟白名单只能设置一个,不能同时使用)

1、先本地或linux编写一个包名文档,adb push到设备上
2、执行命令 blacklist.txt whitelist.txt

adb shell monkey -- pkg-blacklist-file /data/local/tmp/blacklist.txt --throttle 200 300
不跑黑名单里面的应用,延迟200毫秒,执行300次

adb shell monkey -- pkg-whitelist-file /data/local/tmp/whitelist.txt --throttle 200 300 
只跑白名单里面的应用,延迟200毫秒,执行300次。运行结果如下图
monkey测试结果分析

1、monkey目的就是被测应用是否出现奔溃、卡顿现象
主要异常
Crash:被测应用异常停止退出
ANR:5秒内没有响应输入的时间(按钮、屏幕触屏、)
Error或者exception:表示出现未知错误
aborted:无法正常启动,monkey测试被迫中止

2、为了确保monkey测试过程中引入其他干扰干扰,测试过程中建议
关闭所以网络开关(wifi+数据流量),以免莫名消耗流量,除非测试过程要求联网
开起安全设置下未知电源
手机连接电源充电,模拟器不讨论
测试前手动运行一遍手机上分带有首次提示说明,如输入法,文件夹窗口,apk提示

logcat

安卓查看日志
语法 adb logcat [option] [filter - spec]

logcat缓冲区
redio:通信系统 (影像)
system:系统组件
event:event模块 (触摸、滚动)
main:java层log (加载调用)

缓冲区主要给系统组成使用,不需要关系,应用日志都在main,重点关注main
adb logcat -b main

-b 知道缓冲区
-c 清除缓冲区日志并退出
-f 将日志输入到文件默认标准输出(显示器缓存)
-g 打印日志缓存区大小并退出
-n(count) 设置日志最大数目(),默认4和r一起用
-r(kbytes) 默认16kb,需要和f一起用
-s 设置过滤器
-v (format) 设置输出日志消息,默认短暂格式,支持格式列表

日志优先级
V –Verbose(最低优先级)
D – Debug 调试
I – Info 信息
W – Warning 警告
E – Error 错误
F – Fatal 严重错误
S – Silent 静默(最高优先级)
adb logcat *.E

格式化

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值