monkey测试的相关命令



monkey是模拟用户触摸操作,不支持条件判断。
monkey命令格式: 
启动安卓模拟器/真机
点击运行->输入cmd->进入命令行界面
查看设备连接情况,adb devices
在命令行界面输入monkey命令 
-p 用于约束一个限制,例如只想测试某一个app
   adb shell monkey --作为整机测试
   adb shell monkey -p [包名] 100(触发次数) 作为对一个app进行测试
        -s 用于复现异常使用          
           adb shell monkey -p [包名] -s 100 99 
        -v 用于指定反馈信息的日志级别  总共分3个级别
           -v 是一个 level0
           -v -v     level1 
           -v -v -v  level2
           adb shell monkey -p [包名] -s 100  -v -v -v 99  显示日志信息
           adb shell monkey -p [包名] -s 100  -v -v -v 99 >D:\monkey.txt 保存日志到本地
        --throttle  <毫秒> 用于延长点击时间
           adb shell monkey -p [包名] -s 100  -v -v -v  --thrrottle 500 99 >D:\monkey.txt
        --randomize-throttle 在事件之间插入随机延迟  随机延迟范围为0到throttle设定的时间,单位为毫秒
        --pkg-whitelist-file 白名单,后面接txt文件
           用命令将白名单推送到手机中,adb push <本地路径文件> /data/local/tmp 
           用命令  adb shell monkey --pkg-whitelist-file /data/local/tmp/whitelist.txt 100(100指的是测试次数)
       --pkg-blacklist-file 黑名单,后面接txt文件
           用命令将白名单推送到手机中,adb push <本地路径文件> /data/local/tmp 
           用命令  adb shell monkey --pkg-blacklist-file /data/local/tmp/whitelist.txt 100(100指的是测试次数)
       monkey常见参数-百分比事件
        --pct-touch {+百分比}:0
   翻译触摸,触摸事件泛指发生在某一位置的一个down-up事件,点击
adb shell monkey -p cn.trichat.angus999  --pct-touch 10  10

--pct-motion {+百分比}:1
   翻译动作,动作事件泛指从某一位置接下(即down事件)后经过一系列伪随机事件后弹出(即up事件)
--pct-pinchzoom {+百分比}:2
   翻译二指缩放,智能机上的放大缩小手势操作事件
--pct-trackball {+百分比}: 3
   翻译轨迹,轨迹事件包括一系列的随机移动,以及偶尔跟随在移动后面的点击事件
--pct-rotation {+百分比}:4
   翻译屏幕旋转,横屏竖屏事件
--pct-nav {+百分比}:5
       翻译基本导航,基本导航事件主要来自方向输入设备的上、下、左、右事件
--pct-majornav {+百分比}:6
   翻译主要导航,主要导航事件通常指引发图形界面的一些动作,如键盘中间按键、返回按键、菜单按键等
--pct-syskeys {+百分比}:7
   翻译系统按键,系统按键事件通常指仅供系统使用的保留按键,如HOME键、BACK键、拨号键、挂断键、音量键等
--pct-appswitch {+百分比}:8
   翻译应用启动,应用启动事件(activity launches)即打开应用,通过调用startActivity()方法最大限度地开启该package下的所有应用
--pct-flip {+百分比}:9
   翻译翻转,键盘轻弹百分比,如点击输入框,键盘弹起,点击输入框以外区域,键盘收回
        --pct-anyevent {+百分比}:10
   翻译其他类型,其他类型事件指上文中未涉及的所有其他事件,如keypress、不常用的button等 



 

 

日志分析



 命令:
  adb devices  --检测设备  
      list of devices attached  设备列表
  adb connect 127.0.0.1:62001
     -- 用于连接模拟器设备
  adb pull <手机路径文件> <本地路径>  
     -- 文件从手机端复制到本地
  adb push <本地路径文件> <手机路径> 
     -- 文件从本地端复制到手机端
  
  adb logcat  打印日志
     adb logcat >D:logcat.log 用于将日志输出到本地路径  然后用ctrl+终止,日志会在logcat.log中
  adb install xxx.pak  安装apk命令,success说明已经按照好了。
  
  adb uninstall com.tencent.mobileqq --卸载应用
  
  adb uninstall -k com.tencent.mobileqq -- 卸载应用但保留数据和缓存文件

  adb shell dumpsys activity | find mFocusedActivity  --查看前台应用activity名(前两天从Android 7.0升级到Android 8.0,今天在用 adb shell dumpsys activity | findstr "mFocusedActivity"来获取当前活跃的activity时,发现什么也没得到,后来百度得知,命令换了,应该用 adb shell dumpsys activity | findstr "mResumedActivity")
  
  全民养牛包名:cn.trichat.angus999
  adb connect/disconnect 通过wifi进行远程连接手机进行调试
  
  adb tcpip 5555 确定手机端和电脑端的wifi通讯端口。 用于  wifi远程连接


logcat 日志文件 分析命令

  adb  logcat  -b radio --抓起特定模块的log   不加-b radio 默认抓起main的log
  radio:输出通讯系统的log   例如:wifi,蓝牙之类
  System:输出系统组件的log   例如:想要调用摄像头,麦克风之类的
  Events:输出Event模块的log  事件模块,例如手指点击事件。
  Main:所有java层的log(不属于上面3层的log)

  logcat日志由五部分组成:
  1.写下日志的时间,如:2019-05-11 15:50:15
  2.优先级,在Android中,日志的优先级从低到高分以下几种
    V-Verbose(啰嗦,最低级别,开发调试中的一些详细信息,仅在开发中使用,不可在发布产品中)
    D-Debug(调试,用于调试的信息,可以在发布产品中关闭,比较常见)
    I-Info(信息,一般提示性的消息)
    W-Warnlng(警告)  
    E-Error(错误,已经出现可能影响运行的错误,比如应用crash时输出的日志)
  3.标签(tag),标明日志发起者或者方便日志的过滤筛选,I/admin  中的admin 
  4.PID(进程ID),如 I/admin(491)
  5.正文,本日志的主体内容
  
  对于产生崩溃的程序,可以搜索崩溃的日志关键字:FATAL EXCEPTION
  对于无响应的程序,通过查看前台应用activity名来确定ANR的位置,同时,通过发生ANR,将信息记录到一个路径:/data/anr/traces.txt中,traces只能保留最新一次的ANR
  对于多次无响应的问题,可以到/data/system/dropbox中找ANR,同时可以通过ls -l 来查看日志创建时间 



 



执行测试:



将文件传到手机端
adb push C:\Users\Administrator\Desktop\monkeyScriptMain.txt  /sdcard/

开始自动化测试
adb shell monkey -f /sdcard/monkeyScriptMain.txt -v -v -v 1 >D:log.txt