Android自动化测试之MonkeyRunner使用

时间:2022-07-26 12:17:12

MonkeyRunner工具是使用Jython(使用Java编程语言实现的Python)写出来的,它提供了多个API,通过monkeyrunner API 可以写一个Python的程序来模拟操作控制Android设备app,测试其稳定性并通过截屏可以方便地记录出现的问题。

monkeyrunner和money没有什么直接的关系,monkey是在设备直接运行adb shell命令生成随机事件来进行测试的。相比较而言,monkeyrunner则是通过API发送特定的命令和事件通过工作站来控制设备。

MonkeyRunner测试功能

1.多设备控制:API可以跨多个设备,一次启动全部模拟器来实施测试套件;

2.功能测试:为应用自动执行一次功能测试,然后观察输出结果的截屏。

2.可扩展自动化:因为monkeyrunner是一个API工具包,你可以开发基于Python模块的整个系统来控制Android设备;

MonkeyRunner API

MonkeyRunner工具主要有三个类:MonkeyRunner、MonkeyDevice、MonkeyImage.

1.MonkeyRunner类:提供连接真机和模拟器方法waitForConnection(float timeout,string deviceid),还有显示提示显示信息的alert()方法

2.MonkeyDevice类:提供了安装和卸载程序包、开启Activity、发送按键和点击事件、运行测试包等方法

拖拉控件drag(tuple start,tuple end,float duration,integer steps)  //duration手势持续时间

按键press(string keycode,dictionary type) //keycode:KEYCODE_HOME,..其它参考这里

type:DOWN ,UP,DOWN_AND_UP...

安装应用 installPackage(pc端存放apk路径)

启动应用starActivity(package+'/'+activity)//一个参数

点击touch(integer x,integer y, integer type) //type:DOWN,UP,DOWN_AND_UP...

输入type(string message)

截屏 takeSnapshot()

3.MonkeyImage类:在测试过程中用来保存测试截图,保存各种格式,并可以比较两个MonkeyImage对象

图像对比sameAs(MonkeyImage other,float percent)//对比的相似度,结果boolean类型

图像保存writetoFile(string path,string format)

MonkeyRunner运行使用

可以直接使用一个代码文件运行monkeyrunner,抑或在交互式对话中输入monkeyrunner语句。不论使用哪种方式,你都需要调用SDK目录的tools子目录下的monkeyrunner命令。如果提供一个文件名作为运行参数,则monkeyrunner将视文件内容为python程序,并加以运行;否则,它将提供一个交互对话环境。

cmd 运行Monkeyrunner进入交互命令行

Android自动化测试之MonkeyRunner使用

前提是先配置好tools路径环境变量

编写页面操作的python脚本

test.py

  1. #-*-UTF-8-*-
  2. from com.android.monkeyrunner import MonkeyRunner as mr
  3. from com.android.monkeyrunner import MonkeyDevice as md
  4. from com.android.monkeyrunner import MonkeyImage as mi
  5. #连接设备
  6. device=mr.waitForConnection(2,'192.168.56.101:5555')
  7. device.installPackage('D:\\baiduliulanqi_186.apk')
  8. #启动APP
  9. device.startActivity('cmp=com.baidu.browser.apps/com.baidu.browser.framework.BdBrowserActivity')
  10. mr.sleep(3)
  11. #点击搜索框
  12. device.touch(100,100,'DOWN_AND_UP')
  13. mr.sleep(1)
  14. #输入查询词
  15. device.type('test')
  16. mr.sleep(1)
  17. #点击回车键
  18. device.press('KEYCODE_ENTER','DOWN_AND_UP')
  19. mr.sleep(2)
  20. #截图
  21. result=device.takeSnapshot()
  22. #保存到文件
  23. result.writeToFile('./test.png','png')
  24. #清除搜索框
  25. device.touch(100,100,'DOWN_AND_UP')
  26. mr.sleep(1)
  27. device.press('KEYCODE_DEL','DOWN_AND_UP')
  28. mr.sleep(2)

运行测试脚本test.py:monkeyrunner test.py

monkeyrunner 录制和回放

录制:monkey_recorder.py

  1. from com.android.monkeyrunner import MonkeyRunner as mr
  2. from com.android.monkeyrunner.recorder import MonkeyRecorder as recorder
  3. device=mr.waitForConnection()
  4. recorder.start(device)
在 cmd 命令行运行 monkeyrunner  monkey_record.py,会弹出一个MonkeyRecord窗口界面该窗口的功能:
Android自动化测试之MonkeyRunner使用

1、可以自动显示手机当前的界面
     2、自动刷新手机的最新状态
     3、点击手机界面即可对手机进行操作,同时会反应到真机,而且会在右侧插入操作脚本
     4:、wait: 用来插入下一次操作的时间间隔,点击后即可设置时间,单位是秒
            Press a Button:用来确定需要点击的按钮,包括menu、home、search,以及对按钮的press、down、up属性
            Type Something:用来输入内容到输入框
             Fling:用来进行拖动操作,可以向上、下、左、右,以及操作的范围
             Export Actions:用来导出脚本,不需要后缀名,也可以添加后缀名.mr
             Refresh Display:用来刷新手机界面,估计只有在断开手机后,重新连接时才会用到

用录制函数导出操作的脚本,通过monkey_playback.py函数回放之前的操作

回放:monkey_playback.py,

  1. import sys
  2. from com.android.monkeyrunner import MonkeyRunner as mr
  3. CMD_MAP = {
  4. 'TOUCH':lambda dev,arg:dev.touch(**arg),
  5. 'DRAG': lambda dev,arg:dev.drag(**arg),
  6. 'TYPE': lambda dev,arg:dev.type(**arg),
  7. 'PRESS': lambda dev,arg:dev.press(**arg),
  8. 'WAIT': lambda dev,arg:mr.sleep(**arg)
  9. }
  10. def process_file(f,device):
  11. for line in f:
  12. (cmd,rest)=line.split('|')
  13. try:
  14. rest = eval(rest)
  15. except:
  16. print 'unable to parse options'
  17. continue
  18. if cmd not in CMD_MAP:
  19. print 'unknown command: ' + cmd
  20. continue
  21. CMD_MAP[cmd](device, rest)
  22. def main():
  23. file = sys.argv[1]
  24. f = open(file,'r')
  25. device = mr.waitForConnection()
  26. process_file(f,device)
  27. f.close()
  28. if __name__ = '__main__'
  29. main()

。。。。。