第1章3节《MonkeyRunner源码剖析》概述: 架构(原创)

天地会珠海分舵注:本来这一系列是准备出一本书的,详情请见早前博文“寻求合作伙伴编写《深入理解 MonkeyRunner》书籍“。但因为诸多原因,没有如愿。所以这里把草稿分享出来,所以错误在所难免。有需要的就参考下吧,转发的话还请保留每篇文章结尾的出处等信息。

原理架构



MonkeyRunner使用起来非常的简单,只需要导入以下几个类基本上就能满足测试脚本编写的需求,比如:

  • monkeyrunner.jar库的MonkeyRunner
  • monkeyrunner.jar库的MonkeyDevice
  • monkeyrunner.jar库的MonkeyImage

如果你想使用MonkeyRunner的控件相关的功能来让自己的代码可扩展性和可移植性更好,那么你也只需额外用上下面几个类就基本上能满足你的要求了:

  • chimpchat.jar库的:HierarchyViewer
  • hierarchyviewerlib.jar库的:ViewNode

如果你还想更简单的使用控件相关的功能,MonkeyRunner同样也可以满足你,只要你导入以下的类就可以使用EasyMonkeyDevice来调用其封装好的易用的API:

  • monkeyrunner.jar库的easy模块: EasyMonkeyDevice
  • monkeyrunner.jar库的easy模块: By

所以从脚本的角度来看,使用MonkeyRunner可以简单的理解成把需要的类给整合起来,然后通过代码把相应的业务逻辑通过各个类提供的方法给实现出来。?

但从MonkeyRunner实现的角度来看,事实并没有这么简单,为了满足MonkeyRunner脚本需要的功能,整个框架里面会使用到不同的库以及不同的模块,甚至会驱动Android机器端的不同模块与服务来做事情。我们先看下MonkeyRunner的整个架构图:

MonkeyRunner是一个CS(客户端-服务器)架构的框架,主要的代码控制逻辑是在PC端作为客户端来运行的;但客户端需要驱动运行在目标Android系统的服务器端来做事情,比如驱动Monkey服务去调用对应的Android服务去注入事件以实现点击等操作功能。服务器端和客户端的通信是通过Socket来实现的,而Socket又分为基于USB通信协议和TCP通信协议的,也就是说用户既可以通过 USB线直接连接主机和Android目标机器;也可以通过网络使用TCP协议来连接主机和 Android目标机器(使用命令:adb connect IP)。但注意客户端并不会直接连接Android目标设备端中各个服务正在监听的端口,而是连接主机端和该端口对应的转发端口,只要连接上转发端口,所有发向该端口的数据都会直接转发给Android目标机器端对应的服务监听的端口。

从上图可以看到,MonkeyRunner脚本的实现需要多个库的支持,常用的有以下这几个:

  • monkeyrunner库:MonkeyRunner最主要的库,脚本可以直接使用里面的MonkeyRunner,MonkeyDevice,MonkeyImage类来控制Android目标设备和应用以及截图等功能
  • chimpchat库:monkeyrunner库的很多功能都是通过调用chimpchat库相应的类来实现的,比如调用MonkeyDevice类的安装应用包installPackage方法会直接调用到到chimpchat库的对应类AdbChimpDevice的installPackage方法,然后该方法再会调用ddmlib的对应方法来通过Socket往ADB服务器发送命令,然后ADB服务器会驱动Android目标机器端的adbd这个守护进程来实现安装应用包的请求。所以chimpchat对于使用ADB进行通信的过程来说,相当于MonkeyRunner和ddmlib之间的代理中间层。但对于使用Monkey进行通信的时候,chimpchat并不需要通过ddmlib来驱动Android目标机器的monkey服务,而是chimpchat自己来完成socket建立和命令发送的功能
  • ddmlib库:在MonkeyRunner框架中,ddmlib主要是帮忙处理跟ADB服务器通信的事宜
  • hierarchyviewerlib库:当MonkeyRunner脚本需要用到控件相关的功能的时候就会使用到这个库来建立控件树和获取指定控件的相关属性

往下一层我们可以看到,MonkeyRunner跟Android目标机器进行通信根据需要做的事情不同而会驱动三种不同的服务去处理请求:

  • ADB服务:主要是处理非界面操作的相关请求,比如安装应用包等
  • monkey服务:主要是处理界面操作相关的请求,比如点击指定坐标等
  • ViewServer服务:主要是处理控件相关的请求,比如获取当前界面所有控件信息等

这里要注意的是MonkeyRunner框架并不会直接连接adbd这个Android目标机器的守护进程来驱动其做事情,而是先和ADB服务器这个PC端的守护进程进行通信,然后再由ADB服务器来驱动adbd来完成请求的。至于ADB服务器,ADB守护进程,ADB协议以及ADB命令行客户端等概念,第4章”ADB协议及服务“会详述。

最下面一层就是Android系统的核心服务了。MonkeyRunner的很多请求都是需要调用到Android的系统服务来完成的。比如点击一个控件就需要通过monkey服务来调用Android系统的InputManagerService来注入按键事件来实现点击请求。



作者:天地会珠海分舵

微信公众号:TechGoGoGo

微博:http://weibo.com/techgogogo

CSDN:http://blog.csdn.net/zhubaitian

时间: 2024-10-21 20:48:49

第1章3节《MonkeyRunner源码剖析》概述: 架构(原创)的相关文章

老李推荐: 第8章4节《MonkeyRunner源码剖析》MonkeyRunner启动运行过程-启动AndroidDebugBridge 1

老李推荐: 第8章4节<MonkeyRunner源码剖析>MonkeyRunner启动运行过程-启动AndroidDebugBridge 上一节我们看到在启动AndroidDebugBridge的过程中会调用其start方法,而该方法会做2个主要的事情: 715行startAdb:开启AndroidDebugBridge 722-723行:初始化android设备监控并启动DeviceMonitor设备监控线程. 其中第一点我们上一小节已经做了详尽分析了,那么我们往下就去分析下第2点. Dev

老李推荐:第6章5节《MonkeyRunner源码剖析》Monkey原理分析-事件源-事件源概览-事件

老李推荐:第6章5节<MonkeyRunner源码剖析>Monkey原理分析-事件源-事件源概览-事件 从网络过来的命令字串需要解析翻译出来,有些命令会在翻译好后直接执行然后返回,但有一大部分命令在翻译后需要转换成对应的事件,然后放入到命令队列里面等待执行.Monkey在取出一个事件执行的时候主要是执行其injectEvent方法来注入事件,而注入事件根据是否需要往系统注入事件分为两种: 需要通过系统服务往系统注入事件:如MonkeyKeyEvent事件会通过系统的InputManager往系

老李推荐:第6章3节《MonkeyRunner源码剖析》Monkey原理分析-事件源-事件源概览-命令翻译类

老李推荐:第6章3节<MonkeyRunner源码剖析>Monkey原理分析-事件源-事件源概览-命令翻译类 每个来自网络的字串命令都需要进行解析执行,只是有些是在解析的过程中直接执行了事,而有些是需要在解析后创建相应的事件类实例并添加到命令队列里面排队执行.负责这部分工作的就是命令翻译类.那么我们往下还是继续在MonkeySourceNetwork这个范畴中MonkeyCommand类是怎么一回事: 图6-3-1 MonkeyCommand族谱 图中间的MonkeyCommand是一个接口,

老李推荐: 第1章1节《MonkeyRunner源码剖析》概述:前言

老李推荐: 第1章1节<MonkeyRunner源码剖析>概述:前言 前言 相信大家做过安卓移动平台UI自动化开发的必然会用过,至少听过MonkeyRunner这个名字.MonkeyRunner是一个针对安卓平台的UI自动化测试框架,这个框架的其中一个但绝不是唯一的优点是支持用当今非常流行和高效的Python语言来进行脚本开发.同时,它相比Instrumentation框架或者基于Instrumentation的自动化测试框架最大的优点之一就是可以跨应用测试. 这本书不会有什么序言或者致谢什么

boost.asio源码剖析(二) ---- 架构浅析

* 架构浅析 先来看一下asio的0层的组件图.                     (图1.0) io_object是I/O对象的集合,其中包含大家所熟悉的socket.deadline_timer等对象,主要功能是提供接口给用户使用. services服务是逻辑功能的实现者,其中包含提供定时功能的deadline_timer_service.提供socket相关功能的win_iocp_socket_service(windows平台)/reactive_socket_service(其他

第5章5节《MonkeyRunner源码剖析》Monkey原理分析-启动运行: 获取系统服务引用(原创)

天地会珠海分舵注:本来这一系列是准备出一本书的,详情请见早前博文"寻求合作伙伴编写<深入理解 MonkeyRunner>书籍".但因为诸多原因,没有如愿.所以这里把草稿分享出来,所以错误在所难免.有需要的就参考下吧,转发的话还请保留每篇文章结尾的出处等信息. 上一节我们描述了monkey的命令处理入口函数run是如何调用optionProcess方法来解析命令行参数的.启动参数主要时去指导Monkey时怎么运行起来的,但Monkey作为MonkeyRunner框架的一部分,

第5章2节《MonkeyRunner源码剖析》Monkey原理分析-启动运行: 启动流程概览(原创)

天地会珠海分舵注:本来这一系列是准备出一本书的,详情请见早前博文"寻求合作伙伴编写<深入理解 MonkeyRunner>书籍".但因为诸多原因,没有如愿.所以这里把草稿分享出来,所以错误在所难免.有需要的就参考下吧,转发的话还请保留每篇文章结尾的出处等信息. 每个应用都会有一个入口方法来供操作系统调用执行,Monkey这个应用的入口方法就是在Monkey.java这个类里面的,也就是说Monkey.java就是整个Monkey应用的入口类. Monkey作为一个命令行应用,

第2章1节《MonkeyRunner源码剖析》了解你的测试对象: NotePad应用简介(原创)

天地会珠海分舵注:本来这一系列是准备出一本书的,详情请见早前博文"寻求合作伙伴编写<深入理解 MonkeyRunner>书籍".但因为诸多原因,没有如愿.所以这里把草稿分享出来,所以错误在所难免.有需要的就参考下吧,转发的话还请保留每篇文章结尾的出处等信息. 本书脚本相关的示例常会用到Android SDK自带的NotePad这个应用,所以这里很有必要去描述下这个应用.其实去熟悉这个应用最好的办法是自己去把它安装上去你的目标安卓系统,然后亲自去玩一下它的各种功能.因为它只是

第1章1节《MonkeyRunner源码剖析》概述:前言(原创)

天地会珠海分舵注:本来这一系列是准备出一本书的,详情请见早前博文"寻求合作伙伴编写<深入理解 MonkeyRunner>书籍".但因为诸多原因,没有如愿.所以这里把草稿分享出来,所以错误在所难免.有需要的就参考下吧,转发的话还请保留每篇文章结尾的出处等信息. 前言 相信大家做过安卓移动平台UI自动化开发的必然会用过,至少听过MonkeyRunner这个名字.MonkeyRunner是一个针对安卓平台的UI自动化测试框架,这个框架的其中一个但绝不是唯一的优点是支持用当今非常流

第1章2节《MonkeyRunner源码剖析》概述:边界(原创)

天地会珠海分舵注:本来这一系列是准备出一本书的,详情请见早前博文"寻求合作伙伴编写<深入理解 MonkeyRunner>书籍".但因为诸多原因,没有如愿.所以这里把草稿分享出来,所以错误在所难免.有需要的就参考下吧,转发的话还请保留每篇文章结尾的出处等信息. 边界 怎么样才算分析清楚一个事物的原理是什么呢?就以前面提到的<LINUX内核源代码情景分析>为例子,分析到什么程度算是把Linux内核给分析清楚呢?一个操作系统内核的原理无非是要描述清楚这几个核心是如何工