Monkey测试
一、Monkey 命令
1、使用monkey测试手机所有程序
adb shell monkey 100 执行monkey测试100次
2、-p <允许的包名列表>
adb shell monkey -p 包名 100
3、显示日志详细程度
adb shell monkey -p 包名 -v 30
adb shell monkey -p 包名 -v -v 30
adb shell monkey -p 包名 -v -v -v 30
4、将log信息写到文档中
adb shell monkey 100 >路径
5、-s 随机数种子
用来指定伪随机数生成器的seed值,如果seed相同,则两次Monkey测试所产生的事件序列也相同的。 示例:
monkey测试1:adb shell monkey –s 10 100
monkey测试2:adb shell monkey –s 10 100
6、–throttle <毫秒>
adb shell monkey -p com.example.login --throttle 300 100
7、–pct-touch
调整触摸事件的百分比
adb shell monkey --pct-touch 67 -v 10
Event percentages 参考:https://blog.youkuaiyun.com/u011436666/article/details/53998332
8、–pct-motion
调整motion事件百分比
adb shell monkey --pct-motion 67 -v 10
9、–ignore-crashes
通常,应用发生崩溃或异常时Monkey会停止运行。如果设置此项,Monkey将继续发送事件给系统,直到事件计数完成
10、–ignore-timeouts(ANR)
作用:通常,应用程序发生任何超时错误(如“Application Not responding”对话框)Monkey将停止运行,设置此项,Monkey将继续发送事件给系统,直到事件计数完成。
adb shell monkey --ignore-timeouts –v 10
11、Monkey 实例
用monkey 命令 对登录apk进行 性能测试
-
-p后面接着的对应的包名,对具体某个app测试
-
-s后面是对应的种子数,好像就是操作步骤,一般设置相同的种子数目的是复现bug
-
–ignore-crashes --ignore-timeouts 这里是在monkey测试的过程中遇到carash或者timeout的情况时忽略掉,一般不设置时,出现carash或者timeout时,Monkey测试会终止。这里是防止Monkey测试终止。
-
-v 指的是Monkey测试时打印log级别。
-
100000 这里是指点击的次数,根据她们测试的经验,对于单个应用程序这个次数设置在100000次就可以了;如果是真机,一般设置在500000次。
-
–throttle-时间 ,设置事务之间的延迟等待时间,单位是毫秒
7.>路径,设置日志存储路径
-
2>&1 固定的写法,这个也很重要,代表的意思是中间忽略的东西的日志一并输入到指定的文件中。
-
最后单独的一个"&" 是一旦Monkey测试开始了,之后可以拔掉数据线,不会影响Monkey测试。
补充:–pct-touch 50:指定具体的某个事务的占比
二、 Monkey异常分析
一般我们可以一次发送5万次随机事件的请求,每个请求之间的间隔为150毫秒,测试大约会进行40min,完成以后就可以查看日志。
日志中可能的错误:
1.程序异常退出,uncausedexception (ctrl+f搜索)
2.程序强制关闭,ForceClosed (简称FC) (同上)
3.程序无响应,ApplicationNo Response(ctrl+f搜索‘ANR ’,加空格是为了屏蔽掉一些无效信息)
4.手动生成
Monkey 执行中断, 在log最后也能看到当前执行次数
orceClosed (简称FC) (同上)
3.程序无响应,ApplicationNo Response(ctrl+f搜索‘ANR ’,加空格是为了屏蔽掉一些无效信息)
4.手动生成
Monkey 执行中断, 在log最后也能看到当前执行次数