博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Monkey测试总结
阅读量:5146 次
发布时间:2019-06-13

本文共 8229 字,大约阅读时间需要 27 分钟。

Monkey测试总结

1.什么是Monkey

Monkey是Android中的一个命令行工具,可以运行在模拟器里或实际设备中。它向系统发送伪随机的用户事件流(如按键输入、触摸屏输入、手势输入等),   实现对正在开发的应用程序进行压力测试。        Monkey测试是一种为了测试软件稳定性、健壮性的快速有效的方法。Monkey程序由Android系统自带,使用Java语言写成,在Android文件系统中的存放路径是:/system/framework/monkey.jar。Monkey.   jar程序是由一个名为“monkey”的shell脚本来启动执行,shell脚本在Android文件系统中的存放路是:/system/bin/monkey;   这样就可以通过在CMD窗口中执行: adb shell monkey {+命令参数}来进行Monkey测试了。打开CMD窗口,输入adb shell ls /system/framework,可以查看到monkey.jar;同理,可查看monkey。

2.Monkey测试的特点

  • 测试的对象仅为应用程序包,有一定的局限性。
  • Monkey测试使用的事件流数据流是随机的,不能进行自定义。
  • 可对MonkeyTest的对象,事件数量,类型,频率等进行设置。

3.Monkey的基本用法

1)Monkey测试准备   在执行Monkey测试之前,我们需要下载ADB工具,并安装JDK v1.5以上的版本。ADB工具是谷歌提供的Android调试工具,可以通过linux命令行访问手机。   安装好JDK环境,下载adbtools之后,我们需要配置一下环境变量,把adbtools的存放路径添加到path中,我们可以开始进行Monkey测试。注:需要root权限。2)基本语法如下:$ adb devices   这个命令是查看当前连接的设备,?连接到计算机的android设备或者模拟器将会列出显示。$adb installadb install 
:这个命令将指定的apk文件安装到设备上adb install??-r
:如果加-r参数会覆盖原来安装的软件并保留数据注意:apk文件名不要使用中文且不要有空格号$ adb shell monkey [options]它启动指定的应用程序,并向其发送500 个伪随机事件:$ adb shell monkey -p your.package.name -v 500

4.monkey测试的相关的原理

monkey测试的原理就是利用socket通讯的方式来模拟用户的按键输入,触摸屏输入,手势输入等,看设备多长时间会出异常。当Monkey程序在模拟器或设备运行的时候,如果用户触发了比如点击,触摸,手势或一些系统级别的事件的时候,它就会产生随机脉冲,所以可以用Monkey用随机重复的方法去负荷测试你开发的软件。

5.monkey实例

1)启动Android模拟器2)在命令行中输入:adb devices查看设备连接情况3)在有设备连接的前提下,在命令行中输入:adb shell?进入shell界面4)查看data/data文件夹下的应用程序包。注:我们能测试的应用程序包都在这个目录下面5)以com.tencent.mobileqq为对象,进行monkey test

monkey -p com.tencent.mobileqq -v 500

6)另一种执行方法

adb shell monkey -p com.tencent.mobileqq -v 500>E:\monkey\test.log

6.Monkey测试的停止条件

Monkey Test执行过程中在下列三种情况下会自动停止:1)如果限定了Monkey运行在一个或几个特定的包上,那么它会监测试图转到其它包的操作,并对其进行阻止。2)如果应用程序崩溃或接收到任何失控异常,Monkey将停止并报错3)如果应用程序产生了应用程序不响应(application not responding)的错误,Monkey将会停止并报错。通过多次并且不同设定下的Monkey测试才算它是一个稳定性足够的程序。工作中为了保证测试数量的完整进行,我们一般不会在发生错误时立刻退出压力测试。monkey 测试命令如下:

adb shell monkey -p com.xy.android.junit -s 500 –ignore-crashes

–ignore-timeouts –monitor-native-crashes -v -v 10000 > E:\monkey\log.txt

Monkey测试是Android自动化测试里面使用比较简单的方法,可以很大程度检验我们的程序是否稳定,能否经得起压力测试,可以根据实际情况调整测试的强度和测试重点。Monkey测试只是一个模拟测试,很多时候跟实际情况时有差别的,所以这个只能是其中一个辅助测试。

基本命令

一、Monkey测试简介

Monkey测试是Android平台自动化测试的一种手段,通过Monkey程序模拟用户触摸屏幕、滑动Trackball、按键等操作来对设备上的程序进行压力测试,检测程序多久的时间会发生异常。

二、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

四、Monkey命令参数介绍

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个级别,分别对应的参数如下表所示:
  • 日志级别 Level 0

    示例 adb shell monkey -p com.htc.Weather –v 100

    说明 缺省值,仅提供启动提示、测试完成和最终结果等少量信息

  • 日志级别 Level 1

    示例 adb shell monkey -p com.htc.Weather –v -v 100

    说明??提供较为详细的日志,包括每个发送到Activity的事件信息?

  • 日志级别 Level 2

    示例 adb shell monkey -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 shell monkey -p com.htc.Weather –ignore-crashes 1000
    测试过程中即使Weather程序崩溃,Monkey依然会继续发送事件直到事件数目达到1000为止;
  • 示例2:adb shell monkey -p com.htc.Weather 1000

    测试过程中,如果Weather程序崩溃,Monkey将会停止运行。

  • 6) 参数:–ignore-timeouts

    用于指定当应用程序发生ANR(Application No Responding)错误时,Monkey是否停止运行。如果使用此参数,即使应用程序发生ANR错误,Monkey依然会发送事件,直到事件计数完成。

  • 7) 参数:–ignore-security-exceptions

    用于指定当应用程序发生许可错误时(如证书许可,网络许可等),Monkey是否停止运行。如果使用此参数,即使应用程序发生许可错误,Monkey依然会发送事件,直到事件计数完成。

  • 8) 参数:–kill-process-after-error

    用于指定当应用程序发生错误时,是否停止其运行。如果指定此参数,当应用程序发生错误时,应用程序停止运行并保持在当前状态(注意:应用程序仅是静止在发生错误时的状态,系统并不会结束该应用程序的进程)。

  • 9) 参数:–monitor-native-crashes

    用于指定是否监视并报告应用程序发生崩溃的本地代码。

  • 10) 参数:–pct-{+事件类别} {+事件类别百分比}

    用于指定每种类别事件的数目百分比(在Monkey事件序列中,该类事件数目占总事件数目的百分比)

  • –pct-touch {+百分比}

    调整触摸事件的百分比(触摸事件是一个down-up事件,它发生在屏幕上的某单一位置)
    adb shell monkey -p com.htc.Weather –pct-touch 10 1000

  • –pct-motion {+百分比}

    调整动作事件的百分比(动作事件由屏幕上某处的一个down事件、一系列的伪随机事件和一个up事件组成)adb shell monkey -p com.htc.Weather –pct-motion 20 1000

  • –pct-trackball {+百分比}

    调整轨迹事件的百分比(轨迹事件由一个或几个随机的移动组成,有时还伴随有点击)
    adb shell monkey -p com.htc.Weather –pct-trackball 30 1000
    –pct-nav {+百分比}

  • 调整“基本”导航事件的百分比(导航事件由来自方向输入设备的up/down/left/right组成)

    adb shell monkey -p com.htc.Weather –pct-nav 40 1000

  • –pct-majornav {+百分比}

    调整“主要”导航事件的百分比(这些导航事件通常引发图形界面中的动作,如:5-way键盘的中间按键、回退按键、菜单按键)
    adb shell monkey -p com.htc.Weather –pct-majornav 50 1000

  • –pct-syskeys {+百分比}

    调整“系统”按键事件的百分比(这些按键通常被保留,由系统使用,如Home、Back、Start Call、End Call及音量控制键)
    adb shell monkey -p com.htc.Weather –pct-syskeys 60 1000

  • –pct-appswitch {+百分比}

    调整启动Activity的百分比。在随机间隔里,Monkey将执行一个startActivity()调用,作为最大程度覆盖包中全部Activity的一种方法
    adb shell monkey -p com.htc.Weather –pct-appswitch 70 1000

  • –pct-anyevent {+百分比}

    调整其它类型事件的百分比。它包罗了所有其它类型的事件,如:按键、其它不常用的设备按钮、等等
    adb shell monkey -p com.htc.Weather

  • –pct -anyevent 100 1000* 指定多个类型事件的百分比:

    adb shell monkey -p com.htc.Weather –pct-anyevent 50 –pct-appswitch 50 1000
    注意:各事件类型的百分比总数不能超过100%;

monkey之monkey日志分析

一、初步分析方法:

Monkey测试出现错误后,一般的差错步骤为以下几步:

  • 找到是monkey里面的哪个地方出错
  • 查看Monkey里面出错前的一些事件动作,并手动执行该动作
  • 若以上步骤还不能找出,可以使用之前执行的monkey命令再执行一遍,注意seed值要一样

一般的测试结果分析:

  • ANR问题:在日志中搜索“ANR”
  • 崩溃问题:在日志中搜索“Exception”

二、详细分析monkey日志:

首先我们需要查看Monkey测试中是否出现了ANR或者异常,具体方法如上述。将执行Monkey生成的log,从手机中导出并打开查看该log; 在log的最开始都会显示Monkey执行的seed值、执行次数和测试的包名。具体方法如上述。  然后我们要分析log中的具体信息,方法如下:查看log中第一个Switch,主要是查看Monkey执行的是那一个Activity,譬如下面的log中,执行的是com.tencent.smtt.SplashActivity,在下一个swtich之间的,如果出现了崩溃或其他异常,可以在该Activity中查找问题的所在。
:Switch:#Intent;action=android.intent.action.MAIN;category=android.intent.category.LAUNCHER;launchFlags=0x10000000;component=com.tencent.smtt/.SplashActivity;end// Allowing start of Intent {act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER]cmp=com.tencent.smtt/.SplashActivity } in package com.tencent.smtt

在下面的log中,Sending Pointer ACTION_DOWN和Sending Pointer ACTION_UP代表当前执行了一个单击的操作;

Sleeping for 500 milliseconds这句log是执行Monkey测试时,throttle设定的间隔时间,每出现一次,就代表一个事件。
SendKey(ACTION_DOWN) //KEYCODE_DPAD_DOWN?代表当前执行了一个点击下导航键的操作;
Sending Pointer ACTION_MOVE代表当前执行了一个滑动界面的操作。

:Sending Pointer ACTION_DOWN x=47.0 y=438.0:Sending Pointer ACTION_UP x=47.0 y=438.0Sleeping for 500 milliseconds:SendKey (ACTION_DOWN): 20 //KEYCODE_DPAD_DOWN:SendKey (ACTION_UP): 20 //KEYCODE_DPAD_DOWNSleeping for 500 milliseconds:Sending Pointer ACTION_MOVE x=-2.0 y=3.0:Sending Pointer ACTION_MOVE x=4.0 y=-3.0:Sending Pointer ACTION_MOVE x=-5.0 y=-3.0:Sending Pointer ACTION_MOVE x=3.0 y=4.0:Sending Pointer ACTION_MOVE x=-4.0 y=1.0:Sending Pointer ACTION_MOVE x=-1.0 y=-1.0:Sending Pointer ACTION_MOVE x=-2.0 y=-4.0

如果Monkey测试顺利执行完成,在log的最后,会打印出当前执行事件的次数和所花费的时间;// Monkey finished代表执行完成。Monkey执行中断,在log的最后也能查看到当前已执行的次数。Monkey执行完成的log具体如下:

Events injected: 6000:Dropped: keys=0 pointers=9 trackballs=0 flips=0Network stats: elapsed time=808384ms (0ms mobile, 808384ms wifi, 0msnot connected)//Monkey finished

项目实践

  • 安装安卓SDK 配置环境
  • 连接真机或者模拟器
  • 打开测试app
  • 查看是否连接:adb devices
    (连接成功图示)
    这里写图片描述

没有apk,应用已经安装到手机或虚拟机中

1.logcat.清除logcat内容,使用命令adb logcat -c
.启动logcat,使用命令adb logcat ActivityManager:I *:s 启动要查看的程序,
2.dumpsys
(1)启动要查看的程序;
(2)命令行输入:
adb shell dumpsys window w |findstr \/ |findstr name=


5.获取apk包名:adb shell dumpsys window w |findstr \/ |findstr name=

这里写图片描述

6.输入命令进行测试app

adb shell monkey -p com.hanfujia.shq -s 500 –ignore-crashes –ignore-timeouts –monitor-native-crashes -v -v 10000 > E:\monkey_log.txt
产生时间序列的种子值:500
忽略程序崩溃 、 忽略超时 、 监视本地程序崩溃 、 详细信息级别为2 , 产生 10000个事件
monkey作用的包:com.hanfujia.shq
7.查看log并截取CRASH处log发给开发工程师

转载于:https://www.cnblogs.com/Mrking2017/p/7684096.html

你可能感兴趣的文章
如何在mysql查找效率慢的SQL语句
查看>>
斯大林格勒拖拉机厂LCA项目研制成功
查看>>
git 分支
查看>>
Why And When To Use Pre-Update and Pre-Insert Triggers In Oracle Forms
查看>>
7zip在DOS命令行用法总结
查看>>
死锁AB-BA问题
查看>>
<WEB>平板_手机开发_13 个处理触摸事件和多点触摸的JS 库
查看>>
JS方法在iframe父子窗口间的调用
查看>>
笔记本上任务栏显示电池电量使用情况的图标不见了怎么办?
查看>>
Xcode开发 字符串用法
查看>>
在IIS中实现JSP
查看>>
[转载]Meta标签详解
查看>>
File,FileStream,byte[]3者互相转换总结(转)
查看>>
springboot 使用devtools 实现热部署
查看>>
Yahoo网站性能最佳体验的34条黄金守则
查看>>
forward与redirect的区别
查看>>
网络编程之socket
查看>>
Maven pom项目部署
查看>>
Cognos报表验证(添加字段)
查看>>
JavaScript Practices
查看>>