adb shell
pm list packages -3 |grep neteas*
monkey -h
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]
[--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]
[--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]
COUNT
运行monkey script :
打印日志遇到无法创建在只读system / 根目录:/system/bin/sh: can't create logcat.log: Read-only file system
解决办法一:直接跳转到/mnt/sdcard 目录下执行 monkey 命令生成日志:
root@android:/ # pm list packages -3
package:com.android.gesture.builder
package:com.example.android.apis
package:com.netease.newsreader.activity
root@android:/ # pwd
/
root@android:/ # cd /mnt/sdcard/
root@android:/mnt/sdcard # pwd
root@android:/mnt/sdcard # monkey -p com.netease.newsreader.activity -s 10 --throttle 1000 -vv 1000 --ignore-crashes --ignore-timeouts --ignore-security-exceptions --ignore-security-exceptions > monkeylogs.log
解决办法二:直接 windows cmd 执行 adb shell monkey -p com.xxx.xx -s 10 -vv > monkeylogs.log
日志分析,标准流与错误流分开保存:
linux:
monkey -v 100 1>/sdcard/monkey.txt 2>/sdcard/error.txt
pc 端:
C:Userschen>adb shell monkey -v 100 1>d:monkey.log 2>d:error.log
执行以上命令,Monkey的运行日志和异常日志将被分开保存。此时Monkey的运行日志将被保存在monkey.txt文件中,而异常日志将被保存在D盘下的error.txt中。
如果需要控制monkey执行的时间,可以通过设置执行时长/事件发送延时,想要monkey运行24小时,每100毫秒发送一个事件,24*60*60*1000/100=864000(次)
monkey -p *** --ignore-crashes --ignore-timeoutss --throttle 100 864000
一)基础参数
1、最简单的monkey命令(monkey 100)
表示:在设备上,针对整个系统发送100个伪随机事件。
2、-v参数
用于指定反馈信息级别(信息级别就是日志的详细程度)总共分为3级,默认为-v(对应:level0)
-v:只提供启动提示、测试完成提示和最终结果等少量信息。
-v -v:较为详细的日志,包括每个发送到activity的时间信息。
-v -v -v:最详细的日志,包括测试中选中/未选中的activity信息。
注意:在monkey测试完成时,最后一定会有一个:monkey finished标识。
3、-p参数
在我们测试时,是针对具体的app进行测试的,所以在使用monkey测试时,我们需要提供具体的app包名给monkey,此时就需要用到参数-p。在-p后跟随app包名。
在测试时,可以不指定包名,此时monkey会在测试设备上随机启动app进行操作;如果只需要测试一个app,使用一个-p即可;如果有多个app同时测试,可以直接使用-p 包名1 -p 包名2指定具体要测试的app。
如:
4、-s参数
种子值(seed),因为monkey是发送的是伪随机的事件流,但是如果两次seed值相同,那两次monkey测试所产生的事件序列也相同。(所以一般在测试时要记录seed值,以防出现无响应和crash,不容易验证。)
注意:-s需要跟在包名后,次数前
5、--throttle参数
设置执行操作的延迟时间(毫秒)--是指两个事件之间的间隔,如果没有指定此参数,会尽可能快的生成和发送事件。
(二)调试选项
1、--ignore-crashes
用于指定当应用程序崩溃时,Monkey是否停止运行。如果使用此参数,即使应用程序崩溃,monkey依然会发送事件,直到事件计数完成。
2、---ignore-timeouts
用于指定当应用程序发生ANR(Application No Responding)错误时,Monkey是否停止运行。如果使用此参数,即使应用程序发生ANR错误,Monkey依然会发送事件,直到事件计数完成。
3、--ignore-security-exceptionss
用于指定当应用程序发生许可错误时(如证书许可,网络许可等),Monkey是否停止运行。如果使用此参数,即使应用程序发生许可错误,Monkey依然会发送事件,直到事件计数完成。
4、--kill-process-after-error
用于指定当应用程序发生错误时,是否停止其运行。如果指定此参数,当应用程序发生错误时,应用程序停止运行并保持在当前状态(注意:应用程序仅是静止在发生错误时的状态,系统并不会结束该应用程序的进程)。
5、--monitor-native-crashes
用于指定是否监视并报告应用程序发生崩溃的本地代码
6、--hprof
该选项设置后,将会在monkey事件序列前后立刻生成report,大小为大于5MB,存储在/data/misc
(三)事件类型
monkey在发送伪随机事件时,是有不同的类型的。默认随机分配比例,也可以指定其百分比。如果不设置会是--pct-anyevent为100%,也就是纯随机事件;如果配置了其他参数,但是不够100%,余下的百分比部分也是--pct-anyevent事件。
如:
目前共包含11中类型的事件。
分别为:
0:触摸事件--pct-touch
调整touch触屏事件的百分比,触碰事件就是指在屏幕上的一个单独位置的一次点击/抬起的事件。
1:滑屏事件--pct-motion(手势事件)
(手势事件是由一个在屏幕某处的按下事件、一系列的伪随机移动、一个抬起事件组成)即一个滑动操作,但是是直线的,不能拐弯)
2:轨迹球--pct-trackball
(轨迹球事件包括一个或多个随机移动,有时还伴有点击。轨迹球现在智能手机上已经没有了,就是类似手柄的方向键一样)
3:
4:旋转(--pct-rotation)
旋转屏幕
5:
6:导航--pct-nav
(导航事件包括上下左右,如方向输入设备的输入)老手机的上下左右键,智能机上没有)
7:主导航--pct-majornav
调整主要导航事件的百分比(如中间键、取消、确定或菜单引发的图形接口的动作)
8:系统按键--pct-syskeys
调整系统按键事件,如:home/back/startcall/endcall以及音量控制键等
9:app切换--pct-appswitch
调整启动activity的百分比,在随机间隔中,执行一个startActivity()方法调用,作为一种最大化的覆盖安装包的所有的activity的方法
10:键盘翻转(--pct-flip)
11:随机--pct-anyevent
调整其他类型的事件的百分比,比如按键或其他不太常用到的一些事件的百分比
基本命令
- adb install xxx.apk 安装apk
- adb install -r xxx.apk 保留数据和缓存文件,重新安装apk
- adb uninsatll 包名 卸载应用
- adb uninsatll -k 包名 卸载应用但保留数据和缓存文件
- adb shell dumpsys activity | find "mFocusedActivity" 查看前台activity名
- adb connect/disconnect 通过wifi进行远程连接手机进行调试
- adb logcat -c 清除下logcat日志信息
- adb logcat 打印日志
- adb logcat > /xx/xx/xx.txt 重定向输出到xx文件中
- adb pull <手机路径> <本机电脑路径> 把手机内的某一个指定文件推送到电脑
- adb push <本机电脑路径> <手机路径> 把电脑内的某一个指定文件推送到手机
Monkey测试出现的异常的原因以及日志分析:
- 一般是由于以下两种原因导致的:
- Crash 程序崩溃(程序存在空指针/CPU内存不足/内存不足)
- ANR 程序无响应(CPU不足/内存不足/线程阻塞)
- 常见的测试结果分析方法-搜索关键字:(在日志中搜索“ANR”,在日志中搜索“CRASH”,在日志中搜索”Exception”)