需通过api调用deepseek模型,将其集成到selenium与pytest协同流程中,实现测试用例生成、异常分析、参数化数据构建、语义校验及报告润色五大功能。
☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜

如果您希望将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。
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文件,遍历
2、提取
3、构造prompt:“你是一名测试报告编辑专家。请将以下技术性失败描述转换为面向产品经理的简洁中文说明(不超过60字),聚焦影响而非技术细节:{raw_failure_text}”
4、批量调用DeepSeek API处理所有失败项,限制并发请求数为3以避免限流。
5、将返回结果注入原XML的











