Selenium的四种部署方式

关于selenium 的部署,我在网上找了很多,基本上都没有提到或是说的比较清晰的。当时我一直有个困惑:测试的脚本代码,是放在跟浏览器同一台机器上呢,还是放在Application Server上?

在官方开发文档中,提到了四种部署方式:

一、本地部署

说明:脚本代码跟测试的浏览器同一台机器

【WebDriver】 相当于 依赖包,以下代码为例

<dependency>
    <groupId>org.seleniumhq.selenium</groupId>
    <artifactId>selenium-java</artifactId>
    <version>3.X</version>
  </dependency>

【Driver】是下载下来的exe可执行程序(以window系统来说),测试不同的浏览器时,需要不同的exe可执行程序

【Browser】是目标测试浏览器

此部署方式最简单,把测试脚本放在目标浏览器同一台机器上,然后执行测试脚本即可。

 

在第6行代码中,直接启动本地(指代码与浏览器Drvier.exe同一台机器)的chromedriver.exe,然后就是跑脚本了。

简单总结: 优点:容易上手,快速见效,容易对selenium 有大概认识; 缺点:只能作为新手练习用,不能作为建设自动化测试系统的方案,因为不管对每台浏览器管理啊。

二、远程部署

执行的测试脚本与目标浏览器不在同一台机器上。

【RemoteWebDriver】简单来说就提供了一套API接口,允许WebDriver访问RemoteWebDriver 此部署方式分两部分,一边是客户端,一边是服务端。可以把测试脚本与目标浏览器分开在不同的机器上。 服务端是指【RemoteWebDriver】这边,启动时,RemoteWebDriver可以看作为Tomcat容器启动一个WEB应用,暴露了监听端口,并发布RESTFUL接口。

 

注意:服务器的地址如下:http://你的host地址:4444/wd/hub/,记录,后面编写客户端代码的时候需要使用。

客户端是指【WebDriver】这边,是应用程序跑测试脚本的(Java\Python\JavaScript等),通过RESTFUL接口把测试参数化传给RemoteWebDriver。

在第17行代码中,需要把定IP和端口。

图片RemoteWebDriver.png和代码源于:https://www.cnblogs.com/hejing-swust/articles/8052969.html

简单总结: 优点:此部署方式,可以用于一般的企业自动化测试方案,实现测试脚本和执行机(目标浏览器)分离,可以自己实现远程管理多个执行机。 缺点:比本地部署稍稍麻烦些。

三、Grid部署

集中管理,由selenium grid 来统一分以任务。

 

【Grid】官方描述:Selenium Grid is a smart proxy server that allows Selenium tests to route commands to remote web browser instances. Its aim is to provide an easy way to run tests in parallel on multiple machines ,简单来说就是由Grid智能的分发任务到各个执行机

下图"components of grid.png" 这里分三部分,一是client,二是HUB,三是NODES。 【client】就是上文中描述过的 client ,不再重复; 【HUB】相当于一个中控,类似于“二、远程部署”那章的中的“server服务端”,client 端将脚本通过HTTP接口传给HUB,至于由哪个执行机(目标浏览器)执行,那就由HUB去计算了。 【NODES】就是HUB的节点,全由HUB监听和管理;

启动HUB很简单,注意下文的命令是 "-role hub",启动后可以通过浏览器访问控制台 http://localhost:4444/grid/console。

  java -jar selenium-server-standalone.jar -role hub

启动NODES也简单,注意下文的命令是“-role node”, 而 -hub http:localhost:4444 是HUB的IP 和端口。 一台机会可以同时启动多个NODES

  java -jar selenium-server-standalone.jar -role node -hub http://localhost:4444

HUB 和 NODES 更多的配置就参考官网Setting up your own Grid

而client 如何访问HUB呢?

 DesiredCapabilities capability = new DesiredCapabilities();
  capability.setBrowserName("ie");
  capability.setPlatform(Platform.WINDOWS);
  try {
      WebDriver  driver = new RemoteWebDriver(new URL("http://192.168.0.245:4444/wd/hub"), capability);
      driver.get("http://www.baidu.com");
      driver.quit();
  } catch (MalformedURLException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
  }

四、Test Framework

它是这么说的,我就不翻译了:Natural language frameworks/tools such as Cucumber may exist as part of that Test Framework box in the figure above, or they may wrap the Test Framework entirely in their own implementation. 对于Test Framework。

​现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:485187702【暗号:csdn11】

最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走! 希望能帮助到你!【100%无套路免费领取】

  • 21
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Selenium Grid是一个用于分布式测试的工具,它允许同时在多个机器上运行测试脚本,以加快测试的执行速度。下面是Selenium Grid分布式部署的介绍: 1. 配置Hub节点:首先需要配置一个Hub节点,它是Selenium Grid的心控制节点。Hub节点负责接收来自客户端的测试请求,并将这些请求分发给可用的节点进行执行。 2. 配置Node节点:在每台要参与分布式测试的机器上配置一个Node节点。Node节点负责接收来自Hub节点的测试请求,并在本地执行这些请求。每个Node节点可以同时运行多个浏览器实例,以支持并发执行多个测试。 3. 启动Hub和Node:首先启动Hub节点,然后在每台机器上启动Node节点。Node节点会自动注册到Hub节点上,使得Hub能够管理和分发测试请求。 4. 配置浏览器驱动:在每个Node节点上,需要配置相应的浏览器驱动,如ChromeDriver或GeckoDriver。这些驱动程序负责与浏览器进行通信,并执行测试脚本的操作。 5. 编写测试脚本:编写测试脚本时,需要指定要在分布式环境执行的浏览器和节点信息。通过指定不同的浏览器和节点,可以实现在多个机器上并行执行测试。 6. 运行测试:运行测试时,测试脚本会将请求发送到Hub节点,然后由Hub节点将请求分发给可用的Node节点进行执行。执行结果会返回给测试脚本,以便进行断言和验证。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值