51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 3687|回复: 0
打印 上一主题 下一主题

[原创] Monkey稳定性测试实战之Monkey对APP随机测试

[复制链接]
  • TA的每日心情
    擦汗
    昨天 09:02
  • 签到天数: 1046 天

    连续签到: 4 天

    [LV.10]测试总司令

    跳转到指定楼层
    1#
    发表于 2020-12-15 09:18:36 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
     摘要:Monkey测试是Android平台自动化测试的一种手段,通过Monkey程序模拟用户触摸屏幕、滑动Trackball、按键等操作来对设备上的程序进行压力测试,检测程序多久的时间会发生异常。开发人员结合monkey 打印的日志 和系统打印的日志,修改测试中出现的问题, Monkey 是SDK中附带的一个工具,所有的事件都是随机产生的,不带任何人的主观性。
      Monkey程序介绍
      1) Monkey程序由Android系统自带,使用Java语言写成,在Android文件系统中的存放路径是:/system/framework/monkey.jar
      2) Monkey.jar程序是由一个名为“monkey”的Shell脚本来启动执行,shell脚本在Android文件系统中的存放路径是:/system/bin/monkey;
      这样就可以通过在CMD窗口中执行: adb shell monkey {+命令参数}来进行Monkey测试了。


    Monkey命令的简单帮助
      要获取Monkey命令自带的简单帮助,在CMD中执行命令: adb shell monkey –help
      环境搭建
      安装通过 adb命令 安装 apk包 : adb install apk包名。

    根据自己的需要,使用其它命令对apk进行测试: 比如通过adb shell monkey -v -p com.xx.xx 100来简单输出测试信息,如图:

     随机测试
      查看apk包名:Cmd  -->cd apk安装包目录下  aapt dump badging 包名.apk

    或者直接查看手机中存在的apk包,进入adb shell 命令后-手机的data/data文件夹-ls查看所有包名找到要测apk的包名
      Cmd -> adb shell -> cd data/data -> ls

    运行Monkey,对此包进行300 次无规律点击测试在adb shell环境中:monkey –p 包名字 –v 300

    或者在windows外面执行该命令:adb shell monkey -p 包名字 -v 300

    或者运行monkey,对此包进行300次无规律点击后将日志导出到电脑的某一位置  adb shell -p  包名 -v 点击数 > 电脑某一位置

    测试停止后,查看导出的monkey日志,发现问题。

    在log的最开始都会显示Monkey执行的seed值、执行次数和测试的包名。  首先我们需要查看Monkey测试中是否出现了ANR或者异常,
      无响应问题(ANR问题):在日志中搜索“ANR ”(此处有空格)
      崩溃问题:在日志中搜索“Exception”,快速定位到关键事件信息
      然后查看Monkey里面出错前的一些事件动作,并手动执行该动作,找出重现步骤,给开发。
      命令讲解

    monkey –p  com.tencent.mtaexample  -s 23  --throttle2000 --ignore-crashes --ignore-timeouts -v -v -v 100000>/data/local/tmp/log.txt 2>&1 &  1. -p后面接着的对应的包名,如果是整机测试,就不需要 -ppackage_name
      2. --ignore-crashes --ignore-timeouts 这里是在monkey测试的过程中遇到carash或者timeout的情况时忽略掉,一般不设置时,出现carash或者timeout时,Monkey测试会终止。这里是防止Monkey测试终止。
      3. -v 指的是Monkey测试时打印log级别。
      4. 100000 这里是指点击的次数,对于单个应用程序这个次数设置在100000次就可以了;如果是整机,一般设置在500000次。/data/local/tmp/log.txt测试的log记录在手机上/data/local/tmp/ 下面的log.txt里面,这个名字可以自己写。
      5. 2>&1 固定的写法,这个也很重要,代表的意思是中间忽略的东东的日志一并输入到指定的文件中。
      6. 最后单独的一个"&" 是一旦Monkey测试开始了,之后可以拔掉数据线,不会影响Monkey测试。
      7. 测试所有模块  monkey  -s 23 --ignore-crashes --ignore-timeouts -v-v -v 100000> /data/local/tmp/log.txt 2>&1 &
      参数详解
      1)参数: -p
      参数-p用于约束限制,用此参数指定一个或多个包(Package,即App)。指定包之后,Monkey将只允许系统启动指定的APP。如果不指定包,Monkey将允许系统启动设备中的所有APP。
      * 指定一个包:adb shell monkey -p com.htc.Weather 100
      说明:com.htc.Weather为包名,100是事件计数(即让Monkey程序模拟100次随机用户事件)。
      * 指定多个包:adb shell monkey -p com.htc.Weather –p com.htc.pdfreader  -p com.htc.photo.widgets 100
      * 不指定包:adb shell monkey 100
      说明:Monkey随机启动APP并发送100个随机事件。
      *要查看设备中所有的包,在CMD窗口中执行以下命令:
      >adb shell
      #cd data/data
      #ls
      2) 参数:  -v 日志详细程度
      用于指定反馈信息级别(信息级别就是日志的详细程度),总共分3个级别,分别对应的参数如下表所示:
      日志级别 Level0
      示例 adb shellmonkey -p com.htc.Weather –v 100  说明缺省值,仅提供启动提示,测试完成和最终结果等少量信息
      日志级别 Level 1
      示例 adb shellmonkey -p com.htc.Weather –v -v 100   说明提供较为详细的日志,包括每个发送到Activity的事件信息
      日志级别 Level 2
      示例 adb shellmonkey -p com.htc.Weather –v -v –v 100   说明最详细的日志,包括了测试中选中/未选中的Activity信息
      3)参数:  -s
      用于指定伪随机数生成器的seed值,如果seed相同,则两次Monkey测试所产生的事件序列也相同的。
      * 示例:
      Monkey测试1:adb shell monkey -p com.htc.Weather –s 10 100
      Monkey 测试2:adb shell monkey -p com.htc.Weather–s 10 100
      两次测试的效果是相同的,因为模拟的用户操作序列(每次操作按照一定的先后顺序所组成的一系列操作,即一个序列)是一样的。操作序
      列虽然是随机生成的,但是只要我们指定了相同的Seed值,就可以保证两次测试产生的随机操作序列是完全相同的,所以这个操作序列伪随机的;

     4) 参数:  --throttle <毫秒>  用于指定用户操作(即事件)间的时延,单位是毫秒;
      * 示例:adb shell monkey -p com.htc.Weather –throttle 3000 100
      5) 参数:  --ignore-crashes
      用于指定当应用程序崩溃时(Force& Close错误),Monkey是否停止运行。如果使用此参数,即使应用程序崩溃,Monkey依然会发送事件,直到事件计数完成。
      *示例1:adb shellmonkey -p com.htc.Weather --ignore-crashes 1000
      测试过程中即使Weather程序崩溃,Monkey依然会继续发送事件直到事件数目达到1000为止;
      * 示例2:adb shellmonkey -p com.htc.Weather 1000
      测试过程中,如果Weather程序崩溃,Monkey将会停止运行。
      禁用进程
      如果想中断运行中的monkey CTRL+C
      adb shell ps | grep monkey  返回进程号
      adb shell kill [刚才查到的进程号]
      查看包名
      A、手机安装包名查看器'
      B、aapt命令:  aapt dump badging  *.apk
      C、源码下AndroidManifest.xml文件查看(需要将apk解压)
      D、adb logcat抓取当前Android机运行的app的包名命令行输入adb logcat > e:\bag.txt
      手机操控app,ctrl+c停止,去e:\bag.txt这个文件下搜索关键字如Displayed ,一般都能找到!
      将喜欢的一切留在身边,这便是努力的意义。





    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有帐号?(注-册)加入51Testing

    x
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-15 00:36 , Processed in 0.070501 second(s), 24 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表