0

0

DeepSeek与自动化测试框架(Selenium/Pytest)的结合

畫卷琴夢

畫卷琴夢

发布时间:2026-02-20 17:14:02

|

206人浏览过

|

来源于php中文网

原创

需通过api调用deepseek模型,将其集成到selenium与pytest协同流程中,实现测试用例生成、异常分析、参数化数据构建、语义校验及报告润色五大功能。

☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜

deepseek与自动化测试框架(selenium/pytest)的结合

如果您希望将DeepSeek大语言模型的能力集成到自动化测试框架中,以增强测试用例生成、日志分析或异常描述理解等环节,则需通过程序化接口调用DeepSeek模型,并将其嵌入Selenium与Pytest协同工作的流程中。以下是实现该集成的多种方法:

一、通过API调用DeepSeek生成测试用例

该方法利用DeepSeek提供的HTTP API,在Pytest测试套件初始化阶段动态生成符合业务场景的测试数据与步骤描述,再由Selenium执行对应操作。关键在于构造结构化提示词并解析返回的JSON格式响应。

1、在pytest配置文件conftest.py中定义fixture,使用requests库发送POST请求至DeepSeek API端点。

2、在请求头中设置Authorization: Bearer YOUR_DEEPSEEK_API_KEY,并指定Content-Type为application/json。

3、构造payload字典,包含model字段值为deepseek-coder或deepseek-chat,messages字段为包含系统角色与用户指令的列表。

4、从API响应中提取content字段,使用json.loads()解析为Python字典,筛选出steps键对应的浏览器操作序列。

5、将解析后的步骤映射为Selenium WebDriver可执行的动作,例如find_element_by_xpath、click、send_keys等。

二、使用DeepSeek解析Selenium异常堆栈并生成修复建议

该方法在Selenium执行失败时捕获WebDriverException或TimeoutException,将完整错误信息与当前页面HTML源码片段作为上下文提交给DeepSeek,获取自然语言形式的根因分析与代码修正提示。

1、在pytest的exception hook中添加try-except块,捕获Selenium抛出的异常对象。

2、调用driver.page_source获取当前DOM快照,截取前5000字符作为context输入。

3、构建提示词模板:“你是一名资深Web自动化测试工程师。以下是在Chrome上运行Selenium时发生的错误:{exception_str};页面源码片段:{page_source_snippet}。请指出最可能的原因,并给出一行可直接替换的Python代码修复建议。”

4、向DeepSeek API发起异步请求,等待响应返回。

5、从响应中提取“修复建议:”后紧跟的代码行,写入临时文件或打印至pytest控制台输出。

三、基于DeepSeek构建Pytest参数化测试数据集

该方法绕过人工编写@pytest.mark.parametrize装饰器中的参数组合,改由DeepSeek根据接口文档或UI字段约束自动生成高覆盖度的输入值集合,提升边界值与非法输入测试能力。

1、准备一份简要的字段说明文本,例如“用户名字段:长度3-16位,支持字母数字下划线,不能为空”。

2、将多个字段说明拼接为单个字符串,作为用户消息提交至DeepSeek API。

MedPeer
MedPeer

AI驱动的一站式科研服务平台

下载

3、在prompt中明确要求模型以CSV格式返回10组测试数据,每行包含username,password,email三个字段,无表头,用英文逗号分隔。

4、接收响应后,用string.splitlines()分割为行列表,逐行调用csv.reader解析为元组。

5、将解析结果传入@pytest.mark.parametrize,确保每组数据均触发独立的测试用例实例

四、在Selenium Page Object模型中嵌入DeepSeek语义校验逻辑

该方法扩展Page类的方法,在执行click或submit后不立即断言元素状态,而是调用DeepSeek比对预期行为描述与实际页面文本内容,实现非结构化断言。

1、在base_page.py中新增verify_behavior_via_deepseek方法,接收预期描述字符串作为参数。

2、调用driver.find_element(By.TAG_NAME, "body").text获取全部可见文本,截断至8000字符以内。

3、构造提示:“请判断以下页面文本是否满足用户需求:{expected_desc}。页面文本:{full_text}。仅回答‘是’或‘否’,不要附加任何解释。”

4、发送请求并检查响应首字符是否为“是”,否则抛出AssertionError。

5、在具体页面类的方法中调用该验证函数,例如login_success_page.verify_behavior_via_deepseek("用户应看到欢迎消息及个人头像")。

五、利用DeepSeek重写Pytest测试报告中的失败摘要

该方法在pytest运行结束后,读取junitxml或custom report生成的日志,抽取失败用例的原始错误摘要,交由DeepSeek润色为更易懂的技术说明,供非开发人员快速理解问题本质。

1、在pytest_sessionfinish钩子中加载test_results.xml文件,遍历节点查找failure子节点。

2、提取标签内的message属性和中的stdout内容,合并为输入文本。

3、构造prompt:“你是一名测试报告编辑专家。请将以下技术性失败描述转换为面向产品经理的简洁中文说明(不超过60字),聚焦影响而非技术细节:{raw_failure_text}”

4、批量调用DeepSeek API处理所有失败项,限制并发请求数为3以避免限流。

5、将返回结果注入原XML的节点中,替换原有message属性值为“登录按钮点击后未跳转至首页,用户停留在登录页”此类表述。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

797

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

272

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

144

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

25

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

92

2026.02.13

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

53

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

15

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

717

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

64

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号