Selenium Grid分布式测试环境搭建

这篇具有很好参考价值的文章主要介绍了Selenium Grid分布式测试环境搭建。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Selenium Grid简介
Selenium Grid实际上是基于Selenium RC的,而所谓的分布式结构就是由一个hub节点和若干个node代理节点组成。Hub用来管理各个代理节点的注册信息和状态信息,并且接受远程客户端代码的请求调用,然后把请求的命令转发给代理节点来执行(官方说明)

简单来说通过selenium grid可以实现一台服务器控制多台node节点机器远程执行selenium自动化测试脚本。比如自动化测试脚本存放在一台hub主机上,那么通过grid就可以控制多台node客户端来执行hub主机上的自动化测试脚本,下面我们就开始配置一下分布式测试运行环境

环境准备
其实hub主机和node节点可以同时配置在一台物理机上,但是为了模拟真实的测试环境,我准备了2台真实的物理机,当然你也可以使用一台物理机+虚拟机的方式练习

1. 准备2台处于同一个局域网下的物理机,保证2台物理机能够相互ping通

2.下载selenium-server-standalone包

3.作为node节点的物理机需要配置好浏览器和对应驱动,并把驱动程序加入环境变量

4.hub主机和node主机均需要配置java jdk 1.8 (切记本版,否则可能配置不成功)

问题
如果你的两台机器处于同一个网络,但是无法相互ping通,你可以尝试下面的办法解决

打开控制面板-打开防火墙设置-点击【高级设置】-点击【入站规则】找到下面两个规则并开启
Selenium Grid分布式测试环境搭建,自动化测试,软件测试,技术分享,selenium,分布式,测试工具

下载selenium-server-standalone

访问官网 Downloads | Selenium 下载 selenium-server-standalone

Selenium Grid分布式测试环境搭建,自动化测试,软件测试,技术分享,selenium,分布式,测试工具

下载好selenium-server-standalone-3.141.59.jar包后,分别放到两台电脑的任意位置

配置浏览器驱动
浏览器驱动如何配置,请自行百度(谷歌的驱动可以从这里下载https://npm.taobao.org/mirrors/chromedriver),我后面主要使用的是firefox浏览器

安装JDk
https://www.cnblogs.com/linuxchao/p/linuxchao-jenkins-setup.html 我的这篇文章里面有安装jdk的教程,但是请注意jdk的版本

搭建环境
配置hub主机
我选择作为hub主机的地址为:192.168.1.103

打开cmd终端,并切换到selenium-server-standalone-3.141.59.jar所在的目录下,执行命令:java -jar selenium-server-standalone-3.141.59.jar -role hub

Selenium Grid分布式测试环境搭建,自动化测试,软件测试,技术分享,selenium,分布式,测试工具

执行命令后,会初始化本机为hub服务器,自动分配一个ip地址(如图,这个地址是个虚拟地址,作为hub的主机地址,因为同一台机器可以同时作为hub和note,所以会自动生成一个虚拟地址),端口号默认为4444,当然你在初始化hub主机的时候也可以修改默认端口,添加-port=指定端口号即可

初始化完成后,我们可以访问http://192.168.24.1:4444:/grid/console来查看初始化的hub状态如图
Selenium Grid分布式测试环境搭建,自动化测试,软件测试,技术分享,selenium,分布式,测试工具

配置node节点
我选择的node节点机器的地址为:192.168.1.102

同样打开cmd终端,并切换到selenium-server-standalone-3.141.59.jar所在的目录下,执行命令:

java -jar selenium-server-standalone-3.141.59.jar -role webdriver -browser "browserName=firefox,platform=WINDOWS" -hubHost 192.168.1.103(hub所在的主机地址)

如果你使用的浏览器是chrome,可能你需要执行这个命令(别问我为什么,我使用chrome浏览器的时候,使用上面的命令,只是修改了browserName=chrome,没有成功)

java -jar -Dwedriver.chrome.driver=driver所在的目录\chromedriver.exe selenium-server-standalone-3.141.59.jar -browser "browserName=chrome, version=75" -role node -hubHost 192.168.1.103

命令执行完毕后你会看到下面的输出信息

Selenium Grid分布式测试环境搭建,自动化测试,软件测试,技术分享,selenium,分布式,测试工具

ok,现在我们再次访问一下hub主机的地址看下状态

Selenium Grid分布式测试环境搭建,自动化测试,软件测试,技术分享,selenium,分布式,测试工具 

右边就是我初始化成功后的远程node节点机器的配置,左边我也配置了一个,是在hub所在的主机配置的一个note节点

到这里,我们的分布式自动化测试环境就配置完成了,接下来开始编写我们的测试代码,看下是否能够在远程note机器上执行测试

测试脚本
测试脚本放在hub所在的机器(我们的目的就是控制远程note机器执行测试(打开浏览器执行测试),并不是hub所在机器执行(要不然还有啥意义呢?))

"""
------------------------------------
@Time : 2019/7/6 16:55
@Auth : linux超
@File : testCaseNodeB.py
@IDE  : PyCharm
@Motto: Real warriors,dare to face the bleak warning,dare to face the incisive error!
@QQ   : 28174043@qq.com
@GROUP: 878565760
------------------------------------
"""
import time
import unittest
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC


class TestSeleniumGrid(unittest.TestCase):

    def setUp(self):
        self.driver = webdriver.Remote(command_executor="http://192.168.1.102:16891/wd/hub",
                                       desired_capabilities={"browserName": "firefox",  # 浏览器名称
                                                             "platform": "WINDOWS"
                                                             })

    def test_grid(self):
        self.driver.get("https://www.baidu.com")
        self.driver.find_element_by_id('kw').send_keys('linux超')
        self.driver.find_element_by_id('su').click()
        WebDriverWait(self.driver, 10). \
            until(EC.visibility_of_element_located((By.XPATH, '//a[text()="https://www.cnblogs.com/"]')))
        page_source = self.driver.page_source
        self.assertIn('linux', page_source)

    def tearDown(self):
        self.driver.quit()


if __name__ == '__main__':
    unittest.main()
执行过程
我们运行hub主机上的代码然后看一下note节点机器上执行的过程, 并注意看hub主机和note点击机器cmd终端的输出结果

Selenium Grid分布式测试环境搭建,自动化测试,软件测试,技术分享,selenium,分布式,测试工具

执行过程中有一些警告信息,也不知道什么原因,我还没找到解决的办法,但是并不影响测试的执行,到此为止整个测试环境搭建就完成了

最后
搭建过程需要注意

1.浏览器和浏览器驱动版本要匹配,且添加到系统环境变量

2.初始化hub和node时的命令不要敲错,算这次我一共搭过2次环境, 之前2次折腾命令参数就折腾了好久(对一个参数选项不太理解)

3.不要被hub和node机器的ip搞晕,脚本中的要在哪里运行测试就要配置哪个node节点机器的地址 (command_executor="http://192.168.1.102:16891/wd/hub",而且要主要后面接的/wd/hub是固定的不要写错)

需要注意的差不多就这么多吧, 自己不手动配置一遍你也不会知道究竟会遇到什么问题

TODO
配置这个测试环境之后,我一直有个疑问,我的代码只能在一个node上的一个浏览器上执行,分布式分布式,这样的话还有啥意义呢?我的理解是应该能同时在不同的node机器上不同的浏览器上运行才符合这个概念,所以呢我试着使用python线程并发修改了几次代码也没有成功,试着找资料也没有解决我这个疑惑,也可能我理解的有问题,不管怎么样了,以后有了思路再更新这篇文章吧!

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

Selenium Grid分布式测试环境搭建,自动化测试,软件测试,技术分享,selenium,分布式,测试工具

 视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。   文章来源地址https://www.toymoban.com/news/detail-771091.html

到了这里,关于Selenium Grid分布式测试环境搭建的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Spark单机伪分布式环境搭建、完全分布式环境搭建、Spark-on-yarn模式搭建

    搭建Spark需要先配置好scala环境。三种Spark环境搭建互不关联,都是从零开始搭建。 如果将文章中的配置文件修改内容复制粘贴的话,所有配置文件添加的内容后面的注释记得删除,可能会报错。保险一点删除最好。 上传安装包解压并重命名 rz上传 如果没有安装rz可以使用命

    2024年02月06日
    浏览(59)
  • 学点Selenium玩点新鲜~,让分布式测试有更多玩法

    我们都知道 Selenium 是一款在 Web 应用测试领域使用的自动化测试工具,而 Selenium Grid 是 Selenium 中的一大组件,通过它能够实现分布式测试,能够帮助团队简单快速在不同的环境中测试他们的 Web 应用。 分布式执行测试其实并不是一个非常难以理解的概念,简单来说,就是能够

    2024年02月12日
    浏览(22)
  • HBase 伪分布式环境搭建 - 头歌

    mkdir /app cd /opt tar -zxvf hbase-2.1.1-bin.tar.gz -C /app cd /app cd hbase-2.1.1 cd conf echo $JAVA_HOME /usr/lib/jvm/jdk1.8.0_111 vim hbase-env.sh 进入文件,找到下图中红色框框内的路径,将#去掉,把=号后面的路径改成/usr/lib/jvm/jdk1.8.0_111。注意:记得先按A,才能改。 按esc键,输入  :wq  ,回车。 vim hb

    2024年04月28日
    浏览(28)
  • ZooKeeper+HBase分布式集群环境搭建

    安装版本:hadoop-2.10.1、zookeeper-3.4.12、hbase-2.3.1 一、zookeeper 集群搭建与配置 1. 下载zookeeper安装包 2. 解压移动zookeeper 3. 修改配置文件(创建文件夹) 4. 进入conf/ 5. 修改zoo.cfg文件 6. 进入/usr/local/zookeeper-3.4.12/zkdatas/这个路径下创建一个文件,文件名为myid ,文件内容为1 7. 拷贝到

    2024年02月08日
    浏览(34)
  • 基于Docker搭建hdfs分布式实验环境

    理论知识 Docker Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源。Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任

    2023年04月08日
    浏览(35)
  • 【教程】Hadoop完全分布式环境搭建全过程

    保姆级入门教程:图片讲解 + 各种问题解决方案 集群服务器:hadoop102、hadoop103和hadoop104 虚拟机版本:CentOS7-1804 资源分享处(文章最后)提供CentOS7和Hadoop各组件压缩包(也可以自行下载,要注意版本兼容的问题),有需要自取~ 1, 模板虚拟机准备 2, 克隆三台虚拟机,作为

    2024年02月06日
    浏览(42)
  • hadoop伪分布式环境搭建,完整的详细步骤

    1、VMware14 2、一台ubtuntu 18 64位 3、主机名位master 4、ip 地址:192.168.136.31 5、本次实验需要的安装包 1、 查看id 地址 2、 关闭防火墙 命令来关闭防火墙 命令查看当前防火墙状态 3、 修改主机名、 添加主机映射 修改虚拟机hosts文件,将ip地址添加进来 使用 :wq 保存 测试是否修改

    2024年02月08日
    浏览(36)
  • 【云计算平台】Hadoop全分布式模式环境搭建

    此前搭建了hadoop的单机模式与伪分布式模式: 单机模式部署 伪分布式模式部署 中间拖得有点久了,今天索性做个了结,把hadoop的全分布式模式部署的操作也简单地记录一下,算是一个系统性的学习吧。 伪分布式模式是学习阶段最常用的模式,它可以将进程都运行在同一台机

    2023年04月08日
    浏览(37)
  • 头歌大数据——HBase 伪分布式环境搭建

    第1关:HBASE伪分布式环境搭建 编程要求 好了,到你啦,你需要先按照上次实训——HBase单节点安装的方式将 HBase 安装在 /app 目录下,然后根据本关知识配置好伪分布式的 HBase ,最后点击测评即可通关。 测试说明 程序会检测你的 HBase 服务和 Hadoop 服务是否启动,以及伪分布

    2024年02月08日
    浏览(47)
  • Linux环境搭建Hadoop及完全分布式集群

    Hadoop是一个开源的分布式计算框架,旨在处理大规模数据集和进行并行计算。核心包括两个组件:HFDS、MapReduce。 配置方案 各虚拟机的用户名分别为test0、test1、test2,主机名为hadoop100、hadoop101、hadoop102 虚拟机的分配如下: hadoop100:NameNode + ResourceManager hadoop101:DataNode + NodeM

    2024年03月23日
    浏览(33)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包