Monkey adb安装及环境配置:https://blog.csdn.net/Apple_lx/article/details/49496231
Adb命令大全:http://blog.sina.com.cn/s/blog_6294abe70101275q.html
Adb模拟器命令大全:https://blog.csdn.net/m0_37615390/article/details/76919255
ADB,即 Android Debug Bridge,它是 Android 开发/测试人员不可替代的强大工具,也是 Android 设备玩家的好玩具
对整机压测:adb shell monkey 10000
对应用程序压测:adb shell monkey -p com.subject.zhongchou -v 1000
打印压测日志:adb shell monkey -p com.subject.zhongchou -v 1000 >D:/adb/log.txt
查看整机日志:adb logcat
清除缓存日志:adb logcat -c
1、通常我们使用命令adb logcat -c 就是清理的是main缓存区域的日志,但是总是满足不了清理所有缓存日志的要求,因此我们可以使用下面的命令来清理日志;
2、adb logcat -c -b events,清理系统事件信息日志;
3、依次类推清理手机内所有日志的命令:adb logcat -c -b main -b events -b radio -b system
查看程序日志:adb logcat | find "com.subject.zhongchou"
打印程序日志到电脑:adb logcat | find "com.subject.zhongchou" >D:/adb/log.txt
打印程序日志手机:adb logcat -f / sdcard/com.subject.zhongchou/log/wyl.txt
日志优先级是下面的字符,顺序是从低到高:
V — 明细 (最低优先级)
D — 调试
I — 信息
W — 警告
E — 错误
F — 严重错误
S — 无记载 (最高优先级,没有什么会被记载)
Monkey是一款通过命令行来对我们APP进行测试的工具,可以运行在模拟器里或真机上
第一步:搭建环境:主要是安装和搭建java和sdk环境
第二步:准备好要测试的项目,比如可以是一个.apk安装包,也可以是已经安装到手机上的软件
第三步:连接上Android测试设备,可以是模拟器,当然也可以是手机,通过adb 命令对测试项目进行Monkey测试。
查看版本
ADB 的安装这里就不多说了,输入以下命令有如下提示就证明你环境ok,否则自行网上搜索解决下。
$ adb version
Android Debug Bridge version 1.0.36
Revision 8f855a3d9b35-android
获取手机系统信息( CPU,厂商名称等)
adb shell "cat /system/build.prop | grep "product""
获取手机系统api版本
adb shell getprop ro.build.version.sdk
获取序列号
1、adb get-serialno
2、adb shell getprop ro.serialno
02ae0c1021089daf
获取 MAC 地址
adb shell cat /sys/class/net/wlan0/address
bc:f5:ac:f9:f7:c8
查看设备型号
adb shell getprop ro.product.model
vivo X9Plus
查看 Android 系统版本
adb shell getprop ro.build.version.release
7.1.2
查看屏幕分辨率
adb shell wm size
Physical size: 1080×1920
查看屏幕密度
adb shell wm density
Physical density: 480
adb devices 获取连接设备及状态
adb get-state获取设备状态
设备的状态有 3 钟,device , offline , unknown
device:设备正常连接
offline:连接出现异常,设备无响应
unknown:没有连接设备
导出设备信息
adb get-serialno > 序列号.txt
adb shell cat /sys/class/net/wlan0/address > MAC地址.txt
adb shell getprop ro.product.model > 设备型号.txt
adb shell getprop ro.build.version.release> 系统版本.txt
adb shell pm list packages -s > 系统应用的所有包名.txt
adb shell pm list packages -3 > 第三方应用包名.txt
adb shell wm size > 屏幕分辨率.txt
adb shell wm density > 屏幕密度.txt
adb shell cat /proc/cpuinfo > CPU信息.txt
adb shell pm list permissions -f > 权限.txt
adb shell pm list users -f > 用户.txt
获取手机内存信息
adb shell cat /proc/meminfo
获取手机存储信息
adb shell df
获取手机内部存储信息:
魅族手机: adb shell df /mnt/shell/emulated
其他: adb shell df /data
获取sdcard存储信息:
adb shell df /storage/sdcard
在获取手机工作状态的信息中,有一个非常好用的命令
adb shell dumpsys
后边可以加很多东西,具体调用的是底层C代码返回值并打印出来
adb shell dumpsys meminfo 手机当前使用的内存情况,各个线程的内存占用情况
adb shell dumpsys batteryinfo 手机的电池信息
内存:使用adb shell脚本进行测试,查看Log数据。adb shell dump meminfo
CPU:使用adb shell脚本进行测试,查看Log数据。adb shell top
备份adb backup
.使用run-as在非root情况获取沙盒数据(前提是开启debuggable模式)
adb kill-server , adb start-server , 结束 adb 服务, 启动 adb 服务,通常两个命令一起用
adb logcat , 打印 Android 的系统日志
adb bugreport , 打印dumpsys、dumpstate、logcat的输出,也是用于分析错误
adb install xx.apk 把指定的apk包安装到设备中adb install D:\adb\zhongchou.apk
参数含义:
-r允许覆盖安装
-s将应用安装到 sdcard(sd卡)
-d允许降级覆盖安装。
如果见到类似如下输出(状态为 Success)代表安装成功:
12040 KB/s (22205609 bytes in 1.801s)
pkg: /data/local/tmp/SogouInput_android_v8.3_sweb.apk
Success
而如果状态为 Failure 则表示安装失败
保留数据和缓存文件,重新安装apk:
adb install -r demo.apk
安装apk到sd卡:
adb install -s demo.apk
adb uninstall 应用的包名 卸载制定应用adb uninstall com.subject.zhongchou
// 如:adb uninstall com.stormzhang.demo
卸载 app 但保留数据和缓存文件:
adb uninstall -k com.stormzhang.demo
列出手机装的所有app的包名:
adb shell pm list packages
无 |
所有应用 |
-f |
显示应用关联的 apk 文件 |
-d |
只显示 disabled 的应用 |
-e |
只显示 enabled 的应用 |
-s |
只显示系统应用 |
-3 |
只显示第三方应用 |
-i |
显示应用的 installer |
-u |
包含已卸载应用 |
|
|
查看应用的apk文件在手机上的安装位置
adb shell pm list packages -f
列出系统应用的所有包名:
adb shell pm list packages -s
列出除了系统应用的第三方应用包名:
adb shell pm list packages -3
使用 grep 来过滤:
adb shell “pm list packages | grep qq” (注意加双引号)
adb shell "pm list packages -3 | grep zhongchou"
清除应用数据与缓存
有些时候我们测试需要清除数据与缓存,则需要用到如下命令:
adb shell pm clear
// 如:adb shell pm clear com.subject.zhongchou
启动应用
如果我们想要通过 adb 来启动应用
adb shell am start -n com.stormzhang.demo/.ui.SplashActivity
adb shell am start -n 包名/包名+类名(-n 类名,-a action,-d date,-m MIME-TYPE,-c category,-e 扩展数据,等)。
查看类名:https://blog.csdn.net/jlminghui/article/details/40622103
启动要查看的程序:adb shell dumpsys window w |findstr \/ |findstr name=
查看当前运行的包名和Activity:
adb shell dumpsys window | findstr mCurrentFocus(手动打开应用程序)
强制停止应用
有些时候应用卡死了,需要强制停止,则执行以下命令:
adb shell am force-stop
// 如:adb shell am force-stop cn.androidstar.demo
adb pull , 将 Android 设备上的文件或者文件夹复制到本地
例如复制 Sdcard 下的 pull.txt 文件到 D 盘: adb pull sdcard/pull.txt d:\
复制重命名
adb pull sdcard/pull.txt d:\rename.txt
adb push 推送
adb push d:\push.txt sdcard/ sdcard/斜杠不能少
adb root , adb remount 获取root权限
adb reboot , 重启 Android 设备
adb shell monkey :给指定的设备发送压力测试,number是要测试的次数。执行这个命令的效果就相当于有个手指在你的手机上乱点。
adb shell monkey -p pkgname :同上面效果一样,只是对指定包名(pkgname)apk进行测试。
monkey -p com.gewara -v 1000
参数说明:-p后跟着软件所在包名,-v后跟测试的次数)。这里对该软件
进行1000次的自动化测试,几分钟内即可以完成测试。
Monkey高级参数的应用
4.1.throttle参数:指定事件之间的间隔时间
adb shell monkey -throttle :milliseconds是时间值 ,单位毫秒
例:monkey -p com.subject.zhongchou -throttle 2000 100000
4.2.seed参数:伪随机数生成器的seed 值。
adb shell monkey -s :如果用相同的 seed 值再次运行 Monkey ,它将生成相同的事件序列。
列:monkey -p com.subject.zhongchou -s 200 100000
4.3.touch:设置触摸事件
adb shell monkey -pct-touch :指定touch事件的百分比percent
列:monkey -p com.subject.zhongchou -pct-touch 70 100000
4.4.motion:设置动作事件
adb shell monkey -pct-motion :指定motion事件的百分比percent
列:monkey -p com.subject.zhongchou -pct-motion 70 100000
4.5.trackball:设置轨迹球事件
adb shell monkey -pct-trackball :指定轨迹球事件百分比percent
monkey -p com.subject.zhongchou - pct-trackball 70 100000
4.6.nav:导航事件设置
adb shell monkey -pct-nav :指定基本导航事件百分比percent
4.7.majornav:设置主要导航事件
adb shell monkey -pct-majornav :设定主要导航事件百分比percent,兼容中间键,返回键,菜单按键
4.8.syskeys:设置事件
adb shell monkey -pct-syskeys :设定系统事件百分比percent,比如HOME,BACK,拨号及音量调节等事件。
4.9.appswitch:启动Activity事件
adb shell monkey -pct-appswitch :设定启动activity的事件百分比percent
4.10.anyevent:不常用事件设置
adb shell monkey -pct-anyevent :设定不常用事件地百分比
4.11.crashes :程序崩溃事件设置
参数: –ignore-crashes
用于指定当应用程序崩溃时(Force & Close错误),Monkey是否停止运行。如果使用此参数,即使应用程序崩溃,Monkey依然会发送事件,直到事件计数完成。
* 示例1:adb shell monkey -p com.htc.Weather --ignore-crashes 1000
测试过程中即使Weather程序崩溃,Monkey依然会继续发送事件直到事件数目达到1000为止;
* 示例2:adb shell monkey -p com.htc.Weather 1000
测试过程中,如果Weather程序崩溃,Monkey将会停止运行。
4.12.timeouts:超时事件设置
adb shell monkey -ignore-timeouts :忽略超时事件
参数: –ignore-timeouts
用于指定当应用程序发生ANR(Application No Responding)错误时,Monkey是否停止运行。如果使用此参数,即使应用程序发生ANR错误,Monkey依然会发送事件,直到事件计数完成。
ANR:应用无响应
参数: –ignore-security-exceptions
用于指定当应用程序发生许可错误时(如证书许可,网络许可等),Monkey是否停止运行。如果使用此参数,即使应用程序发生许可错误,
Monkey依然会发送事件,直到事件计数完成。
参数: –kill-process-after-error
用于指定当应用程序发生错误时,是否停止其运行。如果指定此参数,当应用程序发生错误时,应用程序停止运行并保持在当前状态(注意:应用程序仅是静止在发生错误时的状态,系统并不会结束该应用程序的进程)
参数: –monitor-native-crashes
用于指定是否监视并报告应用程序发生崩溃的本地代码
参数: –pct-{+事件类别} {+事件类别百分比}
用于指定每种类别事件的数目百分比(在Monkey事件序列中,该类事件数目占总事件数目的百分比)
参数:使用说明:
示例:–pct-touch {+百分比}
调整触摸事件的百分比(触摸事件是一个down-up事件,它发生在屏幕上的某单一位置)
adb shell monkey -p com.htc.Weather –pct-touch 10 1000
–pct-motion {+百分比}
调整动作事件的百分比(动作事件由屏幕上某处的一个down事件、一系列的伪随机事件和一个up事件组成)
adb shell monkey -p com.htc.Weather –pct-motion 20 1000
–pct-trackball {+百分比}
调整轨迹事件的百分比(轨迹事件由一个或几个随机的移动组成,有时还伴随有点击)
adb shell monkey -p com.htc.Weather –pct-trackball 30 1000
–pct-nav {+百分比}
调整“基本”导航事件的百分比(导航事件由来自方向输入设备的up/down/left/right组成)
adb shell monkey -p com.htc.Weather –pct-nav 40 1000
–pct-majornav {+百分比}
调整“主要”导航事件的百分比(这些导航事件通常引发图形界面中的动作,如:5-way键盘的中间按键、回退按键、菜单按键)
adb shell monkey -p com.htc.Weather –pct-majornav 50 1000
–pct-syskeys {+百分比}
调整“系统”按键事件的百分比(这些按键通常被保留,由系统使用,如Home、Back、Start Call、End Call及音量控制键)
adb shell monkey -p com.htc.Weather –pct-syskeys 60 1000
–pct-appswitch {+百分比}
调整启动Activity的百分比。在随机间隔里,Monkey将执行一个startActivity()调用,作为最大程度覆盖包中全部Activity的一种方法
adb shell monkey -p com.htc.Weather –pct-appswitch 70 1000
–pct-anyevent {+百分比}
调整其它类型事件的百分比。它包罗了所有其它类型的事件,如:按键、其它不常用的设备按钮、等等
adb shell monkey -p com.htc.Weather
–pct -anyevent 100 1000* 指定多个类型事件的百分比:
adb shell monkey -p com.htc.Weather –pct-anyevent 50 –pct-appswitch 50 1000
注意:各事件类型的百分比总数不能超过100%;
测试语句如:adb -s emulator-5556 shell monkey -p 包名 -v 10000
adb -s emulator-5556 shell monkey -p com.soft0754.android -vvv 10000 > C:/log.txt
-v 为 verbose的缩写,就是详细输出事件等级,这个3个v就是输出等级1至3的所有事件,然后再使用管道命令将输出结果放到一个文本里面方便查看.接下来就是看你的程序能不能在这样的折腾下坚持下去了.
实例:adb -s emulator-5556 shell monkey -p 包名 –ignore-crashes –ignore-timeouts –ignore-native-crashes –pct-touch 30 -s 1 -v -v –throttle 200 100000 2 logcat >C:/error.txt 1 logcat>C:/info.txt
Monkey log分析
(1) 什么时候会有Log文件的产生 ?
程序异常退出 , uncaused exception
程序强制关闭 ,Force Closed (简称FC)
程序无响应 , Application No Response (简称ANR),一般主线程超过5秒么有处理就会ANR
手动生成
拿到一个日志文件,要分成多段来看 。 log文件很长,其中包含十几个小单元信息,但不要被吓到 ,事实上他主要由三大块儿组成 。
1,系统基本信息 ,包括 内存,CPU ,进程队列 ,虚拟内存 , 垃圾回收等信息
—— MEMORY INFO (/proc/meminfo) ——
—— CPU INFO (top -n 1 -d 1 -m 30 -t) ——
—— PROCRANK (procrank) ——
—— VIRTUAL MEMORY STATS (/proc/vmstat) ——
—— VMALLOC INFO (/proc/vmallocinfo) ——
2,时间信息 , 也是我们主要分析的信息 。
—— VMALLOC INFO (/proc/vmallocinfo) ——
—— EVENT INFO (/proc/vmallocinfo) ——
3,虚拟机信息 , 包括进程的,线程的跟踪信息,这是用来跟踪进程和线程具体点的好地方 。
—— VM TRACES JUST NOW (/data/anr/traces.txt.bugreport: 2011-01-15 16:49:02) ——
—— VM TRACES AT LAST ANR (/data/anr/traces.txt: 2011-01-15 16:49:02) ——