一:简介
Monkey测试是Android平台自动化测试的一种手段
通过Monkey程序模拟用户触摸屏幕、滑动Trackball、按键等操作来对设备上的程序进行压力测试,检测程序多久的时间会发生异常
二:monkey命令
•目前我们做monkey整机测试所使用的命令是:
•monkey
-v -v --monitor-native-crashes --ignore-security-exceptions
--kill-process-after-error --pct-trackball 0 --pct-nav 0 --pct-anyevent 0
--pct-appswitch 0 --pct-flip 0 --pct-majornav 10 --pct-touch 44 --pct-motion 30
--throttle 150 6000000 >/mnt/sdcard/log/monkey_test.txt & logcat -v time
> /mnt/sdcard/log/logcat.txt & logcat -v time -b radio >
/mnt/sdcard/log/radio.txt &
•monkey
-v -v -v --monitor-native-crashes --ignore-security-exceptions
--kill-process-after-error --pct-trackball 0 --pct-nav 0 --pct-anyevent 0
--pct-appswitch 30 --pct-flip 5 --pct-majornav 5 --pct-touch 30 --pct-motion 10
--pct-syskeys 20 --throttle 150 600000 > d:/monkey.log
•monkey模块测试使用的命令是:
•monkey
-v -v -p com.google.android.music(对应的PackageName) --monitor-native-crashes
--ignore-security-exceptions --kill-process-after-error --pct-trackball 0
--pct-nav 0 --pct-anyevent 0 --pct-appswitch 0 --pct-flip 0 --pct-majornav 10
--pct-touch 44 --pct-motion 30 --throttle 150 6000000 >
/mnt/sdcard/log/monkey_test.txt & logcat -v time >
/mnt/sdcard/log/logcat.txt & logcat -v time -b radio >
/mnt/sdcard/log/radio.txt &
三:参数含义
•-p:所在测试的包,可以是一个也可以是多个 如 monkey
-p com.androd.sms -p com.androd.explorer
•-c:如果用此参数指定了一个或几个类别,Monkey将只允许系统启动被这些类别中的某个类别列出的Activity。如果不指定任何类别,Monkey将选择下列类别中列出的Activity: Intent.CATEGORY_LAUNCHER或Intent.CATEGORY_MONKEY。要指定多个类别,需要使用多个-c选项,每个-c选项只能用于一个类别。
•-ignore-crash:当应用程序崩溃或发生任何失控异常时,Monkey将停止运行。如果设置此选项,Monkey将继续向系统发送事件,直到计数完成。
•-ignore-timeouts:通常,当应用程序发生任何超时错误(如“Application Not Responding”对话框)时,Monkey将停止运行。如果设置此选项,Monkey将继续向系统发送事件,直到计数完成。
•-ignore-security-exceptions:通常,当应用程序发生许可错误(如启动一个需要某些许可的Activity)时,Monkey将停止运行。如果设置了此选项,Monkey将继续向系统发送事件,直到计数完成。
•-monitor-native-crashes:监视并报告Android系统中本地代码的崩溃事件。如果设置了–kill-process-after-error,系统将停止运行。
•-kill-process-after-error:如果程序出现错误,monkey将结束此程序进程。
•-hprof:设置此项,将在monkey事件序列之前和之后立即生成profilling报告。这将会在data/misc中生成大文件(约5mb)所以要小心使用它。
•-pct-touch:调整触摸事件的百分比(触摸事件是一个down-up事件,它发生在屏幕的某单一位置)。
•-pct-motion:动作事件的百分比(动作事件由屏幕上某处的一个down事件、一系列的随机事件和一个up事件组成)。
•-pct-trackball:调整轨迹事件的百分比(轨迹事件由一个或几个随机移动组成,有时还伴随着点击)。
•-pct-syskeys:调整系统按键事件的百分比(这些按键通常被保留,由系统使用,如home,back,start call,end call及音量控制)。
•-pct-nav 调整基本导航事件的百分比(导航事件来自方向输入设备的up/down/left/right组成)。
•-pct-majornav:调整“主要”导航事件的百分比(这些导航事件通常引发图形界面中的动作,如:5-way键盘的中间按键、回退按键、菜单按键)
•-pct-appswitch:调整启动Activity的百分比。在随机间隔里,Monkey将执行一个startActivity()调用,作为最大程度覆盖包中全部Activity的一种方法。
•-pct-anyevent:调整启动Activity的百分比。它包罗了所有其它的事件类型,如:按键,其它不常用的设备按钮。
•-pct-flip:
•–wait-dbg:停止执行中的Monkey,直到有调试器和它相连接。
•–dbg-no-events:设置此选项,Monkey将执行初始启动,进入到一个测试Activity,然后不会再进一步生成事件。为了得到最佳结果,把它与-v、一个或几个包约束、以及一个保持Monkey运行30秒或更长时间的非零值联合起来,从而提供一个环境,可以监视应用程序所调用的包之间的转换。
•-setup:
•-f:
•-port:为monkey开启专用端口。此时只monkey不会帮你乱点击,而此时你自己就是一只monkey了,在你乱点的时候,monkey会输出你点击后回馈的信息。如果你打完命令之后模拟器上没有启动你所要启动的包,你需要自己启动,但是你只能启动你-p中指定的那几个包。ctrl+c中断。
•--throttle:当事件起效时等待的毫秒数。
•-s:随机数生成器的seed值。如果用相同的seed值再次运行monkey,它将生成相同的事件序列。
•COUNT:要发送的事件数。
四:LOG存放位置
•首先要创建对应的log文件夹和清空旧的日志:
进入
adbshell
mkdir /mnt/sdcard/log/
rm /mnt/sdcard/log/monkey_test.txt
rm /mnt/sdcard/log/radio.txt
rm -rf/data/anr/
rm -rf/data/tombstones/
rm /mnt/sdcard/log/logcat.txt
•然后再运行上面的整机测试脚本
或者 对应的模块测试脚本
五:LOG取出
•跑完之后取日志
adb pull
/mnt/sdcard/log/monkey_test.txtD:\monkey_test.txt
adb pull
/mnt/sdcard/log/radio.txt D:\radio.txt
adb pull
/data/anr/ D:\
adbpull/data/tombstones/ D:\
adb pull
/mnt/sdcard/log/logcat.txt D:\logcat.txt
得到对应的日志存放在D盘根目录
六:日志分析
•我们主要分析logcat.txt日志
在logcat日志中,分别搜索关键字Fatal、ANR
如果能够搜索到,那么就存在对应的Crash或者ANR的bug
然后就把对应的报错日志截取下来,一般是截取到Processcom.android.XXX has
died