自动化测试框架原理

     最近难得有时间,整理一下目前常用的自动化测试框架的原理,在搬运工的基础上总结一下,便于理解;

1) Appium原理

Appium是 c/s模式的
appium是基于 webdriver 协议添加对移动设备自化api扩展而成的
webdriver 是基于 http协议的,第一连接会建立个 session 会话,并通过 post发送一个 json 告知服务端相关测试信息

IOS 原理图( 来源于:百度 )

appium ios封装了 封装了 封装了 apple 的 Instruments I框架,主要用了 框架,主要用了 Instrument里的 UIAutomation(Apple  的自动化测试框架),然后在设备中注 自动化测试框架),然后在设备中注 入  bootstrap.js 进 行监 听。
Client ent是我们编写的 webdriver脚本 ,中间是 appium启动 server (默认监听 4723 端口 ),
appium server  调用 instruments.js启动 ⼀一个 socket server ,同时分出一个 ,子进程运⾏instruments.app 将 bootstrap.js(一个 UIAutomation 脚本)注 ⼊入到 devices⽤于和外界进行交 。
最后 Bootstrap.js将执行的结果返回给 将执行的结果返回给 appium server  ,appium server再将结果返 回给 appium client 。

Android原理图(  来源于:百度)

4.2 以后是基于 uiautomator框架实现查找注入事件的, 框架实现查找注入事件的,框架实现查找注入事件的, 4.2 以前则是 instrumentation i框架的,并封装成一个叫 框架的, Selendroid 这玩意提供服务
Client ent是我们编写的 webdriver 脚本。中间是 appium启动 server  (默认监听  4723 端口 ),
appium server  会把请求转发给中间件 会把请求转发给中间件 Bootstrap.jar  ,它是用java写的,安装在 手机上 .Bootstrap监听 4723端口并接收appium  的命令,最终通过调 的命令过调 用 UiAutomator U 的命令来实现。
Bootstrap将执行的结果返回给 将执行的结果返回给 appium server 。
Appiumserver再将结果返回给 client端。

2)Uiautomator2 原理

1. Uiautomator2是一个可以使用Python对Android设备进行UI自动化的库。其底层基于Google uiautomator,Google提供的uiautomator库可以获取屏幕上任意一个APP的任意一个控件属性,并对其进行任意操作,目前仅支持android平台的原生应用测试,https://github.com/openatx/uiautomator2, 使用python编写测试脚本;
2.工作原理

分为两个部分:
PC上的python端:运行脚本,并向系统设备发送http请求
移动设备:移动设备上运行了封装了uiautomator2的HTTP服务,解析收到的请求,并转化成uiautomator2的代码。
3.整个过程
以下解释直接引用网址:https://testerhome.com/topics/11357
① 在移动设备上安装atx-agent(守护进程), 随后atx-agent启动uiautomator2服务(默认7912端口)进行监听
② 在PC上编写测试脚本并执行(相当于发送HTTP请求到移动设备的server端)
③ 移动设备通过WIFI或USB接收到PC上发来的HTTP请求,执行指定的操作

 3. UiAutomator、UiAutomator2、Bootstrap的关系

3.1 UiAutomator和bootstrap:
UiAutomator是Android自动化测试框架,是谷歌在Android4.1版本发布时推出的一款用Java编写的UI测试框架。其最大的特点就是可以跨进程操作,我们可以使用UiAutomator框架提供的一些方便的API来对安卓应用进行一系列的自动化测试操作,如点击、滑动、键盘输入、长按以及常用的断言方法等。可以替代以前繁琐的手工测试。
Bootstrap是Appium在初始化的时候推送到安卓手机上的一个UiAutomator测试脚本,该脚本的唯一一个测试方法所做的事情是在手机端开启一个SocketServer(通信模块),用来监听Appium从PC端过来的命令发送给UiAutomator来执行处理。
下图为官方提供的原理图:

WebDriver script:
  我们的测试脚本(java or python)
Appium:
  会首先开启一个监听4723端口的server,接收测试脚本发送过来的对应请求,再讲对应的请求发送给中间件Bootstrap.jar(注意这里的请求不是整个脚本文件,而是对应的命令请求,比如:点击一个元素就是一条请求)
Bootstrap.jar:
  监听4724端口由appium发送过来的相关请求,并且将请求转换成UiAutomator可以识别的命令发给UiAutomator进行处理
UiAutomator2:
说到这里相信大家已经了解了这两者的关系,那为什么还会有UiAutomator2,难道是UiAutomator的升级版本?没错!
appium在最近有加入了UiAutomator2(也可称为UiAutomator V2)来支持实现Android端自动化,原理同之前的UiAutomator+Bootstrap有很大的不同:
为了能够支持UiAutomator2,Appium引入了appium-uiautomator2-server
以下是其官网的wiki介绍,英文基础较好的同学可以去看看
https://github.com/appium/appium-uiautomator2-server/wiki
肯定还是有比较多同学对英文犯晕的,那我就给大家翻译翻译下:
1、Appium使用UiAutomator2的目的是为了替换掉之前的UiAutomator+Bootstrap模式
2、Bootstrap是基于UiAutomator V1(即为UiAutomator)的,但是UiAutomator很多Api基本上官方不再维护了
3、UiAutomator V2修复了UiAutomator V1中遇到的大多数问题,最重要的是实现了与Android系统更新的分离
有看到我们公开课的同学或者VIP课程的同学比较清楚:在获取到toast信息的时候需要将automationName设置成UiAutomator2,就是因为在UiAutomator2上新增了AccessibilityService服务,可以实现Toast的获取。
以下是其使用原理图:

WebDriver script:
 不用多说,就是我们的执行脚本
Appium:
  客户端传递desired capabilities属性配置给Appium Server来创建一个会话,Appium Server会调用appium-uiautomator2-driver,同时将UiAutomator2 server的两个apk安装到测试设备上
  1、appium-uiautomator2-server-vx.x.x.APK
  2、appium-uiautomator2-server-debug-androidTest.apk
UiAutomator2 server两个apk的作用:
  1、UiAutomator2 驱动模块,负责创建会话,安装UiAutomator2-server.apk到设备上,开启Netty(这是一个通信框架,相当于Bootstrap使用的SocketServer升级版本)
  2、UiAutomator2服务器模块,当驱动模块创初始化完毕,服务器就会监听PC端Appium发送过来的请求,将请求发送给真正底层的UiAutomator2。

参考文章:
1) Appium原理解析 ( https://www.cnblogs.com/yulei126/p/6804216.html)
2) Appium原理 (https://www.cnblogs.com/csj2018/p/9937511.html)
3) Uiautomator2原理介绍 (https://blog.csdn.net/zhuhuahong/article/details/81868671)
4)UiAutomator、UiAutomator2、Bootstrap的关系 (https://www.cnblogs.com/yyoba/p/9675071.html)

原文地址:https://www.cnblogs.com/jiguanghover/p/10578951.html