news 2026/6/9 23:51:03

Playwright新人笔记学习记录(鉴权2)--Day5

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Playwright新人笔记学习记录(鉴权2)--Day5

今天自己手动部署了jenkins和Docker,实现CICD,结果发现一个问题,如果单个运行测试类是没有问题的,但是批量运行就会失败。

报错信息如下所示,提示定位元素超时了。

最后我发现是批量运行时,保存的cookie失效了,导致只成功运行了第一个测试函数,后续的测试函数全部失败了,于是我添加了一个判断cookie是否生效的逻辑。

先看看我刚开始的conftest配置文件中的代码。

@pytest.fixture(scope="session") def auth_state(browser) -> Path: """ session 级别:只登录一次,生成 state.json 返回状态文件路径 """ if not STORAGE_STATE_PATH.exists(): STORAGE_STATE_PATH.parent.mkdir(parents=True, exist_ok=True) context = browser.new_context(**DEVICE_CONFIG) page = context.new_page() try: page.goto("http://xxxx.com/") page.locator('input[type="tel"]').fill('xxxxx') page.get_by_role("checkbox").click() page.get_by_text("下一步").click() captcha_input = page.locator('input[placeholder="请输入"][maxlength="6"]') captcha_input.wait_for(state="visible", timeout=10000) captcha_input.fill('123456') page.wait_for_url("http://xxxxx/#/workbench") context.storage_state(path=STORAGE_STATE_PATH) finally: context.close() return STORAGE_STATE_PATH

第一次我判断了保存cookie的文件是否存在,但是没有判断是否生效,导致运行失败,下面我贴上我增加了判断逻辑失效的代码。

def is_auth_valid(state_path: Path) -> bool: if not state_path.exists(): return False try: context = browser.new_context(storage_state=state_path, **DEVICE_CONFIG) page = context.new_page() page.goto("http://xxxxxx.com/#/workbench", wait_until="domcontentloaded")# 关键判断:如果登录失效,通常会自动跳转到 /login 或首页登录框 # 所以我们检查 URL 是否仍然是 workbench,且没有出现登录输入框 current_url = page.url has_login_input = page.locator('input[type="tel"]').count() > 0 context.close() # 如果还在 workbench 且没出现登录输入框,就认为有效 return "/workbench" in current_url and not has_login_inputexcept Exception: return False

关键判断逻辑是红色的这块代码,获取当前的current_url,并判断当前获取的url中是否包含"/workbench"以及当前页面是否还存在登录输入框,因为/workbench是我登录后首页的url路径。

如果失效了,那么整个函数就会返回False,这样程序就会重新走一遍登录流程并重新保存一次登录cookie。

下面是全部代码。

@pytest.fixture(scope="session") def auth_state(browser) -> Path: """ session 级别:只登录一次,生成 state.json 返回状态文件路径 """ def is_auth_valid(state_path: Path) -> bool: if not state_path.exists(): return False try: context = browser.new_context(storage_state=state_path, **DEVICE_CONFIG) page = context.new_page() page.goto("http://xxxx.com/#/workbench", wait_until="domcontentloaded") # 关键判断:如果登录失效,通常会自动跳转到 /login 或首页登录框 # 所以我们检查 URL 是否仍然是 workbench,且没有出现手机号输入框 current_url = page.url has_login_input = page.locator('input[type="tel"]').count() > 0 context.close() # 如果还在 workbench 且没出现登录输入框,就认为有效 return "/workbench" in current_url and not has_login_input except Exception: return False # 如果状态文件不存在,或已失效,则重新登录 if not is_auth_valid(STORAGE_STATE_PATH): STORAGE_STATE_PATH.unlink(missing_ok=True) STORAGE_STATE_PATH.parent.mkdir(parents=True, exist_ok=True) context = browser.new_context(**DEVICE_CONFIG) page = context.new_page() try: page.goto("http://xxxxx.com/") page.locator('input[type="tel"]').fill('xxxxx') page.get_by_role("checkbox").click() page.get_by_text("下一步").click() captcha_input = page.locator('input[placeholder="请输入"][maxlength="6"]') captcha_input.wait_for(state="visible", timeout=10000) captcha_input.fill('123456') page.wait_for_url("http://xxxxx.com/#/workbench", timeout=15000) context.storage_state(path=STORAGE_STATE_PATH) finally: context.close() return STORAGE_STATE_PATH

注:单个运行测试类或者测试函数的命令为:pytest test_login.py::TestDemo::test_login

批量运行测试类或者测试函数的命令为:python -m pytest tests/ --html=report.html --self-contained-html -v

test_login.py:测试文件名

TestDemo:测试类名

test_login:测试函数名

tests/:目录名

--html=report.html:输出为一个 HTML 文件,文件名为report.html

--self-contained-html:将 CSS、JavaScript、图片等资源内嵌到 HTML 文件中

-v:表示详细模式:在控制台中显示每个测试用例的完整名称

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/6 6:46:53

LobeChat能否撰写商业计划书?创业者的秘密武器

LobeChat能否撰写商业计划书?创业者的秘密武器 在今天这个快节奏的创业环境中,一份逻辑清晰、数据扎实、结构完整的商业计划书,往往是决定项目能否获得投资的关键。然而现实是,大多数创业者既不是专业写手,也没有专职的…

作者头像 李华
网站建设 2026/6/9 18:54:55

中小企业备份方案: 如何评估备份方案是否符合企业实际需求

成本、安全性与法规合规性这三方面考量,构成了评估备份解决方案是否符合企业实际需求的基础框架。业务需求评估评估备份解决方案时,必须首先审视公司的具体需求。企业通常有着多样化的数据保护要求,例如保护 Microsoft 365 等关键应用&#x…

作者头像 李华
网站建设 2026/6/7 18:34:58

小白狂喜!护网行动日入 2K+,零基础也能冲

一、网络安全基础认知 1.1 网络安全定义与法律体系 什么是网络安全? 保护网络系统免受破坏/入侵/数据泄露,确保服务持续可用。例如: 医院系统防勒索病毒攻击电商平台防用户数据窃取 五大核心法律规范 法律名称核心要求违反后果《网络安…

作者头像 李华
网站建设 2026/6/6 3:04:44

ComfyUI_ACE-Step:高效音乐生成与编辑新工具

ComfyUI_ACE-Step:让音乐创作从灵感到交响仅需一步 你有没有过这样的经历?脑海中浮现出一段旋律,情绪饱满、画面感十足,却苦于无法记谱或编曲,最终只能眼睁睁看着它消散在风里。又或者,作为视频创作者&…

作者头像 李华
网站建设 2026/6/9 7:04:19

巴菲特的现金管理策略:在低利率环境中的调整

巴菲特的现金管理策略:在低利率环境中的调整 关键词:巴菲特、现金管理策略、低利率环境、投资调整、价值投资 摘要:本文聚焦于巴菲特的现金管理策略在低利率环境下的调整。首先介绍了相关背景,包括目的范围、预期读者等内容。接着阐述核心概念及联系,通过示意图和流程图呈…

作者头像 李华
网站建设 2026/6/7 15:17:03

EmotiVoice社区版与商业版功能对比选型指南

EmotiVoice社区版与商业版功能对比选型指南 在AIGC技术席卷各行各业的当下,语音合成已不再是简单的“文字转语音”,而是迈向有情感、有个性、可定制的智能交互核心环节。EmotiVoice 正是在这一趋势下脱颖而出的一款开源TTS引擎——它不仅支持零样本音色…

作者头像 李华