1、什么是UI自动化?
模拟人用代码的方式去操作页面
2、为什么要做UI自动化?
后期迭代的时候,老功能比较多,人工维护成本较大,重复性工作较多,这个时候就考虑因为UI自动化
3、什么时候做UI自动化?
项目稳定,不再修改的某些老功能,为这些老功能提供UI自动化,来提高效率
4、市面上主流的ui自动化方式
基于selenium ****** 基于webdriver Selenium3.x
5、selenium的介绍
selenium是用于测试web应用程序用户界面常用的框架,他是一款用于运行端到端的功能测试的工具,selenium能在一个或多个浏览器中执行这些测试
selenium1.0:2004年,throughtworks编写了一种测试工具用来验证浏览器页面的行为,这个js类库就是selenium core,同时也是seleniumRC,seleniumIDE的核心组件
selenium1.0=selenium IDE[实现简单的浏览器操作的录制和回放]+selenium Grid【辅助工具】+Selenium RC【

Selenium RC 支持多种不同语言编写的自动化测试脚本,通过Selenium RC的服务器作为代理服务器去访问应用,从而达到测试的目的。

Selenium RC分为Client Libraries和Selenium Server。Client Libraries库主要用于编写测试脚本,用来控制Selenium Server的库。Selenium Server负责控制浏览器行为。


selenium2.0=selenium1.0+webdriver
selenium3.0:selenium2.0+SeleniumRC(remote control)
去掉了对selenium rc的支持,webdriver协议已经成为业内公认的浏览器UI测试的标准实现

RemoteWebDriver(selenium的WebDriver的基类)

启动目标浏览器,并绑定到指定端口。该启动的浏览器实例,做为web driver的remote server,Remote server 需要依赖原生的浏览器组件(如:IEDriver.dll,chromedriver.exe),来转化浏览器的api调用,一些定位元素的api都在该类中。

WebDriver

webdriver是按照server – client的经典设计模式设计的。

webdriver的作用就是创建一个新的浏览器实例,也就是启动一个Server端。

(Starts the service and then creates new instance of chrome driver)

server端就是我们的Remote server,也就是我们通过各个不同浏览器所启动的浏览器实例,在我们脚本启动浏览器后,这个浏览器就可以称之为我们的Remote server,它的职责就是等待client发送请求并做出相应处理。

client 就是我们的测试代码,我们测试代码中的所有操作,比如打开浏览器,寻找元素,点击都是以http请求的方式发送给被测试浏览器,也就是我们的Remote server,remote server接受请求,并执行相应操作,并在response中返回执行状态、返回值等信息(这里调用的接口是浏览器的源生API,而每一个浏览器都有自己的一套接口信息,这也就是为什么我们要安装不同的驱动的原因)

webdriver的工作流程

1、通过webdriver创建一个浏览器服务,remote server

2、脚本启动时会在新的线程中启动一个浏览器,并绑定特定端口,每个浏览器有不同的端口段,

3、client创建一个session,在该session中通过http请求向remote server发送restful的请求,remote server解析请求,完成相应的操作并返回response

4、返回response,继续执行脚本还是结束执行

command.py

Command类中定义了WebDriver的一些常用的常量。

remote\webdrvier.py

所有浏览器webdrvier的基类,其中包含了所有webdriver的api接口

remote\remote_connection.py

包含启动Remote WebDrvier server,执行client请求,self._commands是selenium的核心请求参数,根据对应的Command常量,发送不同的http请求。

6、page object moder(pom模型)

pom提供了一种在ui 层操作,业务流程,验证分离的模式,

对象与用例分离,使得我们更好的复用对象,甚至能与不同的工具进行深度结合应用

可复用的页面方法代码会变得更加优化

更加有效的命名方式使得我们更加清晰的知道方法所操作的Ui元素