zoukankan      html  css  js  c++  java
  • 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”)
  • 相关阅读:
    本周总结
    团队组队
    ListView之checkbox错位问题解决
    ListView
    ScrollView(滚动条)
    elementui中自定义Select选择器样式自定义
    element-ui中Select 选择器列表内容居中
    element-ui中Select 选择器去除点击时的淡蓝色边框
    vue和uni-app不同的类型绑定不同的类名
    根据年月日获取星期几
  • 原文地址:https://www.cnblogs.com/SunshineKimi/p/12243015.html
Copyright © 2011-2022 走看看