眼下android SDK里自带的现成的測试工具有monkey 和 monkeyrunner两个。大家别看这俩兄弟名字相像,但事实上是完全然全不同的两个工具,应用在不同的測试领域。总的来说,monkey主要应用在压力和可靠性測试上,执行该命令能够随机地向目标程序发送各种模拟键盘事件流,而且能够自定义发送的次数,以此观察被測应用程序的稳定性和可靠性,应用起来也比較简单,记住那几个命令即可了。而monkeyrunner呢,相比之下会强大一些,它主要可应用于功能測试,回归測试,而且能够自定义測试扩展,灵活性较强,而且測试人员能够全然控制。

本篇乃本人学习monkeyrunner时笔记,查看网络中的资料并经本人測试而出,因为本人刚接触,所以本篇内容不免肤浅,高手们请绕走~

在測试本人下面实例时,请自行搭建Android环境。

一、打开模拟器

执行monkeyrunner之前必须先执行对应的模拟器,不然monkeyrunner无法连接设备。

用Elipse打开Android模拟器或在CMD中用Android命令打开模拟器。这里重点讲一下在CMD中用Android命令打开模拟器

命令:emulator -avd test
(注意:test为虚拟设备的名称——AVD的全称为:Android Virtual Device,就是Android执行的虚拟设备,例如以下图所看到的:)

上面命令中的test是模拟器名称。使用时须要改成实际名字。

假设正常,模拟器应该能够启动起来了。

假设运行的结果出现下面错误内容:

PANIC: Could not open: C:\Documents and Settings\sAdministrator\.android/avd/test.ini

例如以下图所看到的:

原因在于你的环境变量缺少配置。请在“系统变量”中加入“ANDROID_SDK_HOME”,设置其值为“C:\Documents and Settings\Administrator”(注意:这里的值不能为C:\Documents and Settings\Administrator\.android),例如以下图所看到的:

确定后,关闭CMD窗体,又一次打开CMD。运行以上命令。将会启用模拟器。

模拟器启动成功后,我们仍在CMD环境中操作。如今进入monkeyrunner的shell命令交互模式。

命令:monkeyrunner

进入shell命令交互模式后,首要一件事就是导入monkeyrunner所要使用的模块。直接在shell命令下输入:

from com.android.monkeyrunner import MonkeyRunner,MonkeyDevice 回车

OK,这步完毕我们就能够利用monkeyrunner进行測试工作了。

这里有两种方案,一是直接在shell命令下输入下面命令;

命令说明

device=MonkeyRunner.waitForConnection() #连接手机设备

device.installPackage("../samples/android-10/ApiDemos/bin/Apidemos.apk") #安装apk包到手机设备。

启动当中的随意activity了,仅仅要传入package和activity名称就可以。命令例如以下:

device.startActivity(component="com.example.android.apis/com.example.android.apis.ApiDemos")

此时模拟器会自己主动打开ApiDemos这个应用程序的主页。

device.reboot() #手机设备重新启动

device.touch(300,300,'DOWN_AND_UP')

MonkeyRunner.alert("hello")#在emulator上会弹出消息提示

device.press('KEYCODE_HOME',MonkeyDevice.DOWN_AND_UP)

device.type('hello')#向编辑区域输入文本'hello'

二是将下面命令写到python文件中,比如test.py,然后我们再从命令行直接通过monkeyrunner执行它就可以。比方,我们还是用上面的样例,语法例如以下:monkeyrunner test.py 接下来monkeyrunner会自己主动调用test.py,并执行当中的语句,相当方便。

实例:test.py

from com.android.monkeyrunner import MonkeyRunner,MonkeyDevice
device=MonkeyRunner.waitForConnection()
device.startActivity(component="your.www.com/your.www.com.TestActivity")

在CMD中运行

monkeyrunner test.py

可能出现错误“Can't open specified script file”,例如以下图所看到的:

原因在于python脚本文件路径不对。你能够有下面解决的方法:

1、将test.py文件存放到monkeyrunner文件同一文件夹中。能够运行:monkeyrunner test.py 调用

2、指定python文件位置。假设test.py文件在D盘根文件夹下,能够这样运行:monkeyrunner d:\test.py

学习笔记

以下是学习中的笔记,有点乱。就放在本篇最后吧。

环境变量

变量名:ANDROID_SDK_HOME

变量值:C:\Documents and Settings\Administrator



变量名:Path

变量值:%SystemRoot%\system32;%SystemRoot%;C:\Python27;C:\py;D:\android\android-sdk-windows\tools;D:\android\android-sdk-windows\platform-tools





android自己主动化測试框架:CTS、monkey、monkeyrunner、benchmark

monkeyrunner

monkeyrunner工具提供了一个API,运用该API编写的程序能够不用通过android代码来直接控制android设备和模拟器,我们能够写一个python程序对android应用程序或測试包进行安装、执行、发送模拟击键,对用户界面进行截图并将截图存储在workstation上等操作。monkeyrunner工具的主要设计目的是用于測试application/framework层上的应用程序和设备、或用于执行单元測试套件,也能够用于其他目的。



monkey工具,是直接执行在设备或模拟器的adb shell中,生成用户或系统的伪随机事件流。



monkeyrunner为android測试提供了下面独特的功能:

1、多设备控制:monkeyrunner API能够跨多个设备或模拟器实施測试套件。能够在同一时间接上所有设备或一次启动所有模拟器,根据程序依次连接到每个,然后执行一个或多个測试。也能够用程序启动一个配置好的模拟器,执行一个或多个測试,然后关闭模拟器。

2、功能測试:monkeyrunner能够为一个应用自己主动贯彻一次功能測试。您提供按键或触摸事件的输入数值,然后观察输出结果的截屏。

4、回归測试:monkeyrunner能够执行某个应用,并将其结果截屏与既定已知正确的结果截屏相比較,以此測试应用的稳定性。

4、可扩展的自己主动化:因为monkeyrunner是一个API工具包,我们能够开发基于python模块和程式的一整套系统,以此来控制android设备。除了使用monkeyrunner API,我们还能够使用标准的python os和ubprocess模块来调用android debug bridge这种android工具。如ADB这种android工具,也能够将自己写的类加入到monkeyrunner API中。



执行monkeyrunner

能够直接使用一个代码文件执行monkeyrunner,抑或在交互式对话中输入monkeyrunner语句。不论使用哪种方式,你都须要调用SDK文件夹的tools子文件夹下的monkeyrunner命令。假设提供一个文件名称作为执行參数,则monkeyrunner将视文件内容为python程序,并加以执行;否则,它将提供一个交互对话环境。



monkeyrunner命令语法

monkeyrunner -plugin <plugin_jar> <programe_filename> <programe_option>

monkeyrunner API

主要包含三个模块

1、MonkeyRunner:这个类提供了用于连接monkeyrunner和设备或模拟器的方法,它还提供了用于创建用户界面显示提供了方法。

2、MonkeyDevice:代表一个设备或模拟器。这个类为安装和卸载包、开启Activity、发送按键和触摸事件、执行測试包等提供了方法。

3、MonkeyImage:这个类提供了捕捉屏幕的方法。这个类为截图、将位图转换成各种格式、对照两个MonkeyImage对象、将image保存到文件等提供了方法。



注意:在执行monkeyrunner之前必须先执行对应的模拟器,否则monkeyrunner无法连接到设备

执行模拟器有两种方法:1、通过eclipse中执行模拟器 2、在CMD中通过命令调用模拟器



这里介绍通过命令,在CMD中运行模拟器的方法



命令:emulator -avd test

上面命令中test是指模拟器的名称。



导入须要的模块

import sys

from com.android.monkeyrunner import MonkeyRunner as mr

from com.android.monkeyrunner import MonkeyDevice as md

from com.android.monkeyrunner import MonkeyImage as mi

假设给导入的模块起了别名,就应该使用别名,而不能使用原名,否则会出现错误。

比方连接设备或模拟器,起了以上别名后,命令应该例如以下:

device=mr.waitForConnection() 



也能够採用下面方式

from com.android.monkeyrunner import MonkeyRunner,MonkeyDevice,MonkeyImage



也能够採用这样的方式

import com.android.monkeyrunner

可是在使用时,就显得特别麻烦

device=com.android.monkeyrunner.MonkeyRunner.waitForConnection() 

我们也能够给它一个别名

import com.android.monkeyrunner as cam

可是在使用时,就显得特别麻烦

device=cam.MonkeyRunner.waitForConnection()



#等待连接到设备,与模拟器连接,返回monkeydevice对象,代表连接的设备。没有报错的话说明连接成功。

參数1:超时时间,单位秒,浮点数。默认是无限期地等待。

參数2:串deviceid,指定的设备名称。默觉得当前设备(手机优先,比方手机通过USB线连接到PC、其次为模拟器)。

默认连接:device=MonkeyRunner.waitForConnection()

參数连接:device = mr.waitForConnection(1.0,'emulator-5554')



向设备或模拟器安装要測试的APK

device.installPackage('myproject/bin/MyApplication.apk') #參数是相对或绝对APK路径

路径级别用“/”,不能用“\”,比方d:\www\a.apk,而应该写成d:/www/a.apk

成功安装返回true,此时查看模拟器我们能够在IDLE界面上看到安装的APK的图标了。





从设备中删除指定的软件包,包含其相关的数据和调整缓存

device.removePackage('myproject/bin/MyApplication.apk')

删除成功返回true。





#启动随意的Activity

device.startActivity(component="your.www.com/your.www.com.TestActivity")

或者

device.startActivity(component="your.www.com/.TestActivity")



此时能够向模拟器发送如按键、滚动、截图、存储等操作了。





运行一个adb shell命令,并返回结果,假设有的话

device.shell("...")



暂停眼下正在执行的程序指定的秒数

MonkeyRunner.sleep(秒数,浮点数)



获取设备的屏蔽缓冲区,产生了整个显示器的屏蔽捕获。(截图)

result=device.takeSnapshot()

返回一个MonkeyImage对象(点阵图包装),我们能够用下面命令将图保存到文件

result.writeToFile('takeSnapshot\\result1.png','png')



写文件MonkeyImage

MonkeyImage.writeToFile(參数1:输出文件名称,也能够包含路径,參数2:目标格式)

写成功返回true,否则返回false





键盘上的类型指定的字符串,这相当于要求每一个字符串中的字符按(键码,DOWN_AND_UP).

字符串发送到键盘

device.type('字符串')



唤醒设备屏幕(在设备屏幕上唤醒)

device.wake()



又一次引导到指定的引导程序指定的设备

device.reboot()

=========================================================

在指定位置发送触摸事件(x,y的单位为像素)

device.touch(x,y,TouchPressType-触摸事件类型)

发送到指定键的一个关键事件

device.press(參数1:键码,參数2:触摸事件类型)

參数1:见android.view.KeyEvent

參数2,如有TouchPressType()返回的类型-触摸事件类型,有三种。

1、DOWN 发送一个DOWN事件。指定DOWN事件类型发送到设备,相应的按一个键或触摸屏幕上。

2、UP 发送一个UP事件。指定UP事件类型发送到设备,相应释放一个键或从屏幕上抬起。

3、DOWN_AND_UP 发送一个DOWN事件,然后一个UP事件。相应于输入键或点击屏幕。

以上三种事件做为press()或touch()參数。原英文例如以下:

use this with the type argument of press() or touch() to send a down event.





为了模拟输入键,发送DOWN_AND_UP。





參数1的部分详细内容逻辑:

按下HOME键 device.press('KEYCODE_HOME',MonkeyDevice.DOWN_AND_UP) 

按下BACK键 device.press('KEYCODE_BACK',MonkeyDevice.DOWN_AND_UP) 

按下下导航键 device.press('KEYCODE_DPAD_DOWN',MonkeyDevice.DOWN_AND_UP) 

按下上导航键 device.press('KEYCODE_DPAD_UP',MonkeyDevice.DOWN_AND_UP) 

按下OK键 device.press('KEYCODE_DPAD_CENTER',MonkeyDevice.DOWN_AND_UP)





device.press('KEYCODE_ENTER',MonkeyDevice.DOWN_AND_UP)#输入回车

device.press('KEYCODE_BACK',MonkeyDevice.DOWN_AND_UP)#点击返回



home键 KEYCODE_HOME 

back键 KEYCODE_BACK 

send键 KEYCODE_CALL 

end键 KEYCODE_ENDCALL 

上导航键 KEYCODE_DPAD_UP 

下导航键 KEYCODE_DPAD_DOWN 

左导航 KEYCODE_DPAD_LEFT 

右导航键 KEYCODE_DPAD_RIGHT  

ok键 KEYCODE_DPAD_CENTER 

上音量键 KEYCODE_VOLUME_UP  

下音量键 KEYCODE_VOLUME_DOWN 

power键 KEYCODE_POWER 

camera键 KEYCODE_CAMERA 

menu键 KEYCODE_MENU

很多其它:http://developer.android.com/reference/android/view/KeyEvent.html

Android自己主动化測试之Monkeyrunner用法及实例的更多相关文章

  1. Android 自己主动化測试(3)&lt;monkeyrunner&gt; 依据ID查找对象&amp;touch&amp;type (python)

    我在之前的两篇文章中用java来实现过 Android 自己主动化測试(1)怎样安装和卸载一个应用(java).Android 自己主动化測试(2)依据ID查找对象(java). 可是本质上都是用mo ...

  2. Android自己主动化測试解决方式

    如今,已经有大量的Android自己主动化測试架构或工具可供我们使用,当中包含:Activity Instrumentation, MonkeyRunner, Robotium, 以及Robolect ...

  3. 【金阳光測试】大话Android自己主动化測试--Android自己主动化系列(1)--金阳光于2013年4月份

    Android自己主动化測试框架和工具在四年多的发展日趋成熟. 从五年前的第一代自己主动化架构演进到眼下第四代(本系列讲座第7篇后将具体剖析第三代和第四代自己主动化框架)从曾经最早谷歌推崇的monke ...

  4. Android 自己主动化測试之------ Monkey工具

    尽管 一般公司都有专门的測试人员,可是有时候 免不了 我们既要去开发产品,也要去測试产品,測试产品.有些机械化的 点界面的操作,谷歌已经给我们提供了工具.Monkey, 猴子測试. 什么是Monkey ...

  5. 使用Adt自带的工具进行Android自己主动化測试(三)

    在这个系列的上一篇文章中,我们介绍了MonkeyRunner,并提到假设依据坐标来编写自己主动化脚本的话存在着一定的局限性(点击文末"阅读原文"能够打开这篇文章查看).这篇文章将进 ...

  6. Android自己主动化測试——CTS測试

    一.为什么须要兼容性測试(下面称CTS)? 1.1.让APP提供更好的用户体验.用户能够选择很多其它的适合自己设备的APP.让APP更稳定. 1.2.让开发人员设计更高质量的APP. 1.3.通过CT ...

  7. MAC中在eclipse luna上搭建移动平台自己主动化測试框架(UIAutomator/Appium/Robotium/MonkeyRunner)关键点记录

    这几天由于原来在用的hp laptop的电池坏掉了,机器一不小心就断电.所以仅仅能花时间在自己的mackbook pro上又一次搭建整套环境.大家都知道搭建好开发环境是个非常琐碎须要耐心的事情,特别是 ...

  8. Android Monkey自己主动化測试

    前言 假设你做Android开发,还没有使用过Monkey进行測试,那么今天看到这篇文章,希望能解决你Android測试中的一些问题.起码能帮你省点測试的时间而且发现很多其它的问题. Monkey简单 ...

  9. iOS自己主动化測试的那些干货

    前言 假设有測试大佬发现内容不正确.欢迎指正,我会及时改动. 大多数的iOS App(没有持续集成)迭代流程是这种 也就是说.測试是公布之前的最后一道关卡.假设bug不能在測试中发现,那么bug 就会 ...

随机推荐

  1. 用B-树实现虚拟图书管理系统

    学校数据结构的课程实验之一. 用到的数据结构:B-树 基本功能:对虚拟书库的图书进行查看.增加.删除.修改. 主函数: #include <iostream> #include " ...

  2. JOB+MERGE 跨服务器同步数据

    为了解决单服务器压力,将库分服务器部署,但是原来用触发器实现的表数据同步就实现不了了. 因为总监老大不允许 开启分布式事务(MSDTC),我又不想为了一个几千行的基础数据做复制订阅. 于是乎决定用 J ...

  3. Class对象

    (一) 获得Class对象的四种方式 第1种方法:Object.getClass() 第2种方法:.class语法 第3种方法:Class.forName() 第4种方法:包装类的TYPE域 impo ...

  4. 有一种acm题目叫做,奇葩!

    本文全然没有技术含量,纯粹是娱乐. 我事实上想写点东西.可是近期好像做计算几何做得太多了,一种想说说不出东西的感觉,唯有写一下一些奇葩的题目了. HDU3337:Guess the number pi ...

  5. iOS开发-CGAffineTransformMakeRotation改变了中心解决的方法

    坑爹的.  为了这个问题折腾了2个小时. 恼.. 今天在写一个时钟demo的时候, 时针的旋转用到了CGAffineTransformMakeRotation, 按理说. 图像的旋转是以图像本身的中心 ...

  6. 【模拟】【HDU1443】 Joseph

    Joseph Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Sub ...

  7. android第一天错误

    1.自己写的activity并在AndroidManifest.xml中注册 在模拟机上运行时出现 No Launcher activity found! The launch will only s ...

  8. 工具使用 eclipse the user operation is waiting for Building Working to be completed。

    问题定位: 在使用 IDE开发时,学习一个新事物如语言,框架,出现错误时暂时无法判断是新写的代码错还是IDE使用错: 则编写简单的未使用该技术的test.java ,运行后还有异常出现,则不是代码问题 ...

  9. 使用NODEJS+REDIS开发一个消息队列以及定时任务处理

    作者:RobanLee 原创文章,转载请注明: 萝卜李 http://www.robanlee.com 源码在这里: https://github.com/robanlee123/RobCron 时间 ...

  10. 2015.4.10-C#入门基础(三)

    今天,我们聊一聊一些基本问题: 1.修饰符有哪些?有什么区别呢? 首先大家想到的应该是 public:特点是所属类的成员和非所属类的成员都可以访问 private:只有所属类的成员才可以访问 prot ...