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)

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

相关推荐
SLD_Allen几秒前
Kafka分区与消费者的关系kafka分区和消费者线程的关系
分布式·kafka
Championship.23.241 分钟前
Linux 3.0 音频机制深度解析:ALSA基础架构与传统音频驱动模型
linux·运维·音视频·alsa
he___H5 分钟前
数据密集型应用系统设计--其一
分布式
Full Stack Developme8 分钟前
Java DFA算法
java·python·算法
留白_21 分钟前
pandas文件读取与存储
开发语言·python·pandas
我的xiaodoujiao23 分钟前
API 接口自动化测试详细图文教程学习系列25--继续处理testCase中的数据
python·学习·测试工具·pytest
Wang ruoxi26 分钟前
Pygame 小游戏——节奏点击
python·pygame
夕除28 分钟前
AOP 实现 Redis 缓存切面解析
java·开发语言·python
无证驾驶梁嗖嗖28 分钟前
ubuntu下测试nvme带宽和健康度
运维
fanjiu202034 分钟前
python查询nightingale监控
python