当前位置: 首页 > news >正文

自动化测试框架搭建-单次接口执行-三部曲

目的

判断接口返回值和提前设置的预期是否一致,从而判断本次测试是否通过

代码步骤设计

第一步:前端调用后端已经写好的POST接口,并传递参数

第二步:后端接收到参数,组装并请求指定接口,保存返回

第三步:预期结果对比接口返回,一致返回测试通过,不一致返回接口本次测试的真实数据

代码实现思路

第一步

1、接口的请求的方式是post
2、前端以post形式提交参数信息
3、接口将单个参数信息读取放到后端代码的变量中

第二步

1、根据解析的后端变量填入接口调用的参数中
2、访问指定接口,保存接口返回的json数据

第三步

1、读取忽略字段,如果没有,对接口返回的json数据(json转化为字典数据类型)做全量校验
2、读取忽略字段,如果有,对接口返回的json数据(json转化为字典数据类型)做校验,遇见匹配的忽略字段跳过
3、返回对比结果

4、对比一致,返回接口测试通过

返回差异数据(为空)

5、对比不一致,接口测试不通过

返回差异数据(不为空)

代码实现

步骤一
1、接收post请求的参数
from flask import request
from flask_restful import Resourcefrom app.api.common.utils import res
from app.commen.resopDiff import resp_diff
from app.interfaces.interfaces import interfacesclass TestCase(Resource):def post(self):data = request.get_json()if not data:# 返回明确的错误信息,避免引用未定义的 result# 400 Bad Requestreturn res(message="请求数据为空", success=False, code=400)try:# 打印接收到的数据(调试用)# print("Received data:", data)# 提取必要字段(建议增加字段存在性校验)method = data.get('method')url = data.get('url')params = data.get('params', {})  # 默认空字典headers = data.get('headers', {})  # 默认空字典expected = data.get('expected')  # 注意字段名拼写是否正确ignore_keys = data.get('ignore_keys', [])# 调用接口请求resp = interfaces.request(method=method,url=url,headers=headers,params=params)# 确保获取响应文本内容resp_text = resp.text#  调试输出响应内容# print("Response text:", resp_text)# 对比预期结果与实际响应# 假设 resp_diff 返回可序列化的字典(需确保实现正确)result = resp_diff(expected, resp_text, ignore_keys)# 构建返回结果if not result:  # 等价于 result == {}return res(data=result, message="接口对比一致,测试通过!", success=True, code=200)else:return res(data=result, message="接口对比不一致,测试不通过!", success=True, code=200)except KeyError as e:# 处理字段缺失错误return res(message=f"请求数据缺少必要字段: {str(e)}", success=False, code=500)except Exception as e:# 捕获其他异常(如接口请求失败)return res(message=f"服务器内部错误: {str(e)}", success=False, code=500)
步骤二

2、resp_diff(预期结果与实际响应求差异值)

from deepdiff import DeepDiff
import json# 参数要求,需要对比的是json字符串,以及需要忽略的字段def resp_diff(expected, realResp, ignore_keys):"""比较两个 JSON 数据的差异,并忽略指定的键。:param expected: 第一个 JSON 数据(字符串或字典):param realResp: 第二个 JSON 数据(字符串或字典):param ignore_keys: 需要忽略的键的列表(例如 ["extra", "age"]):return: 返回比较结果的描述和差异(如果有)"""# 如果输入是字符串,将其解析为字典if isinstance(expected, str):dict1 = json.loads(expected)else:dict1 = expectedif isinstance(realResp, str):dict2 = json.loads(realResp)else:dict2 = realResp# 构造 exclude_paths 参数exclude_paths = {f"root['{key}']" for key in ignore_keys}# print(f"ignore_keys{ignore_keys}")# # 使用 DeepDiff 进行比对# print(f"dict1{dict1}")# print(f"dict2{dict2}")# print(f"exclude_paths:{exclude_paths}")diff = DeepDiff(dict2, dict1, exclude_paths=exclude_paths)# 返回比较结果,直接返回diff需要对diff做判断return rename_diff_keys(diff)def rename_diff_keys(diff_dict):"""递归遍历 DeepDiff 结果,将 new_value/old_value 替换为自定义名称"""if not isinstance(diff_dict, dict):return diff_dictrenamed = {}for key, value in diff_dict.items():# 直接替换字段名if key == "new_value":renamed["realResp"] = valueelif key == "old_value":renamed["expected"] = value# 递归处理嵌套结构elif isinstance(value, dict):renamed[key] = rename_diff_keys(value)elif isinstance(value, list):renamed[key] = [rename_diff_keys(item) if isinstance(item, dict) else item for item in value]else:renamed[key] = valuereturn renamed

3、在蓝图上注册接口,访问路径

api.add_resource(TestCase, '/interfaces/post1')

4、通过Postman传递参数测试效果

  • 结果与预期一致
    请添加图片描述

  • 结果与预期不一致
    请添加图片描述

http://www.lryc.cn/news/539358.html

相关文章:

  • 【阮一峰】2.数组
  • DeepSeek 接入PyCharm实现AI编程!(支持本地部署DeepSeek及官方DeepSeek接入)
  • 【Java Card】Applet 使用Shareable进行数据分享以及部分问题处理
  • 国产FPGA开发板选择
  • com.typesafe.config
  • Ubuntu学习备忘
  • 【C++】— 掌握STL vector 类:“Vector简介:动态数组的高效应用”
  • Docker__持续更新......
  • 【R语言】主成分分析与因子分析
  • ROS-相机话题-获取图像-颜色目标识别与定位-目标跟随-人脸检测
  • STM32 如何使用DMA和获取ADC
  • 【JAVA实战】JAVA实现Excel模板下载并填充模板下拉选项数据
  • java面试笔记(一)
  • 【C++】36.C++IO流
  • Qt5开发入门指南:从零开始掌握跨平台开发
  • Rook-ceph(1.92最新版)
  • 深度学习在蛋白质-蛋白质相互作用(PPI)领域的研究进展(2022-2025)
  • 网络安全学习架构 网络安全架构内容
  • 硕成C语言24
  • 《Stable Diffusion绘画完全指南:从入门到精通的Prompt设计艺术》-配套代码示例
  • Linux下为Intel核显安装OpenCL
  • 用deepseek学大模型04-机器学习建模过程
  • 【ClickHouse】Ubuntu下离线安装ClickHouse数据库并使用DBeaver连接
  • Unity3D实现接入DeepSeek对话
  • 【ISO 14229-1:2023 UDS诊断(会话控制0x10服务)测试用例CAPL代码全解析②】
  • 前端新手必看:10 大 UI 组件库全面解析,快速搭建高质量 Web 应用」 「从零开始:Vue 和 React 最受欢迎的 UI 组件库入门指南」 「超实用!PC 端和移动端 UI 组件库推荐与实战
  • 【MySQL高级】17 - MySQL中常用工具
  • 【Linux】Linux 文件系统——有关 inode 不足的案例
  • 计算机视觉:卷积神经网络(CNN)基本概念(二)
  • 【第7章:注意力机制与Transformer模型—7.4 NLP领域的BERT、GPT系列模型】