
本文档旨在指导 Selenium Grid 4 的新手,使其能够配置 Grid 环境,并实现在特定节点上运行测试脚本的需求。通过设置自定义 capabilities,您可以精确控制测试用例的执行位置,从而提高测试效率和可靠性。
Selenium Grid 4 允许您在不同的机器和浏览器上并行运行测试。在某些情况下,您可能需要将特定的测试用例定向到特定的节点执行,例如,某个节点配置了特定的硬件或软件环境。本文将介绍如何通过自定义 capabilities 来实现这一目标。
配置 Selenium Grid 节点
首先,您需要在 Selenium Grid 节点的配置文件(toml 文件)中设置自定义 capabilities。这些 capabilities 将用于标识特定的节点。
打开节点的 toml 配置文件,找到 [[node.driver-configuration]] 部分。在此部分中,添加自定义的 capabilities。例如,您可以添加 networkname:applicationName 和 nodename:applicationName 两个 capabilities。
[node]
override-max-sessions = true
max-sessions = 15
selenium-manager = true
detect-drivers = false
enable-managed-downloads = true
grid-url = "yourIp"
session-timeout = 1800
[[node.driver-configuration]]
max-sessions = 15
display-name = "Chrome"
stereotype = '{"browserName": "chrome", "platformName": "WIN10", "networkname:applicationName":"nodex", "nodename:applicationName":"appx"}'说明:
- networkname:applicationName 和 nodename:applicationName 是自定义的 capability 名称,您可以根据自己的需要进行修改。
- nodex 和 appx 是对应的值,用于标识特定的节点。请确保每个节点的值都是唯一的。
- stereotype 定义了节点的标准 capabilities,例如浏览器名称和平台名称。确保这些 capabilities 与您要运行的测试用例兼容。
修改测试代码
接下来,您需要在测试代码中设置相应的 capabilities,以便将测试用例定向到特定的节点。
在创建 WebDriver 实例时,设置 networkname:applicationName 和 nodename:applicationName capabilities。
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.chrome.ChromeOptions;
import org.openqa.selenium.remote.RemoteWebDriver;
import java.net.URL;
import java.net.MalformedURLException;
public class SeleniumGridExample {
public static void main(String[] args) throws MalformedURLException {
ChromeOptions options = new ChromeOptions();
options.setCapability("networkname:applicationName", "nodex");
options.setCapability("nodename:applicationName", "appx");
// options.setBrowserVersion("96"); // 可选:设置浏览器版本
// options.setPlatformName("macOS"); // 可选:设置平台名称
WebDriver driver = new RemoteWebDriver(new URL("http://localhost:4444"), options);
driver.get("https://www.example.com");
System.out.println("Page title is: " + driver.getTitle());
driver.quit();
}
}说明:
- ChromeOptions 用于设置 Chrome 浏览器的 capabilities。
- options.setCapability("networkname:applicationName", "nodex") 和 options.setCapability("nodename:applicationName", "appx") 设置了自定义的 capabilities,其值与节点配置文件中的值相匹配。
- new RemoteWebDriver(new URL("http://localhost:4444"), options) 创建了一个远程 WebDriver 实例,连接到 Selenium Grid Hub。将 http://localhost:4444 替换为您的 Grid Hub 地址。
- 您可以根据需要设置其他的 capabilities,例如浏览器版本和平台名称。
注意事项
- 确保节点配置文件中的 capabilities 与测试代码中的 capabilities 相匹配。
- 如果多个节点具有相同的 capabilities,则测试用例可能会在其中任何一个节点上运行。
- 如果没有任何节点具有与测试代码中指定的 capabilities 相匹配的节点,则测试用例将无法运行。
- 启动 Grid Hub 和节点时,请确保它们能够相互通信。检查防火墙设置和网络连接。
总结
通过设置自定义 capabilities,您可以灵活地控制 Selenium Grid 4 中测试用例的执行位置。这对于需要在特定环境中运行测试用例的情况非常有用。 请记住,准确配置节点和测试代码中的 capabilities 至关重要,以确保测试用例能够正确地定向到所需的节点。










