MonkeyRunner简介

简介: monkeyrunner工具提供了编写控制Android设备或仿真器从Android的代码之外程序的API。随着monkeyrunner,您可以编写安装一个Android应用程序或测试包,运行它,发送击键它,需要它的用户界面截图,并将截图工作站上的Python程序。

monkeyrunner工具提供了编写控制Android设备或仿真器从Android的代码之外程序的API。随着monkeyrunner,您可以编写安装一个Android应用程序或测试包,运行它,发送击键它,需要它的用户界面截图,并将截图工作站上的Python程序。该monkeyrunner工具主要设计在功能/框架水平和运行单元测试套件来测试应用程序和设备,但你可以自由地将其用于其它用途。

monkeyrunner工具为Android的测试,这些独特的功能:

1.多设备控制:monkeyrunner API可以跨多个设备或仿真器应用一个或多个测试套件。您可以物理连接的所有设备或启动了所有的仿真器(或两者兼有)同时,连接到每一个轮流程序,然后运行一个或多个测试。您也可以启动一个模拟器配置编程,运行一个或多个测试,然后关闭模拟器。
2.功能测试:monkeyrunner可以运行Android应用程序的自动启动到完成测试。您提供的输入值与键盘或触摸事件,并查看结果的截图。
3.回归测试 - monkeyrunner可以运行一个应用程序,并比较其输出截图一组被称为是正确的截图测试应用程序的稳定性。
4.可扩展的自动化-由于monkeyrunner是一个API工具包,你可以开发基于Python模块和控制Android设备程序的整个系统。除了 ​​使用monkeyrunner API本身,你可以使用标准的Python OS和 子 模块的调用Android的工具,比如 Android的调试桥。

monkeyrunner 的三个模块

所述monkeyrunner API被包含在包中的三个模块 com.android.monkeyrunner:
1.MonkeyRunner:一类为monkeyrunner程序的实用方法。这个类提供了用于连接monkeyrunner至设备或模拟器的方法。它也提供了用于创建用户界面的monkeyrunner程序和用于显示内置帮助的方法。
2.MonkeyDevice:表示一个设备或模拟器。这个类提供了安装和卸载程序包,启动一个活动以及发送键盘或触摸事件到应用程序的方法。您也可以使用这个类来运行测试包。
3.MonkeyImage:表示一个屏幕捕获图像。这个类提供了捕捉屏幕,将位图图像,以各种不同的格式,比较两个MonkeyImage对象,写一个图像文件的方法。

1
2
3
4
#导入三个模块MonkeyRunner,MonkeyDevice,MonkeyImage
from  com.android.monkeyrunner  import  MonkeyRunner as mr
from  com.android.monkeyrunner  import  MonkeyDevice as md
from  com.android.monkeyrunner  import  MonkeyImage as mi

monkeyrunner的接入设备API

adb devices 命令可以获取设备对象的名称

1
2
3
#获取接入的设备,前面的为等待时间(s),后面正则或者设备的全名,返回一个device对象
#device=mr.WaitForConnection(1,'ss1z1')
device = mr.WaitForConnection()

安装apk

device.startActivity("package名/activity名")

1
device.installPackage( 'myproject/bin/MyApplication.apk' )

卸载,这应该是应用的包名

1
device.removePackage ( 'com.example.android.notepad' )

启动入口活动

1
device.startActivity (component = 'com.android.htccontacts/com.android.htccontacts.ContactsTabActivity' )

等待时间,秒

1
mr.sleep( 3 )

唤醒屏幕

1
mr.wake()

触摸屏幕,x,y坐标,触摸类型三种,UP,DOWN,DOWN_AND_UP

1
device.touch( 10 , 20 ,DOWN_AND_UP)

设备屏幕上模拟拖曳

用法:MonkeyDevice.drag(start,end,duration,steps)
start:拖曳开始坐标 - The starting point for the drag (a tuple (x,y) in pixels)
end:拖曳结束坐标点- The end point for the drag (a tuple (x,y) in pixels
duration:持续时间 - Duration of the drag in seconds (default is 1.0 seconds)
steps:拖曳步骤- The number of steps to take when interpolating points. (default is 10)

1
device.drag(( 472 , 1067 ),( 482 , 560 ))  

按键指令,前面为按键名称,如HOME键

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
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
 
device.press( 'KEYCODE_HOME' , 'DOWN_AND_UP' )

  

输入一个字符串

device.type("你好")

获取monkeyrunner的帮助

1
device. help ()

获取设备系统环境变量的名称

1
device.getProperty()

重启设备

1
device.reboot()

一些图片的操作API

1
2
3
4
5
6
7
8
9
10
11
12
13
#获取截图
result1 = device.takeSnapshot()
#将结果输出到文件,前面为路径,后面为图片类型,可写可不写
result1.writeToFile( 'D:/demo1.png' , 'png' )
#两种写法都可以
result1.writeToFile( 'D:\\demo1.png' , 'png' )
#将当前图像转换为一个特定的格式并将其作为字符串返回,然后你可以访问的iterable二进制字节。
result.convertToBytes()
#图片的对比,先获取第二张截图
result2 = device.takeSnapshot()
result2.writeToFile( 'D:/demo2.png' , 'png' )
#判断图片相识度是否是为90%
if (result1.sameAs(result2, 0.9 )):

  

相关文章
|
运维 Java 应用服务中间件
Tomcat详解(三)——tomcat多实例
Tomcat详解(三)——tomcat多实例
240 1
资源块|带你读《5G空口特性与关键技术》之九
3GPP TS38.211 中对 Point A 进行了定义。需要说明的是,2018/6 版本的TS38.211-f20 中的定义在 2018/9 版本中没有变化,不过在2018/12 版本 TS38.211-f40 中,基于 RAN1#94b 会议的决议进行了修改,有关信息请参看 RAN1#94b会议报告以及提案 R1-1811817 和 R11810834。
12325 1
资源块|带你读《5G空口特性与关键技术》之九
|
域名解析 弹性计算 云计算
【深度好文】中小企业上云,为什么做好网络架构规划很重要!
本文通过一位小微软件公司技术负责人的实际体验为始,引发了对大量小微企业上云架构实践的研究。 发现中小企业上云时,往往聚焦于业务测试和服务尽快上线,很难有精力投入在云上技术架构的规划和设计中。所以,大家云上的架构五花八门,很多架构缺乏长远规划,极可能给业务未来发展埋下隐患。 基于此,我们沉淀了一套《应用上云经典托管架构》,强调了上云架构规划对于业务的重要性,并带领大家理解了方案中的网络规划和架构设计全过程。 作为从事企业上云IT部门,或者初创事业的个人开发者们,都可以参考和了解。
|
8月前
|
人工智能 API 语音技术
WhisperChain:开源 AI 实时语音转文字工具!自动消噪优化文本,效率翻倍
WhisperChain 是一款基于 Whisper.cpp 和 LangChain 的开源语音识别工具,能够实时将语音转换为文本,并自动清理和优化文本内容,适用于会议记录、写作辅助等多种场景。
2418 2
WhisperChain:开源 AI 实时语音转文字工具!自动消噪优化文本,效率翻倍
|
8月前
|
缓存 Ubuntu Linux
Docker Buildx 简介与安装指南
Docker Buildx 是一个强大的工具,提供了多架构构建、并行构建和高级缓存管理等功能。通过正确安装和配置 Buildx,可以显著提升 Docker 镜像的构建效率和灵活性。希望本文能帮助你更好地理解和使用 Docker Buildx,以提高开发和部署的效率。
4161 16
|
8月前
|
机器学习/深度学习 人工智能 量子技术
量子计算的商业化前景:未来科技的颠覆性力量
量子计算的商业化前景:未来科技的颠覆性力量
469 17
|
9月前
|
存储 人工智能 JSON
Open-Deep-Research:开源复现版 Deep Research,支持切换多种大模型,不再依赖 OpenAI o3
Open Deep Research 是一个开源的 AI 智能体,支持多种语言模型,具备实时数据提取、多源数据整合和AI推理功能。
2116 16
|
UED
如何申请国际网络专线?
【10月更文挑战第9天】如何申请国际网络专线?
726 2
|
人工智能 Python Shell
CodeFormer——AI驱动的面部图像修复与增强
CodeFormer是由南洋理工大学和商汤科技联合研发的AI人脸复原模型,结合VQGAN和Transformer技术,能从模糊或马赛克图像中生成清晰图像。它具备老照片修复、黑白照片彩色化、马赛克修复和低码率视频增强等功能。安装过程涉及miniconda3、Python环境配置、相关库的安装及模型训练数据下载。在测试视频增强时,虽然初期遇到ffmpeg导入问题,但通过安装ffmpeg-python得以解决,不过CPU占用率高。此外,还展示了对图片进行增强的命令行操作及结果示例。