UI自动化:poium测试库

ops/2025/3/13 22:46:49/

以下是关于 poium 测试库 的详细介绍,涵盖其核心功能、使用方法及与原生 Selenium 的对比,帮助快速掌握这一工具:


1. poium 简介

  • 定位:基于 Selenium 的 Page Object 模式增强库,专注于简化元素定位和页面操作。

  • 核心目标

    • 通过简洁的 API 提升代码可读性。

    • 减少样板代码,提升测试脚本开发效率。

    • 内置智能等待、链式调用等实用功能。

  • 适用场景:Web 自动化测试(尤其适合中大型项目需要维护 Page Object 的场景)。


2. 安装 poium

bash

复制

pip install poium

3. 核心功能与使用

3.1 元素定位

  • 支持多种定位方式(语法更简洁):

    python

    复制

    from poium import Page, Elementclass LoginPage(Page):username = Element(id_="username", describe="用户名输入框")  # id定位password = Element(css=".password", describe="密码输入框")  # CSS选择器submit = Element(xpath="//button[@type='submit']", describe="提交按钮")

3.2 链式操作

  • 流式调用提升代码可读性:

    python

    复制

    LoginPage().username.input("admin").password.input("123456").submit.click()

3.3 智能等待

  • 自动处理元素加载等待,无需手动编写 WebDriverWait

    python

    复制

    # 元素默认等待时间(全局配置)
    from poium import config
    config.timeout = 10  # 设置全局等待时间为10秒# 单个元素自定义等待
    error_msg = Element(css=".error", timeout=5)

3.4 元素操作扩展

  • 内置丰富操作方法

    python

    复制

    element.input("text")     # 输入文本
    element.click()           # 点击
    element.clear()           # 清空内容
    element.get_text()        # 获取文本
    element.is_displayed()    # 判断元素是否可见

3.5 断言增强

  • 集成常用断言方法

    python

    复制

    from poium import assertsasserts.assert_title("首页")                     # 断言页面标题
    asserts.assert_element_text(login.submit, "登录") # 断言元素文本

4. 完整示例

Page Object 定义

python

复制

from poium import Page, Elementclass BaiduSearchPage(Page):search_input = Element(id_="kw", describe="搜索框")search_button = Element(id_="su", describe="搜索按钮")def search(self, keyword):self.search_input.input(keyword)self.search_button.click()

测试用例(结合 pytest)

python

复制

def test_baidu_search():page = BaiduSearchPage()page.open("https://www.baidu.com")page.search("poium")asserts.assert_title_contains("poium")

5. 与原生 Selenium 对比

功能原生 Seleniumpoium
元素定位driver.find_element(By.ID, "kw")Element(id_="kw")
元素操作element.send_keys("text")element.input("text")
等待处理需手动编写 WebDriverWait自动智能等待(可配置超时)
代码结构需自行封装 Page Object内置 Page 类,直接继承即可
断言结合 unittest 或 pytest 断言内置 asserts 模块提供专用断言方法

6. 实践

poium + pytest + Allure

  1. 目录结构

    复制

    project/├── pages/          # 存放Page Object类├── tests/          # 测试用例├── conftest.py     # pytest配置(如driver初始化)└── utils/          # 工具函数(如数据生成)
  2. Driver 管理

    python

    复制

    # conftest.py
    import pytest
    from selenium import webdriver
    from poium import Browser@pytest.fixture(scope="session")
    def driver():driver = webdriver.Chrome()yield Browser(driver)  # 将原生driver封装为poium的Browser对象driver.quit()
  3. 数据驱动(结合 pytest.mark.parametrize):

        python

        复制

import pytest@pytest.mark.parametrize("keyword", ["selenium", "poium", "pytest"])
def test_search(driver, keyword):page = BaiduSearchPage(driver)page.open("https://www.baidu.com")page.search(keyword)asserts.assert_title_contains(keyword)

seldom + poium

import seldom
from poium import Page, Elementclass BaiduPage(Page):"""baidu page"""search_input = Element(id_="kw")search_button = Element(id_="su")class BaiduTest(seldom.TestCase):"""Baidu search test case"""def test_case(self):"""A simple test"""page = BaiduPage(self.driver, print_log=True)page.open("https://www.baidu.com")page.search_input.send_keys("seldom")page.search_button.click()self.assertTitle("seldom_百度搜索")if __name__ == '__main__':seldom.main(browser="chrome")

7. 常见问题

Q1:如何处理动态元素(如弹窗)?

  • 方案:通过 Element 的 timeout 参数调整等待时间,或结合 is_displayed() 判断。

    python

    复制

    class PopupPage(Page):confirm_btn = Element(css=".confirm", timeout=5)def test_handle_popup():if PopupPage().confirm_btn.is_displayed():PopupPage().confirm_btn.click()

Q2:如何与 Allure 报告集成?

  • 步骤

    1. 安装 pytest-allure

      bash

      复制

      pip install allure-pytest
    2. 运行测试并生成报告:

      bash

      复制

      pytest --alluredir=./allure-results
      allure serve ./allure-results

Q3:如何复用公共页面组件?

  • 方案:通过类继承或 Mixin 模式复用组件。

    python

    复制

    class HeaderComponent(Page):home_link = Element(link_text="首页")class HomePage(HeaderComponent):search_input = Element(id_="search")

8.总结

  • poium 优势:简化元素操作、内置智能等待、提升代码可维护性,适合中大型项目。

  • 适用项目:需要长期维护的 Web 自动化测试,尤其是遵循 Page Object 模式的项目。


http://www.ppmy.cn/ops/165529.html

相关文章

Spring Cloud Alibaba 实战:Sentinel 保障微服务的高可用性与流量防护

1.1 Sentinel 作用 Sentinel 是阿里巴巴开源的一款 流量控制和熔断降级 框架,主要用于: 流量控制:限制 QPS,防止流量暴增导致系统崩溃熔断降级:当某个服务不可用时自动降级,避免故障扩散热点参数限流&…

超越限制:大模型token管理与优化实践

前言 在大型语言模型(LLM)的应用中,token数量的管理是一个核心挑战。无论是模型的输入限制、计算资源的分配,还是成本的控制,token计数都至关重要。然而,当调用超过预期范围时,我们该如何应对&…

C盘清理技巧分享:释放空间,提升电脑性能

目录 1. 引言 2. C盘空间不足的影响 3. C盘清理的必要性 4. C盘清理的具体技巧 4.1 删除临时文件 4.2 清理系统还原点 4.3 卸载不必要的程序 4.4 清理下载文件夹 4.5 移动大文件到其他盘 4.6 清理系统缓存 4.7 使用磁盘清理工具 4.8 清理Windows更新文件 4.9 禁用…

IEC61850标准下MMS 缓存报告控制块 ResvTms详细解析

IEC61850标准是电力系统自动化领域唯一的全球通用标准。IEC61850通过标准的实现,使得智能变电站的工程实施变得规范、统一和透明,这大大提高了变电站自动化系统的技术水平和安全稳定运行水平。 在 IEC61850 标准体系中,ResvTms(r…

Redis 事务底层实现

Redis 事务的底层实现主要基于以下机制: 1.事务的启动与命令排队 Redis 使用MULTI命令启动一个事务。当客户端发送MULTI命令后,Redis 会进入事务模式。在此模式下,客户端发送的所有命令不会立即执行,而是被放入一个队列中&#x…

STM32 内置的通讯协议

数据是以帧为单位发的 USART和UART的区别就是有没有同步功能 同步是两端设备有时钟连接,异步是没时钟连接,靠约定号的频率(波特率)接收发送数据 RTS和CTS是用来给外界发送已“可接收”或“可发送”信号的,一般用不到…

Python数据分析之数据可视化

Python 数据分析重点知识点 本系列不同其他的知识点讲解,力求通过例子让新同学学习用法,帮助老同学快速回忆知识点 可视化系列: Python基础数据分析工具数据处理与分析数据可视化机器学习基础 四、数据可视化 图表类型与选择 根据数据特…

Denoising as Adaptation Noise-Space Domain Adaptation for Image Restoration

去噪即自适应:用于图像恢复的噪声空间域自适应 论文链接:https://arxiv.org/html/2406.18516v3 项目链接:https://kangliao929.github.io/projects/noise-da/ ABSTRACT 尽管基于学习的图像恢复方法取得了重大进展,但由于合成数…