UI自动化-Grid分布式运行

实现 Selenium Grid 分布式运行测试用例,核心是通过 Hub(中心节点) 统一调度、 Node(代理节点) 执行用例,实现多浏览器 / 多机器并行测试

  • Hub:Grid 的 "调度中心",负责接收测试请求、管理所有 Node 节点、分发用例到可用的 Node;
  • Node:连接到 Hub 的 "执行节点",提供浏览器运行环境(Chrome/Firefox 等),执行 Hub 分发的用例;
  • 核心价值:多机器 / 多浏览器并行执行用例,提升测试效率;支持跨平台(Windows/Linux/Mac)、跨浏览器测试。

1. 安装运行环境

1.1 下载 JDK(推荐 8/11 版本,兼容 Selenium 4.x):

2. 访问启动的地址:http://192.168.1.14:4444/ui/----能访问成功则说明启动成功

3. 连接Grid-单个用例

python 复制代码
import time
from selenium.webdriver import Remote, ChromeOptions

driver = Remote(
    command_executor="http://127.0.0.1:4444",
    options=ChromeOptions()
)
driver.get("https://www.baidu.com")

time.sleep(3)
driver.quit() # 在grid浏览器不会随着Python自动结束,务必要手动关闭!不然影响资源占用

4. 分布式执行

  • 执行命令: pytest -n 4(执行并行数) / pytest test_grid.py -n auto (自动根据 CPU 核心数并行)
  • 注意需要安装pytest-xdist插件: pip install pytest-xdist
python 复制代码
import pytest
import time
from selenium.webdriver import Remote, ChromeOptions


@pytest.fixture()
def driver():
    d = Remote(
        command_executor="http://127.0.0.1:4444",
        options=ChromeOptions()
    )
    yield d
    d.quit()  # 在grid 浏览器不会随着Python自动结束,务必要手动关闭!


@pytest.mark.parametrize(
    "url",
    [
        "https://www.baidu.com",
        "https://www.bilibili.com/",
        "https://www.csdn.net/",
    ]
)
def test_ces(driver, url):
    time.sleep(2)
    driver.get(url)

执行结果:三个用例同时执行

相关推荐
上海云盾-小余11 小时前
验证码接口攻防实战:杜绝拖拽刷量引发服务器瘫痪
运维·服务器
DianSan_ERP11 小时前
自研电商架构:一套API安全对接60+平台
大数据·运维·数据库·人工智能·安全·架构
小小de风呀11 小时前
de风——【从零开始学习Linux】Linux基础指令详解(一)
linux·运维·服务器
蜡笔婧萱11 小时前
Linux---web服务器与DNS域名解析服务器的综合挑战
linux·运维·服务器
zandy101111 小时前
hermes agent 安装教程 3.0:Win / Mac / Linux 全平台指南
linux·运维·macos
.千余11 小时前
【Linux 】网络基础1
linux·运维·服务器·开发语言·网络·学习
IMPYLH11 小时前
Linux 的 uniq 命令
linux·运维·服务器·bash
TechWayfarer11 小时前
IP归属地API实战指南:用IP数据云解析日志挖掘用户地域分布
大数据·开发语言·网络·python·tcp/ip
Cloud_Shy61811 小时前
Python 数据分析基础入门:《Excel Python:飞速搞定数据分析与处理》学习笔记系列(第十一章 Python 包跟踪器 中篇)
数据库·python·sql·数据分析·excel·web
刘马想放假11 小时前
OpenVPN 深度解析:从协议原理到生产实践
运维·网络协议