Selenium Grid简介

利用Selenium Grid可以使主节点(hub)的测试用例在不同主机即分支点(node)运行。可以使一份测试用例在不同环境下(操作系统、浏览器)执行自动化测试。Selenium Grid 使用Hub和Node模式,一台计算机作为Hub(管理中心)管理其他多个Node(节点)计算机,Hub负责将测试用例分发给多台Node计算机执行,并收集Node计算机执行结果的报告,汇总后提交一份总的测试报告。

Hub:

1.在分布式测试模式中,只能有一台作为Hub的计算机。

2.Hub负责关机测试用例,并负责发送脚本给其他Node节点。

3.所有的Node节点计算机会在Hub计算机中先进行注册,祖册成功后再和Hub计算机通信,Node节点计算机会告之Hub自己的相关信息,例如,Node计算机的操作系统和浏览器版本。

4.Hub计算机可以为自己分配执行测试用例的任务。

5.Hub计算机分发的测试用例任务会在各个Node计算机节点执行。

Node:

1.在分布测试中可以有一个或多个Node节点。

2.Node节点会打开本地的浏览器完成测试任务并返回测试结果给Hub。

3.Node节点的操作系统和浏览器版本无需和Hub保持一致。

4.在Node节点上可以同时打开多个浏览器并行执行测试任务。

selenium Grid环境搭建

grid下载地址:http://selenium-release.storage.googleapis.com/index.html

找一个版本和自己使用的selenium版本相同的下载,这里下载的时2.53.1

启动Hub:

下载完成后,打开cmd,进入jar问件所在目录,执行命令 java -jar selenium-server-standalone-2.53.1.jar -role hub

打开浏览器输入本机的IP+端口号(下图所示)

点击console

点击view config

修改Hub参数

方式一:

(例:修改端口号为 5566)

在cmd中按Ctrl+C退出关闭当前的Hub,执行命令 java -jar selenium-server-standalone-2.53.1.jar -role hub -port 5566

方式二:

在存放grid的目录下新建一个hub.json文件,将Hub所有参数放进去

{
"browserTimeout": 0,
"capabilityMatcher":"org.openqa.grid.internal.utils.DefaultCapabilityMatcher",
"cleanUpCycle": 5000,
"host": null,
"jettyMaxThreads": -1,
"maxSession":10,
"newSessionWaitTimeout": -1,
"nodePolling": 5000,
"port": 5555,
"prioritizer": null,
"role": hub,
"servlets": [],
"throwOnCapabilityNotPresent": true,
"timeout":200000
}

根据自己实际情况修改后在cmd中执行命令: java -jar selenium-server-standalone-2.53.1.jar -role hub -hubConfig hub.json

打开浏览器输入IP+端口即可

Node使用

node节点计算机要求

1. Node 节点必须要有 java 环境

2. Node节点跟Hub节点机器间可以互相 ping 通。

3. Node 节点负责执行Selenium 脚本,所以必须有Selenium 环境(脚本语言对应的环境如java, 各个浏览器及其对应的driver)

启动Node节点注册到Hub

在cmd中执行命令:java -jar selenium-server-standalone-2.53.1.jar -role node -hub http://192.168.1.8:4444/grid/register(192.168.1.8:4444是我打开的Hub地址,可以根据自己实际情况而定)

Hub中看到的效果如下

修改参数(和Hub的一样)

方式一:

以修改端口为例

在cmd中执行命令:java -jar selenium-server-standalone-2.53.1.jar -role node -hub http://192.168.1.8:4444/grid/register -port 5556

方式二:

在grid文件下创建一个node.json文件,json内容如下(其中的hub值根据实际情况做修改):

{
"capabilities": [
{
"browserName": "chrome",
"maxInstances": 10,
"platform": "WINDOWS",
"version": "51",
"webdriver.chrome.driver":"chromedriver.exe"
},
{
"browserName": "firefox",
"maxInstances": 10,
"platform": "WINDOWS",
"version": "46"
},
{
"browserName": "internet explorer",
"maxInstances": 3,
"platform": "WINDOWS",
"version": "11",
"webdriver.ie.driver":"IEDriverServer.exe"
}

],
"configuration": {
"proxy": "org.openqa.grid.selenium.proxy.DefaultRemoteProxy",
"maxSession": 5,
"port": 6060,
"register": true,
"registerCycle": 5000,
"hub": "http://192.168.1.8:4444"
}
}

在cmd中执行命令:java -jar selenium-server-standalone-2.53.1.jar -role node -nodeConfig node.json

这种方式修改的配置参数只能执行webdriver脚本。也能通过命令的方式指定执行webdriver脚本,执行命令:java -jar selenium-server-standalone-2.53.1.jar -role wd -port 6767 -hub http://192.168.1.8:4444/grid/register

(此方法基本不使用)只能执行rc脚本的命令:java -jar selenium-server-standalone-2.53.1.jar -role rc-port 6768 -hub http://192.168.1.8:4444/grid/register

指定Node节点计算机执行测试用例

启动一个Hub:java -jar selenium-server-standalone-2.53.1.jar -role hub -port 5050

启动一个Node并注册大Hub:java -jar selenium-server-standalone-2.53.1.jar -role node -hub http://192.168.1.8:5050/grid/register

Java代码

package com.selenium;

import java.net.MalformedURLException;
import java.net.URL; import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.remote.DesiredCapabilities;
import org.openqa.selenium.remote.RemoteWebDriver;
import org.testng.Assert;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeTest;
import org.testng.annotations.Test; public class Grid {
WebDriver driver;
@BeforeTest
public void BeforeTest() throws MalformedURLException{
//创建一个DesiredCapabilities类型 DesiredCapabilities ChromeGrid=DesiredCapabilities.chrome();
//实例化一个driver
driver=new RemoteWebDriver(new URL("http://192.168.1.8:5050/wd/hub"),ChromeGrid);
driver.get("https://www.baidu.com/");
} @Test
public void gridTest() throws InterruptedException{ driver.findElement(By.xpath("//*[@id='kw']")).sendKeys("selenium");
driver.findElement(By.xpath("//*[@id='su']")).click();
Thread.sleep(3000);
//获取页面上的资源
String sourcetext=driver.getPageSource();
//校验搜索结果是否包含 selenium
Assert.assertTrue(sourcetext.contains("selenium"));
Thread.sleep(3000);
}
@AfterMethod
public void aftermethod(){
driver.quit();
} }

通过TestNG数据驱动的方式指定Node节点计算机上指定浏览器执行测试用例

Java代码:

package com.selenium;

import java.net.MalformedURLException;
import java.net.URL; import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.remote.DesiredCapabilities;
import org.openqa.selenium.remote.RemoteWebDriver;
import org.testng.Assert;
import org.testng.annotations.*; public class GridBingFa {
WebDriver driver;
@DataProvider(name="data")
public Object[][] Data(){
return new Object[][]{
{"chrome","http://192.168.1.8:6060/wd/hub"},
{"ie","http://192.168.1.8:6070/wd/hub"},
};
}
@Test(dataProvider="data")
public void test(String browser,String Url) throws InterruptedException, MalformedURLException{
DesiredCapabilities BrowserGrid = null;
if(browser.contentEquals("chrome")){
BrowserGrid =DesiredCapabilities.chrome();
}else{
BrowserGrid =DesiredCapabilities.internetExplorer();
}
WebDriver driver=new RemoteWebDriver(new URL(Url),BrowserGrid);
driver.get("https://www.baidu.com/");
driver.findElement(By.xpath("//*[@id='kw']")).sendKeys("selenium");
driver.findElement(By.xpath("//*[@id='su']")).click();
Thread.sleep(3000);
//获取页面上的资源
String sourcetext=driver.getPageSource();
//校验搜索结果是否包含 selenium
Assert.assertTrue(sourcetext.contains("selenium"));
Thread.sleep(3000);
driver.quit();
} }

 

selenium Grid2环境搭建和基本使用的更多相关文章

  1. Python+Selenium+webdriver环境搭建(windows)以及相关资源下载链接

    今天记录一下测试小菜鸟alter在测试入门的一点关于python+Selenium+webdriver环境搭建的经历以及资源分享.欢迎交流学习,批评指正. 一.Python的下载与安装 1.pytho ...

  2. 自动化测试基础篇--Selenium Python环境搭建

    学习selenium python需要的工具: 1.浏览器 2.Python 3.Selenium 4.FireBug(Firefox) 5.chromedriver.IEDriverServer.g ...

  3. Selenium Web 自动化 - Selenium(Java)环境搭建

    Selenium Web 自动化 - Selenium(Java)环境搭建 2016-07-29 1 下载JDK JDK下载地址:http://www.oracle.com/technetwork/j ...

  4. 引用 自动化测试基础篇--Selenium Python环境搭建

    原文链接:https://www.cnblogs.com/sanzangTst/p/7452922.html 鸣谢参藏法师. 学习selenium python需要的工具: 1.浏览器 2.Pytho ...

  5. selenium测试环境搭建(一)

    selenium测试环境搭建 下载资源 1.  selenium-java-2.53.0.zip 下载地址:http://pan.baidu.com/s/1dFDf27Z 2. Firefox Set ...

  6. 《手把手教你》系列基础篇之(二)-java+ selenium自动化测试-环境搭建(下)基于Maven(详细教程)

    1.简介 Apache Maven是一个软件项目管理和综合工具.基于项目对象模型(POM)的概念,Maven可以从一个中心资料片管理项目构建,报告和文件.由于现在企业和公司中Java的大部分项目都是基 ...

  7. Selenium RC 环境搭建(eclipse)

    环境搭建参考:http://seleniumcn.cn/read.php?tid=7962  非常详细!晕乎晕乎了两天,看到这边帖子,终于搭起来了. 关于Selenium RC的原理,还是Seleni ...

  8. mac下selenium+python环境搭建

    selenium2+python的环境搭建主要需要python和selenium 1.python mac下自带了python,可以查看版本.当然可以选择安装其它版本的python. 2.seleni ...

  9. 基于python的selenium自动化测试环境搭建

    Windows下的环境搭建: 1.安装python2.7.152.cmd里敲pip install selenium3.安装firefox47.geckodriver11(并将geckodriver. ...

随机推荐

  1. mysql基础知识语法汇总整理(二)

    mysql基础知识语法汇总整理(一) insert /*insert*/ insert into 表名(字段列表) values(值列表); --蠕虫复制 (优点:快速复制数据,测试服务器压力) in ...

  2. Leetcode题目33.搜索旋转排序数组(中等)

    题目描述: 假设按照升序排序的数组在预先未知的某个点上进行了旋转. ( 例如,数组 [0,1,2,4,5,6,7] 可能变为 [4,5,6,7,0,1,2] ). 搜索一个给定的目标值,如果数组中存在 ...

  3. AsyncTaskMethodBuilder

    AsyncTaskMethodBuilder Represents a builder for asynchronous methods that return a task. public stru ...

  4. 梯度下降(Gradient Descent)小结 -2017.7.20

    在求解算法的模型函数时,常用到梯度下降(Gradient Descent)和最小二乘法,下面讨论梯度下降的线性模型(linear model). 1.问题引入 给定一组训练集合(training se ...

  5. DP&图论 DAY 2 下午

    DP&图论  DAY 2  下午 基础树形DP 前言◦ 1:与树或图的生成树相关的动态规划.◦ 2:以每棵子树为子结构,在父亲节点合并,注意树具有天然的子结构.这是很优美的很利于dp的.◦ 3 ...

  6. YJango的卷积神经网络——介绍

    原文地址:https://zhuanlan.zhihu.com/p/27642620 如果要提出一个新的神经网络结构,首先就需要引入像循环神经网络中“时间共享”这样的先验知识,降低学习所需要的训练数据 ...

  7. mysql sql常用语句

    1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份sql server --- 创建 备份 ...

  8. JavaScript日常学习3

    JavaScript函数  函数就是包裹在花括号中的代码块,前面使用了关键词 function: function functionname()     {执行代码} function myFunct ...

  9. 集群中配置多台机器之间 SSH 免密码登录

    集群中配置多台机器之间 SSH 免密码登录 问题描述 由于现在项目大多数由传统的单台机器部署,慢慢转变成多机器的集群化部署. 但是,这就涉及到机器间的 SSH 免密码互通问题. 当集群机器比较多的时候 ...

  10. JSP 简单标签extends SimpleTagSupport

    1.控制JSP页面某一部分内容是否执行 public void doTag() this.getJspBody().invoke(null);执行 空白,不执行 2.控制JSP页面内容重复执行 pac ...