monkey 稳定性测试

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

  调整其他类型的事件的百分比,比如按键或其他不太常用到的一些事件的百分比

 

基本命令

  1. adb install xxx.apk  安装apk
  2. adb install -r xxx.apk  保留数据和缓存文件,重新安装apk
  3. adb uninsatll 包名   卸载应用
  4. adb uninsatll -k 包名 卸载应用但保留数据和缓存文件
  5. adb shell dumpsys activity | find "mFocusedActivity"  查看前台activity名
  6. adb connect/disconnect 通过wifi进行远程连接手机进行调试
  7. adb logcat -c 清除下logcat日志信息
  8. adb logcat 打印日志
  9. adb logcat > /xx/xx/xx.txt   重定向输出到xx文件中
  10. adb pull <手机路径> <本机电脑路径>   把手机内的某一个指定文件推送到电脑
  11. adb push  <本机电脑路径>  <手机路径>  把电脑内的某一个指定文件推送到手机

Monkey测试出现的异常的原因以及日志分析:

  1. 一般是由于以下两种原因导致的:
  2. Crash 程序崩溃(程序存在空指针/CPU内存不足/内存不足)
  3. ANR 程序无响应(CPU不足/内存不足/线程阻塞)
  4. 常见的测试结果分析方法-搜索关键字:(在日志中搜索“ANR”,在日志中搜索“CRASH”,在日志中搜索”Exception”)
原文地址:https://www.cnblogs.com/SunshineKimi/p/12243015.html