网站首页 > 知识剖析 正文
SeleniumBase是一款全功能的浏览器自动化框架,专为Web测试、爬虫、数据抓取和"隐身"操作设计。
它构建在Selenium WebDriver的基础上,但提供了更简洁的API和强大的扩展功能,大幅提高了Web自动化任务的效率和可靠性。
作为一款专业的Web自动化工具包,SeleniumBase其核心目标是简化 Web 测试、数据抓取、隐身浏览等复杂任务,提供从单机脚本到分布式测试的全流程支持。
核心特性
- 简化的API:相比原生Selenium,提供更简洁、更直观的命令语法
- 多种运行模式:支持UC Mode和CDP Mode等特殊模式,具备"隐身"能力
- 多浏览器支持:兼容Chrome、Edge、Firefox和Safari等主流浏览器
- 跨平台兼容:支持Linux/Ubuntu、macOS和Windows操作系统
- CI/CD集成:可在GitHub Actions、Jenkins、Azure、Google Cloud和AWS等平台上运行
- 自动等待:自动等待页面元素加载完成,无需手动添加time.sleep()语句
- 测试报告:生成丰富的HTML报告和仪表盘可视化测试结果
- 调试工具:提供Demo Mode和Debug Mode便于测试调试和可视化
项目结构与快速上手
目录解析
SeleniumBase/
├── examples/ # 200+实战示例(含测试、爬虫、隐身模式案例)
├── help_docs/ # 官方文档与客户案例
├── integrations/ # 集成模块(如Selenium Grid、MySQL日志存储)
├── sbase/ # 核心库代码(含CDP模式、驱动管理)
├── tests/ # 单元测试与集成测试
├── .github/ # 自动化工作流配置(如CI/CD脚本)
├── LICENSE # MIT开源协议
└── requirements.txt # 依赖清单(支持Python 3.8-3.13)
安装与初始化
# 从PyPI安装(推荐)
pip install seleniumbase
# 从GitHub克隆开发版
git clone https://github.com/seleniumbase/SeleniumBase.git
cd SeleniumBase
pip install -e .
# 初始化测试项目
sbase mkdir my_tests # 自动生成配置文件与示例脚本
代码示例
基于BaseCase类的测试示例
以下示例展示了SeleniumBase中最常用的测试方式,通过继承BaseCase类创建测试用例。
这段代码模拟了在电商网站上完成完整购物流程的场景,从登录到下单确认。
from seleniumbase import BaseCase
BaseCase.main(__name__, __file__)
class MyTestClass(BaseCase):
def test_swag_labs(self):
self.open("https://www.saucedemo.com")
self.type("#user-name", "standard_user")
self.type("#password", "secret_sauce")
self.click("input#login-button")
self.assert_element("div.inventory_list")
self.click("button#add-to-cart-sauce-labs-backpack")
self.click("#shopping_cart_container a")
self.assert_text("Backpack", "div.cart_item")
self.click("button#checkout")
self.type("#first-name", "SeleniumBase")
self.type("#last-name", "Automation")
self.type("#postal-code", "77123")
self.click("input#continue")
self.assert_text("Thank you for your order!")
BaseCase提供了丰富的内置方法如open()、type()、click()和assert_element()等,使测试代码简洁易读。
使用SB上下文管理器的简洁写法
以下代码展示了SeleniumBase的上下文管理器(Context Manager)用法,是快速执行短期自动化任务的理想选择。
通过with SB() as sb:语法,可以自动处理浏览器的启动和关闭,无需手动管理资源。
from seleniumbase import SB
with SB(uc=True, test=True, locale="en") as sb:
sb.open("https://nowsecure.nl/users/sign_in")
sb.activate_cdp_mode(url)
sb.xp_click_captcha()
sb.sleep(2)
参数uc=True启用了"无痕模式"(Undetected Chrome),能有效绕过现代网站的反爬机制。test=True启用测试模式,提供更详细的日志。
使用Driver管理器
Driver管理器提供了比原生Selenium更简洁但功能相当的API,适合那些熟悉Selenium但希望减少代码量的开发者。
from seleniumbase import Driver
driver = Driver()
try:
driver.open("seleniumbase.io/simple/login")
driver.type("#username", "demo_user")
driver.type("#password", "secret_pass")
driver.click("a:contains('Sign in')")
driver.assert_exact_text("Welcome!", "h1")
driver.assert_element("img#image1")
driver.highlight("#image1")
driver.click_link("Sign out")
driver.assert_text("signed out", "#top_message")
finally:
driver.quit()
使用try-finally结构确保测试无论成功失败都会正确关闭浏览器,防止资源泄露。
特色功能详解
Demo模式
Demo模式可以帮助可视化测试过程,使测试步骤变得清晰可见:
pytest my_first_test.py --demo
在Demo模式下,测试会在浏览器操作之间短暂暂停,并高亮显示正在操作的页面元素,同时显示断言信息。当测试速度过快时,这个模式非常有用。
仪表盘和报告
SeleniumBase提供了强大的仪表盘功能,可实时显示测试结果:
pytest --dashboard --rs --headless
此命令会生成一个HTML仪表盘,自动更新测试运行结果,包括通过、失败和跳过的测试数量,以及详细的测试信息。
还可以使用以下命令生成HTML报告:
pytest test_suite.py --htmlreport.html
生成测试报告
使用--htmlreport.html参数可生成详细的HTML测试报告
pytest test_suite.py --dashboard --html=report.html
使用--junit-xml=report.xml生成XML格式报告
pytest test_suite.py --junit-xml=report.xml
还支持pynose格式的报告(--report选项),提供简洁的测试结果摘要,并支持使用--show-report即时显示
pynose test_suite.py --report
behave测试框架的用户可以使用类似的仪表盘和报告功能,通过--dashboard和--junit参数生成可视化结果。
behave behave_bdd/features/ -D dashboard -D headless
命令行选项
SeleniumBase提供了丰富的命令行选项,用于自定义测试行为:
- --browser=BROWSER:指定使用的浏览器(默认为Chrome)
- --headless:无头模式运行测试,不显示浏览器界面
- --demo:以演示模式运行测试,展示每个步骤
- --rs或--reuse-session:重用浏览器会话,提高效率
- --dashboard:生成实时更新的测试仪表盘
- --proxy=IP_ADDRESS:PORT:使用代理服务器进行测试
SeleniumBase VS 原生Selenium
对比维度 | SeleniumBase | 原生Selenium |
开发效率 | 单方法实现多步操作,语法极简 | 需要手动处理等待、异常等底层逻辑 |
反爬能力 | 内置UC/CDP隐身模式 | 需自行封装CDP协议 |
测试报告 | 支持HTML、仪表盘、JUnit XML | 需额外插件生成报告 |
团队协作 | 提供CasePlans用例管理、GUI工具 | 依赖第三方工具链 |
总结
SeleniumBase是一款非常好用的Web自动化框架,它在Selenium WebDriver的基础上提供了显著的功能增强和简化的API。
不仅支持常规的网站测试,还能有效处理验证码绕过、数据抓取和自动化任务执行。直观的命令语法大幅降低了Web自动化的学习曲线,同时内置的Demo模式和调试工具让测试过程更加透明可控。
SeleniumBase还兼容所有主流浏览器和操作系统,更是可以无缝集成到各种CI/CD平台,是自动化工作流的理想选择。
GitHub项目地址:https://github.com/seleniumbase/SeleniumBase
猜你喜欢
- 2025-06-04 记一次实战给朋友站点测试(测试站点是什么意思)
- 2025-06-04 详细讲解性能测试(详细讲解性能测试题)
- 2025-06-04 [实战] cursor +claude-3.7+ go 实现批量网站敏感词检测
- 2025-06-04 Python最强大测试框架pytest(pytest框架原理)
- 2025-06-04 接口自动化的关键思路和解决方案,看完不会你捶我
- 2025-06-04 pytest测试框架pytest-cov插件生成代码覆盖率
- 2025-06-04 pytest单元测试框架(pytest框架设计)
- 2025-06-04 Pytest入门指南:轻松学会高效测试框架
- 2025-06-04 测试员进阶技能:如何有效地利用单元测试报告?
- 2025-06-04 测试开发必知必会:Pytest框架实战
- 最近发表
- 标签列表
-
- xml (46)
- css animation (57)
- array_slice (60)
- htmlspecialchars (54)
- position: absolute (54)
- datediff函数 (47)
- array_pop (49)
- jsmap (52)
- toggleclass (43)
- console.time (63)
- .sql (41)
- ahref (40)
- js json.parse (59)
- html复选框 (60)
- css 透明 (44)
- css 颜色 (47)
- php replace (41)
- css nth-child (48)
- min-height (40)
- xml schema (44)
- css 最后一个元素 (46)
- location.origin (44)
- table border (49)
- html tr (40)
- video controls (49)