Github 10.1K star,突破 Web 自动化瓶颈,小白亦能成测试大神!
ccwgpt 2025-06-10 13:40 31 浏览 0 评论
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
相关推荐
- 自己动手写Android数据库框架_android开发数据库搭建
-
http://blog.csdn.net/feiduclear_up/article/details/50557590推荐理由关于Android数据库操作,由于每次都要自己写数据库操作,每次还得去...
- 谷歌开源大模型评测工具LMEval,打通谷歌、OpenAI、Anthropic
-
智东西编译|金碧辉编辑|程茜智东西5月28日消息,据科技媒体TheDecoder5月26日报道,当天,谷歌正式发布开源大模型评测框架LMEval,支持对GPT-4o、Claude3.7...
- 工信部:着力推动大模型算法、框架等基础性原创性的技术突破
-
工信部新闻发言人今日在发布会上表示,下一步,我们将坚持突出重点领域,大力推动制造业数字化转型,推动人工智能创新应用。主要从以下四个方面着力。一是夯实人工智能技术底座。通过科技创新重大项目,着力推动大模...
- 乒乓反复纠结“框架不稳定”的三个小误区
-
很多球友由于对框架的认知不清晰,往往会把“框架不稳定”当成一种心理负担,从而影响学球进度,其典型状态就是训练中有模有样,一旦进入实战,就像被捆住了手脚。通过训练和学习,结合“基本功打卡群”球友们交流发...
- 前AMD、英特尔显卡架构师Raja再战GPU,号称要全面重构堆栈
-
IT之家8月5日消息,知名GPU架构师拉贾科杜里(RajaKoduri)此前曾先后在AMD和英特尔的显卡部门担任要职。而在今日,由Raja创立的GPU软件与IP初创企...
- 三种必须掌握的嵌入式开发程序架构
-
前言在嵌入式软件开发,包括单片机开发中,软件架构对于开发人员是一个必须认真考虑的问题。软件架构对于系统整体的稳定性和可靠性是非常重要的,一个合适的软件架构不仅结构清晰,并且便于开发。我相...
- 怪不得别人3秒就知道软考案例怎么做能50+
-
软考高级统一合格标准必须三科都达到45分,案例分析也一直是考生头疼的一门,但是掌握到得分点,案例能不能50+还不是你们说了算吗?今天就结合架构案例考点,分享实用的备考攻略~一、吃透考点,搭建知识框架从...
- UML统一建模常用图有哪些,各自的作用是什么?一篇文章彻底讲透
-
10万+爆款解析:9大UML图实战案例,小白也能秒懂!为什么需要UML?UML(统一建模语言)是软件开发的“蓝图”,用图形化语言描述系统结构、行为和交互,让复杂需求一目了然。它能:降低沟通成本避...
- 勒索软件转向云原生架构,直指备份基础设施
-
勒索软件组织和其他网络犯罪分子正越来越多地将目标对准基于云的备份系统,对久已确立的灾难恢复方法构成了挑战。谷歌安全研究人员在一份关于云安全威胁演变的报告中警告称,随着攻击者不断改进数据窃取、身份泄露和...
- ConceptDraw DIAGRAM:释放创意,绘就高效办公新未来
-
在当今数字化时代,可视化工具已成为提升工作效率和激发创意的关键。ConceptDrawDIAGRAM,作为一款世界顶级的商业绘图软件,凭借其强大的功能和用户友好的界面,正逐渐成为众多专业人士的首选绘...
- APP 制作界面设计教程:一步到位_app界面设计模板一套
-
想让APP界面设计高效落地,无需繁琐流程,掌握“框架搭建—细节填充—体验优化”三步法,即可一步到位完成专业级设计。黄金框架搭建是基础。采用“三三制布局”:将屏幕横向三等分,纵向保留三...
- MCP 的工作原理:关键组件_mcp部件
-
以下是MCP架构的关键组件:MCP主机:像ClaudeDesktop、GitHubCopilot或旅行助手这样的AI智能体,它们希望通过MCP协议访问工具、资源等。MCP主机会...
- 软件架构_软件架构师工资一般多少
-
软件架构师自身需要是程序员,并且必须一直坚持做一线程序员。软件架构应该是能力最强的一群程序员,他们通常会在自身承接编程任务的同时,逐渐引导整个团队向一个能够最大化生产力的系统设计方向前进。软件系统的架...
- 不知不觉将手机字体调大!老花眼是因为“老了吗”?
-
现在不管是联系、交友,还是购物,都离不开手机。中老年人使用手机的时间也在逐渐加长,刷抖音、看短视频、发朋友圈……看手机的同时,人们也不得不面对“视力危机”——老花眼,习惯眯眼看、凑近看、瞪眼看,不少人...
- 8000通用汉字学习系列讲座(第046讲)
-
[表声母字]加(续)[从声汉字]伽茄泇迦枷痂袈笳嘉驾架咖贺瘸(计14字)嘉[正音]标准音读jiā。[辨形]上下结构,十四画。会意形声字,从壴从加,加也表声。注:从壴,字义与鼓乐有关;从加,字义与...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- 框架图 (58)
- flask框架 (53)
- quartz框架 (51)
- abp框架 (47)
- springmvc框架 (49)
- 分布式事务框架 (65)
- scrapy框架 (56)
- shiro框架 (61)
- 定时任务框架 (56)
- java日志框架 (61)
- mfc框架 (52)
- abb框架断路器 (48)
- beego框架 (52)
- java框架spring (58)
- grpc框架 (65)
- tornado框架 (48)
- 前端框架bootstrap (54)
- orm框架有哪些 (51)
- 知识框架图 (52)
- ppt框架 (55)
- 框架图模板 (59)
- 内联框架 (52)
- cad怎么画框架 (58)
- ssm框架实现登录注册 (49)
- oracle字符串长度 (48)