当前位置: 代码网 > it编程>前端脚本>Python > Python的端到端测试框架SeleniumBase使用解读

Python的端到端测试框架SeleniumBase使用解读

2025年06月19日 Python 我要评论
seleniumbase详细介绍及用法指南什么是 seleniumbase?seleniumbase 是一个基于 python 的端到端测试框架,它构建在 selenium 和 pytest 之上,提

seleniumbase详细介绍及用法指南

什么是 seleniumbase?

seleniumbase 是一个基于 python 的端到端测试框架,它构建在 selenium 和 pytest 之上,提供了更简单、更强大的 web 自动化测试和爬虫开发体验。

它简化了 selenium 的许多复杂操作,并添加了大量有用的功能。

seleniumbase 的主要特点

  1. 简化语法:比原生 selenium 更简洁的 api
  2. 内置等待机制:自动处理元素加载等待
  3. 丰富的断言方法:提供多种验证方式
  4. 可视化测试:支持实时浏览器操作观察
  5. 截图和日志:自动记录测试过程
  6. 多浏览器支持:chrome, firefox, edge, safari 等
  7. 无头模式:支持无头浏览器测试
  8. 移动设备模拟:可以模拟移动设备测试
  9. 代理支持:方便使用代理服务器
  10. 与 pytest 集成:充分利用 pytest 的强大功能

安装 seleniumbase

pip install seleniumbase

基本用法

1. 简单测试示例

from seleniumbase import basecase

class mytestclass(basecase):

    def test_basic(self):
        self.open("https://www.example.com")
        self.assert_title("example domain")
        self.assert_element("div h1")
        self.type("input[name='q']", "seleniumbase\n")
        self.assert_text("results for", "h3")

2. 元素定位与操作

seleniumbase 提供了多种元素定位和操作方法:

def test_element_operations(self):
    self.open("https://www.example.com")
    
    # 点击元素
    self.click("button#submit")
    
    # 输入文本
    self.type("input#username", "testuser")
    
    # 清除输入框
    self.clear("input#username")
    
    # 获取元素文本
    text = self.get_text("h1")
    
    # 获取元素属性
    attr = self.get_attribute("img#logo", "src")
    
    # 检查元素是否存在
    self.assert_element("div.container")
    
    # 检查元素是否可见
    self.assert_element_visible("div.message")

3. 断言方法

seleniumbase 提供了丰富的断言方法:

def test_assertions(self):
    self.open("https://www.example.com")
    
    # 标题断言
    self.assert_title("example domain")
    self.assert_title_contains("example")
    
    # 文本断言
    self.assert_text("example domain", "h1")
    self.assert_exact_text("example domain", "h1")
    
    # url 断言
    self.assert_url("https://www.example.com/")
    self.assert_url_contains("example.com")
    
    # 元素断言
    self.assert_element("div h1")
    self.assert_element_present("div h1")
    self.assert_element_absent("div.nonexistent")
    
    # 其他断言
    self.assert_true(1 + 1 == 2)
    self.assert_false(1 + 1 == 3)

4. 等待机制

seleniumbase 自动处理大多数等待场景,但也提供了显式等待方法:

def test_waiting(self):
    self.open("https://www.example.com")
    
    # 等待元素出现
    self.wait_for_element("div.loading")
    
    # 等待元素可点击
    self.wait_for_element_clickable("button.submit")
    
    # 等待文本出现
    self.wait_for_text("welcome back", "h2")
    
    # 自定义等待时间
    self.wait_for_element("div.result", timeout=20)
    
    # 等待元素消失
    self.wait_for_element_absent("div.loading")

高级功能

1. 无头模式测试

def test_headless(self):
    self.open("https://www.example.com")
    # 断言代码...
    
# 运行时使用 --headless 参数
# pytest test_file.py --headless

2. 截图和日志

def test_screenshot(self):
    self.open("https://www.example.com")
    self.save_screenshot("example.png")
    self.save_screenshot_to_logs()  # 保存到日志目录

3. 移动设备模拟

def test_mobile_emulation(self):
    mobile_emulation = {
        "devicemetrics": {"width": 360, "height": 640, "pixelratio": 3.0},
        "useragent": "mozilla/5.0 (linux; android 4.2.1; en-us; nexus 5 build/jop40d) applewebkit/535.19 (khtml, like gecko) chrome/18.0.1025.166 mobile safari/535.19"
    }
    self.open_with_options("https://www.example.com", mobile_emulation=mobile_emulation)

4. 使用代理

def test_with_proxy(self):
    proxy_string = "127.0.0.1:8080"
    self.open_with_proxy("https://www.example.com", proxy_string)

5. iframe 操作

def test_iframe(self):
    self.open("https://www.example.com")
    self.switch_to_frame("iframe#content")
    # 在 iframe 中操作元素
    self.click("button.submit")
    self.switch_to_default_content()  # 切换回主文档

测试运行选项

seleniumbase 测试可以使用 pytest 运行,并支持多种参数:

# 基本运行
pytest test_file.py

# 无头模式
pytest test_file.py --headless

# 指定浏览器
pytest test_file.py --browser=firefox

# 慢动作模式(便于观察)
pytest test_file.py --demo_mode

# 保存失败的测试截图
pytest test_file.py --screenshot_on_failure

# 并行测试
pytest test_file.py -n 4

与 ci/cd 集成

seleniumbase 测试可以轻松集成到 ci/cd 流程中。例如,在 github actions 中的配置示例:

name: seleniumbase tests

on: [push]

jobs:
  test:
    runs-on: ubuntu-latest
    steps:
    - uses: actions/checkout@v2
    - name: set up python
      uses: actions/setup-python@v2
      with:
        python-version: '3.8'
    - name: install dependencies
      run: |
        python -m pip install --upgrade pip
        pip install seleniumbase
    - name: run tests
      run: |
        pytest tests/ --headless --browser=chrome

最佳实践

  1. 使用 page object 模式:将页面元素和操作封装成类
  2. 合理使用等待:优先使用 seleniumbase 的自动等待
  3. 清晰的测试命名:使测试目的明确
  4. 适当的断言:每个测试验证一个明确的功能点
  5. 维护测试数据:使用外部文件或数据库管理测试数据
  6. 定期维护测试:随着应用更新调整测试用例
  7. 利用钩子和固件:使用 pytest 的固件功能减少重复代码

总结

seleniumbase 是一个功能强大且易于使用的测试框架,它简化了 selenium 的复杂性,同时提供了丰富的功能。无论是简单的网站测试还是复杂的 web 应用程序测试,seleniumbase 都能提供高效的解决方案。通过结合 pytest 的强大功能,它可以满足从简单到复杂的所有测试需求。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com