Selenium Grid作用是什么?Selenium Grid的使用过程?

SeleniumGrid 作用

Selenium Grid 是 Selenium 的三大组件之一,它可以在多台机器上并行运行测试,集中管理不同的浏览器版本和浏览器配置。通过将客户端命令发送到远程浏览器的实例, Selenium Grid 允许在远程计算机 (虚拟或真实) 上执行 WebDriver 脚本. 它提供一种在多台计算机上并行运行测试的简便方法。

使用场景

场景一: 实现分布式执行测试,提高执行效率
比如:我们有 1000 条用例执行,如果在本机执行,一条用例耗时 100 秒,执行完成则需要大约 27 小时 1000*100/60/60=27个小时。如果让这些用例并发执行,比如分配 6 台计算机,每个计算机执行 1000/6 大约 166 条用例,那时间大约节省了 6 倍,原来需要大约 27 个小时,现在可能只需要 4.5 个小时左右就基本完成了, 分布式并发执行可以让我们用例的执行总时长指数级的缩小,从而效率得到很大的提升。

场景二: 解决浏览器兼容性问题

比如还是 1000 条用例,需要分别在 Chrome、Firefox、Edge、Safari 这些浏览器上都执行一遍,保证每个浏览器上都能正常执行,测试浏览器的兼容性。这时也可以使用 Selenium Grid,通过 Selenium Grid 将这些请求分发到不同的系统、不同浏览器中执行。这些浏览器可以分别布署在不同的计算机中比如可以布署在 Linux 、Windows、Mac 上都可以,作为它的 Node 结点,从而解决兼容性测试的问题

执行过程

Client是本地IDEA要执行的测试用例。

  • 1.Client的测试用例通过HTTP协议发送请求给路由Router

Router是 Selenium Grid 内的一个处理器/组件,也是Selenium Grid的入口。

  • 2.Router接受请求并立即进行分发。创建一个新的Session会话同时分配对应的Node节点机器。

Router作用把请求从路由Router发送到Node的机器节点。

  • 3.路由Router进行请求分发。

新请求

接收是一个新请求时,路由Router此时不知往哪个Node节点上发送该请求。

  • 3.1.1 新请求时,路由Router将请求发送给分发器Distributor
分发器  Distributor 读取 Client脚本的 DesiredCapability 属性,从中获取用例的  操作系统 Platform 及  浏览器 browserName 属性。
  • 3.1.2 Distributor根据属性值把请求发送给符合的 Node节点 ,同时 创建session会话对象Session Map
Session会话创建时会产生一个 Session ID分发器  Distributor会把 Session ID与对应的 Node 节点URI地址一一对应存储在  Session Map 中。
  • 3.1.3 Session Map会把Session ID与对应的Node发送给Router路由,Router路由再发送给客户端Client

会话的职责就是创建一个简单的映射,其中包含正在执行的测试用例的Session会话ID及其执行的物理机器Node的地址

已存在的请求

接收是一个已存在的请求时,路由Router直接从Session Map中根据对应的Session ID查找到Node节点的URI地址,把用例请求发送到对应节点上直接运行即可。

  • 3.2.1 已存在的请求时,路由Router将请求根据Session Map中对应关系直接把请求发送给Node节点。

以上是SeleniumGrid的各个组件之间的执行过程。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值