51Testing软件测试论坛

标题: Selenium Grid的使用过程和作用 [打印本页]

作者: lsekfe    时间: 2023-4-11 13:14
标题: 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 将这些请求分发到不同的系统、不同浏览器中执行。这些浏览器可以分别布署在不同的计算机中比如可以布署在 LinuxWindows、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的各个组件之间的执行过程。






欢迎光临 51Testing软件测试论坛 (http://bbs.51testing.com/) Powered by Discuz! X3.2