monkey学习总结笔记

一、什么是monkey?

Monkey是Android中的一个命令行工具,可以运行在模拟器里或实际设备中。它向系统发送伪随机的用户事件流(如按键输入、触摸屏输入、手势输入等),实现对正在开发的应用程序进行压力测试。Monkey测试是一种为了测试软件的稳定性、健壮性的快速有效的方法。

二、monkey特点?

Monkey 程序是由 Android 系统自带,使用 Java 语言写成。在Android文件系统中的存放路径是:/system/framework/monkey.jar;

Monkey.jar程序是由一个名为“monkey”的Shell脚本来启动执行,shell脚本在Android文件系统中 的存放路径是:/system/bin/monkey;

也就是说monkey可以直接通过打包进测试工具中,被测试人员直接使用,网络上许多第三方的monkey工具就是通过对原生的Monkey.jar包进行二次开发实现。

三、monkey原理?

  1). adb shell monkey的运行机制: 实际上是执行手机中/system/bin/monkey这个脚本;
  2). Monkey事件注入机制:Monkey注入系统事件是通过 framework 层的 hidenApi (如:activemanager,inputmanager,windowmanager) 获取系统服务。
  Monkey中有11种事件,这些事件在MonkeyEventSource中对事件之间的比例进行设置。Monkey事件根据类型比例生成事件队列,循环查找事件。
    a.触摸事件(inputmanager):包括屏幕以及物理键的触摸,滑动,点击事件。
    b.Activity事件(activemanager):是指我们调用Android系统组件的事件。
    c.Window事件(windowmanager):是指操作Window的事件,例如转屏。
  3).Monkey核心类
    a. Monkey.java, 程序的入口,根据参数选择合适的MonkeyEventSource,并适时触发MonkeyEvent;
    b. MonkeyEventSource.java, MonkeyEvent的工厂,是一个接口;
    c. MonkeyEvent.java,各种事件的具体实现。

四、monkey架构图?

  Monkey 运行在设备或模拟器上面,可以脱离PC运行(一般在一些大公司中都是将其抽离成一个测试专用的APP工具,使用相应的操作来完成测试)

五、测试准备?

  1、首先需要将手机连接到PC,测试连接是否正常,可在cmd里输入adb devices来进行验证;
  2、因测试多针对一个特定的APP包,所以需要获取测试包的包名;

    方法一:直接问开发,

    方法二:通过 adb shell pm list packages 列出所有包名来进行查找
(不确定包是否已安装,可以用adb shell pm list packages [options] <INTENT> 来进行确认,它的含义是列举出所有包含<INTENT>的package。 e.g. adb shell pm list packages com.taobao.taobao)。

    方法三:启动设备上的测试app,同时输入下列命令查看当前活动的应用包名。  

    Android 7.0:adb shell dumpsys activity activities | findstr mFocusedActivity
    Android 8.0:adb shell dumpsys activity activities | findstr mResumedActivity
          或者:adb shell dumpsys window | findstr mCurrentFocus

            

  3、对特定APP包进行测试的命令为adb shell monkey -p <pakage.name>

六、monkey命令参数详解?  

          

  示例:adb shell monkey -p com.chineseall.microbookroom --throttle 100 --ignore-crashes --ignore-timeouts --ignore-security-exceptions --ignore-native-crashes --monitor-native-crashes -v -v -v –s 1540475754297 100

  -help                                     查看monkey参数及说明     adb shell monkey -help
  -p ***                                     指定包名,常用参数
  --throttle  100                             操作间隔100ms:常用参数,一般设置为300毫秒,原因是实际用户操作的最快300毫秒左右一个动作事件,所以此处一般设置为300毫秒。
       --randomize-throttle                      随机延迟,后面接数字如500时表示每次事件间隔在0~500ms之间随机延迟
  --ignore-crashes                            忽略崩溃,继续执行,常用参数
  --ignore-timeouts                           忽略超时,常用参数
  --ignore-security-exceptions         忽略许可错误,常用参数
  --monitor-native-crashes               监视并报告Andorid系统中本地代码的崩溃事件。如果设置--kill-process-after-error,系统将停止运行。
  -s                                                   用于指定伪随机数生成器的seed值,相同则两次事件序列也相同
       -v -v -v 1>D:\monkey.txt 2>D:\error.txt &       存放在电脑路径上,常用参数
    默认1个v(仅提供启动、测试完成和最终结果等少量信息),2个v(包括每个发送到Activity的事件信息),3个v(包括了测试中选中/未选中的Activity信息)比较常用的是3个
    -v,即最多详细信息,一般会保存到指定文件中供开发人员查找bug原因时使用。
  -v -v -v 1>/mnt/sdcard/monkey.txt 2>/mnt/sdcard/error.txt &   存放在手机路径上
    0 :标准输入
    1 :标准输出
               2 :标准错误输出
                &:后台运行,拔掉数据线,不影响测试
                >: 重定向,会覆盖原来文件里的内容
             >>: 重定向,追加到原来文件末尾 
  --pkg-whitelist-file  whitelist.txt     白名单,monkey执行对象
    创建白名单txt文件(含包名,多个包换行输入)后,adb push whitelist.txt /data/local/tmp/, 执行命令:
  • adb shell monkey --pkg-whitelist-file /data/local/tmp/whitelist.txt 100
  --pkg-blacklist-file  blacklist.txt     黑名单,monkey不执行对象,不能与白名单同时使用 

  -c <main-category>     如果你指定一个或多个类别,Monkey将只允许系统启动这些指定类别中列出的Activity。如果你不指定任何类别,Monkey将选择谢列类别中列出的ActivityIntent.CATEGORY_LAUNCHERIntent.CATEGORY_MONKEY。指定多个类别使用多个-c,每个-c指定一个类别。不常用。

   --dbg-no-events       设置此选项,Monkey将执行初始启动,进入一个测试Activity,并不会在进一步生成事件。为了得到最佳结果,结合参数-v,一个或多个包的约束,以及一个保持Monkey运行30秒或更长时间的非零值,从而提供了一个可以监视应用程序所调用的包之间转换的环境。不常用。

   --hprof       设置此选项,将在Monkey生成事件序列前后生成profilling报告。在data/misc路径下生成大文件(~5Mb),所以要小心使用。不常用。 

  --kill-process-after-error          通常,当Monkey由于一个错误而停止时,出错的应用程序将继续处于运行状态。设置此项,将会通知系统停止发生错误的进程。注意,正常(成功)的结束,并没有停止启动的进程,设备只是在结束事件之后简单的保持在最后的状态。

  --wait-dbg             停止执行中的Monkey,直到有调试器和它相连接。

  百分比事件:

  0:--pct-touch <percent>            调整点击事件百分比,即在屏幕某处按下并抬起的操作事件:常用参数,此参数设置要适应当前被测应用程序的操作,比如一个应用80%的操作都是触摸,那就可以将此参数的百分比设置成相应较高的百分比。
  1:--pct-motion <percent>          调整滑动事件百分比。(motion事件是由屏幕上某处一个down事件、一系列伪随机的移动事件和一个up事件组成):常用参数,需注意的是移动事件是直线滑动

  2:--pct-pinchzoom <percent>    调整缩放事件百分比,不常用。
  3:--pct-trackball <percent>       调整滚动球事件百分比。(滚动球事件由一个或多个随机的移动事件组成,有时会伴随着点击事件),不常使用参数,现在手机几乎没有滚动球,但滚动球事件中包含曲线滑动事件,在被测程序需要曲线滑动时可以选用此参数。

  4:-pct-roration <percent>         调整旋转屏幕事件百分比。
  5:--pct-nav <percent>              调整基本的导航事件百分比。(导航事件由方向输入设备的上下左右按键所触发的事件组成),不常用操作。
  6:--pct-majornav <percent>     调整主要导航事件的百分比。(这些导航事件通常会导致UI界面中的动作事件,如5-way键盘的中间键,回退按键、菜单按键),不常用。
  7:--pct-syskeys <percent>       调整系统事件百分比。(这些按键通常由系统保留使用,如Home、Back、Start Call、End Call、音量调节),不常用。
  8:--pct-appswitch <percent>    调整Activity启动的百分比。(在随机的时间间隔中,Monkey将执行一个startActivity()调用,作为最大程度覆盖被测包中全部Activity的一种方法),不常用。

  9:--pct-flip <percent>                调整唤出/隐藏键盘事件百分比。
  10:--pct-anyevent <percent>    调整其他事件的百分比。(这包含所有其他事件,如按键、其他在设备上不常用的按钮等)不常用。

七、常用测试命令?

  •   adb shell monkey -p com.chineseall.microbookroom -v -v -v 20000 >D:\monkey.txt
  •   adb shell monkey -p com.chineseall.microbookroom --ignore-crashes --ignore-timeouts --ignore-security-exceptions --ignore-native-crashes --monitor-native-crashes -v -v -v 20000 >D:\monkey.txt
  •        adb shell monkey -s 9372 -p com.chineseall.microbookroom --ignore-crashes --ignore-timeouts --ignore-security-exceptions --pct-trackball 0 --pct-nav 0 --pct-majornav 0 --pct-anyevent 0 -v -v -v --throttle 200 120000000 1> /mnt/sdcard/log.txt & 2>/mnt/sdcard/error.txt &

  •        adb shell monkey -s 9372 -p com.chineseall.microbookroom --ignore-crashes --ignore-timeouts --ignore-security-exceptions --pct-trackball 0 --pct-nav 0 --pct-majornav 0 --pct-anyevent 0 -v -v -v --throttle 200 120000000 1> D:\log.txt 2>D:\error.txt &
  •       adb shell monkey -s 6738 -p com.chineseall.microbookroom --ignore-crashes --ignore-timeouts --ignore-security-exceptions --pct-trackball 0 --pct-nav 0 --pct-majornav 0 --pct-anyevent 0 -v -v -v --throttle 200 120000000 > /mnt/sdcard/log.txt 2>&1 &    (xuelian)

  停止monkey:

  •   adb shell
  •   ps | grep monkey    //查看monkey对应的进程数
  •   kill pid(前面会输出)  // 杀进程

八、monkey日志分析?                     参考: https://testerhome.com/topics/12212

       

   测试结果初步判断:

  1.monkey执行时未加--ignore-crashes 参数,就先浏览日志中Events injected: 值,查看当前已执行的次数,就知道有无bug
    a、程序无响应,ANR问题:在日志中搜索“ANR”
    b、崩溃问题:在日志中搜索“CRASH”
    c、其他问题:在日志中搜索”Exception”
    d、内存泄漏问题搜索”GC”,并进一步分析

  2.常见的Java异常:

    算术异常类:ArithmeticExecption
    空指针异常类:NullPointerException     出现空指针,需要重视
    类型强制转换异常:ClassCastException
    文件已结束异常:EOFException
    文件未找到异常:FileNotFoundException
    数组负下标异常:NegativeArrayException
    数组下标越界异常:ArrayIndexOutOfBoundsException
    违背安全原则异常:SecturityException
    字符串转换为数字异常:NumberFormatException
    操作数据库异常:SQLException
    输入输出异常:IOException
    违法访问错误:IllegalAccessError
    内存不足错误:OutOfMemoryError
    堆栈溢出错误:StackOverflowError
    其他,请参考:https://www.cnblogs.com/cvst/p/5822373.html    

  3.找到错误信息后,monkey里面的哪个Activity出错,在switch后面找,两个swtich之间如果出现了崩溃或其他异常,可以在该Activity中查找问题的所在。

              

      查看Monkey里面出错前的一些事件动作,并手动执行该动作。Sleeping for XX milliseconds这是执行Monkey测试时,throttle设定的间隔时间,每出现一次,就代表一个事件,Sending XX 就是代表一个操作,如下图的两个操作 应该就是一个点击事件。

                 

   若以上步骤还不能找出,可以使用之前执行的monkey命令再执行一遍,注意seed值要一样。 

posted @ 2019-05-06 11:43  青域  阅读(835)  评论(3编辑  收藏  举报