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

pytest + pytest-mock + pytest-parametrize为基础构建测试框架

一、框架核心组件整合

pytest作为基础测试框架,与pytest-mock(unittest.mock封装)和pytest-parametrize(参数化测试)形成黄金三角。三者协同可实现:

  • 依赖隔离:通过mocker fixture模拟外部API/数据库交互
  • 场景覆盖:利用参数化实现多输入组合测试
  • 代码复用:通过fixture机制实现测试资源共享
二、项目结构设计(推荐方案)
my_project/ ├── src/ # 业务代码 │ ├── api/ # API模块 │ └── utils/ # 工具函数 ├── tests/ # 测试目录 │ ├── unit/ # 单元测试 │ │ ├── test_api.py │ │ └── test_utils.py │ ├── integration/ # 集成测试 │ ├── conftest.py # 全局fixture定义 │ └── pytest.ini # 配置文件 └── requirements.txt # 依赖管理
三、核心功能实现示例

1. 参数化测试(pytest-parametrize)

import pytest # 基础参数化 @pytest.mark.parametrize("a,b,expected", [ (2, 3, 5), # 正常场景 (0, 0, 0), # 边界值 (-1, 1, 0), # 异常输入 ]) def test_add(a, b, expected): assert a + b == expected # 高级用法:结合fixture实现动态参数 @pytest.fixture(params=[ {"input": "valid", "expected": True}, {"input": "invalid", "expected": False} ]) def dynamic_data(request): return request.param def test_validation(dynamic_data): assert validate(dynamic_data["input"]) == dynamic_data["expected"]

2. Mock服务集成(pytest-mock

def test_api_call(mocker): # 模拟requests.get方法 mock_get = mocker.patch("requests.get") mock_get.return_value.json.return_value = {"status": "ok"} # 执行测试 result = fetch_data("https://api.example.com") # 验证调用 mock_get.assert_called_once_with("https://api.example.com") assert result["status"] == "ok"

3. 复杂场景测试(三者结合)

@pytest.mark.parametrize("scenario", [ {"url": "/v1/users", "expected_code": 200}, {"url": "/v2/users", "expected_code": 404}, ]) def test_api_versioning(scenario, mocker): # 模拟API响应 mock_response = mocker.Mock() mock_response.status_code = scenario["expected_code"] mocker.patch("requests.get", return_value=mock_response) # 执行测试 response = call_api(scenario["url"]) # 断言结果 assert response.status_code == scenario["expected_code"]
四、最佳实践建议
  1. fixture管理

    • 使用conftest.py定义跨模块fixture
    • 合理设置作用域(function/module/session)
    • 实现fixture依赖链(如db_conn → api_client)
  2. 测试分类

    • 单元测试:使用mock隔离外部依赖
    • 集成测试:通过--integration标记单独执行
    • 性能测试:添加@pytest.mark.slow标记
  3. 报告与集成

    • 生成HTML报告:pytest --html=report.html
    • CI集成:配置pytest.ini实现零配置执行
    • 覆盖率分析:结合pytest-cov生成覆盖率报告
五、常用命令参考
# 运行所有测试 pytest # 运行指定测试 pytest tests/unit/test_api.py::test_create_user # 仅运行标记测试 pytest -m "smoke and not slow" # 生成详细报告 pytest --cov=src --cov-report=html

这套框架设计遵循了测试金字塔原则,既保证了单元测试的执行效率,又通过集成测试验证了模块间协作。通过参数化和mock的结合使用,可在最少代码量下实现最大测试覆盖率。

http://www.jsqmd.com/news/183518/

相关文章:

  • Sonic生成视频用于商业广告需要授权吗?法律风险提示
  • 量化校准集动态调整实战
  • 使用Typora编写Sonic项目文档?Markdown编辑器推荐搭配
  • 工信部将Sonic纳入新一代人工智能创新项目库
  • Git tag标记VoxCPM-1.5-TTS-WEB-UI重要发布版本
  • Ehercat代码解析中文摘录<3>
  • Sonic数字人英文语音生成效果测试:发音准确度达行业前列
  • 小红书博主分享Sonic生成数字人种草视频
  • 超高品质数字人视频生成工作流使用Sonic全攻略
  • 《创业之路》-796-软件系统的兼容性、适应性、适配性与人际交往中的兼容性、适应性、适配性
  • 福建土楼围屋:客家人大年初一的祭祖祷告
  • 武侠小说江湖语录:金庸笔下人物开口说话了
  • P1861 星之器
  • 《创业之路》-797-企业管理中,追求高效和专业性是执行层中基层管理评判的标准;方向和立场的正确性和利益的价值性是高层管理者评判的标准。中基层与高层本就不在一个频道上。
  • [CCO 2022] Double Attendance
  • 曾贝贝湖南卫视跨年首秀搭档徐佳莹 《身骑白马》融合舒曼金曲惊艳全场
  • 意大利歌剧选段:AI演唱《图兰朵》茉莉花片段
  • Avalanche子网部署Sonic集群面向金融信息服务
  • 2026.1.2
  • 二叉树遍历的递归和非递归版本(所有题型)
  • 基于YOLO的车库汽车检测系统
  • 基于YOLO的车库汽车检测系统
  • 老年人友好设计:大字版界面+VoxCPM-1.5-TTS-WEB-UI语音辅助操作
  • FDA认证AI加速,新药上市快一倍
  • 语音克隆安全性探讨:VoxCPM-1.5-TTS-WEB-UI如何防范滥用风险?
  • allure的安装
  • C#能否调用Sonic模型接口?跨语言调用可行性分析
  • 一般一元五次(及以上)方程无求根公式的直观解释(转)
  • 公安部提醒:警惕犯罪分子利用Sonic进行诈骗
  • Git Commit规范写Sonic项目日志?专业开发者必备