老李推荐:第1章3节《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来注入按键事件来实现点击请求。

老李推荐:第1章3节《MonkeyRunner源码剖析》概述:架构的更多相关文章

  1. 老李推荐:第14章9节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-遍历控件树查找控件

    老李推荐:第14章9节<MonkeyRunner源码剖析> HierarchyViewer实现原理-遍历控件树查找控件   poptest是国内唯一一家培养测试开发工程师的培训机构,以学员 ...

  2. 老李推荐:第14章5节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-装备ViewServer-查询ViewServer运行状态

    老李推荐:第14章5节<MonkeyRunner源码剖析> HierarchyViewer实现原理-装备ViewServer-查询ViewServer运行状态   poptest是国内唯一 ...

  3. 老李推荐:第14章6节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-装备ViewServer-启动ViewServer

    老李推荐:第14章6节<MonkeyRunner源码剖析> HierarchyViewer实现原理-装备ViewServer-启动ViewServer   poptest是国内唯一一家培养 ...

  4. 老李推荐:第14章3节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-HierarchyViewer实例化

    老李推荐:第14章3节<MonkeyRunner源码剖析> HierarchyViewer实现原理-HierarchyViewer实例化 poptest是国内唯一一家培养测试开发工程师的培 ...

  5. 老李推荐: 第14章2节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-HierarchyViewer架构概述

    老李推荐: 第14章2节<MonkeyRunner源码剖析> HierarchyViewer实现原理-HierarchyViewer架构概述   HierarchyViewer库的引入让M ...

  6. 老李推荐:第14章1节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-面向控件编程VS面向坐标编程

    老李推荐:第14章1节<MonkeyRunner源码剖析> HierarchyViewer实现原理-面向控件编程VS面向坐标编程   poptest是国内唯一一家培养测试开发工程师的培训机 ...

  7. 老李推荐:第8章7节《MonkeyRunner源码剖析》MonkeyRunner启动运行过程-小结

    老李推荐:第8章7节<MonkeyRunner源码剖析>MonkeyRunner启动运行过程-小结   poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性 ...

  8. 老李推荐:第8章5节《MonkeyRunner源码剖析》MonkeyRunner启动运行过程-运行测试脚本

    老李推荐:第8章5节<MonkeyRunner源码剖析>MonkeyRunner启动运行过程-运行测试脚本   poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化 ...

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

    老李推荐:第6章8节<MonkeyRunner源码剖析>Monkey原理分析-事件源-事件源概览-小结   本章我们重点围绕处理网络过来的命令的MonkeySourceNetwork这个事 ...

  10. 老李推荐:第8章1节《MonkeyRunner源码剖析》MonkeyRunner启动运行过程-运行环境初始化

    老李推荐:第8章1节<MonkeyRunner源码剖析>MonkeyRunner启动运行过程-运行环境初始化   首先大家应该清楚的一点是,MonkeyRunner的运行是牵涉到主机端和目 ...

随机推荐

  1. esri-leaflet入门教程(5)- 动态要素加载

    esri-leaflet入门教程(5)- 动态要素加载 by 李远祥 在上一章节中已经说明了esr-leaflet是如何加载ArcGIS Server提供的各种服务,这些都是服务本身来决定的,API脚 ...

  2. ASP.NET Core MVC之Serilog日志处理,你了解多少?

    前言 本节我们来看看ASP.NET Core MVC中比较常用的功能,对于导入和导出目前仍在探索中,项目需要自定义列合并,所以事先探索了如何在ASP.NET Core MVC进行导入.导出,更高级的内 ...

  3. 【开源】NodeJS仿WebApi路由

    用过WebApi或Asp.net MVC的都知道微软的路由设计得非常好,十分方便,也十分灵活.虽然个人看来是有的太灵活了,team内的不同开发很容易使用不同的路由方式而显得有点混乱. 不过这不是重点, ...

  4. Activiti工作流(一)之基本操作介绍

    工作流的概念: 工作流(Workflow),就是"业务过程的部分或整体在计算机应用环境下的自动化",它主要解决的是"使在多个参与者之间按照某种预定义的规则传递文档.信息或 ...

  5. abp zero sample

    测试运行地址:http://ghy.demo.aspnetzero.com 账号:admin  密码:123456 需要源码,请加QQ:858-048-581 一.用户管理 二.日志记录 1.先编译成 ...

  6. java数组、泛型、集合在多态中的使用及对比

    我们在使用数组,泛型集合的过程中不可避免的会碰到多态,或者说什么情况下能如何使用父数组引用子数组(集合.泛型)呢? 数组在多态中的使用 元素为父类型的数组引用可指向元素为子类型的数组对象 当数组被调用 ...

  7. 基于Bootstrap设计网页

    <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...

  8. for循环与foreach的区别

    for循环与foreach的区别 foreach 依赖 IEnumerable. 第一次 var a in GetList() 时 调用 GetEnumerator 返回第一个对象 并 赋给a, 以后 ...

  9. 9 个用于移动APP开发的顶级 JavaScript 框架

    顶级 Java 框架 对于Web开发而言,Java是一个有前途的编程语言,并且在不久的将来它将依然在这个领域大放光彩.Java在移动app开发上也有同样的影响吗?让我们一起来看看ValueCoders ...

  10. 前端资讯周报 3.6 - 3.12: 对学习Javascript最有帮助的三本书,以及HTML标题的迷思

    每周一我都会分享上一周我订阅的技术站点中,和解决问题的过程中阅读到的值得分享的文章. 毕竟个人的阅读量有限,也欢迎大家留言或者私信给我你们阅读到的,对你们前端技术有帮助的任何内容,题材不限,语言不限. ...