0

0

Python mock 过度使用的问题分析

冰川箭仙

冰川箭仙

发布时间:2026-02-16 13:59:52

|

218人浏览过

|

来源于php中文网

原创

应避免过度使用 mock,只对网络、数据库、时间等不可控边界进行 mock;mock 位置须为被测代码导入路径而非定义路径;协程函数必须用 asyncmock;mock 返回值需动态构造以覆盖分支逻辑。

python mock 过度使用的问题分析

mock 用太多,测试变脆弱了

过度使用 mock 会让测试严重依赖实现细节,而不是行为契约。一旦函数内部调用链微调(比如改了个辅助函数名、拆了个逻辑块),一堆测试就红——但业务逻辑其实没坏。

常见错误现象:AttributeError: Mock object has no attribute 'xxx'AssertionError: Expected call not made,不是因为功能出错,而是因为 mock 的路径或调用次数和实际执行路径对不上。

  • 只在「无法控制的边界」mock:比如网络请求(requests.get)、数据库驱动(sqlite3.connect)、时间(datetime.now
  • 别 mock 同一模块里的其他函数——它们是你的协作单元,应该一起跑;否则等于把单元测试写成了“伪集成”
  • 如果发现要 mock 5 个以上对象才能让一个测试通过,大概率是函数职责太重,该拆了

patch 的作用域搞错,mock 失效

mock 生效位置必须是「被测试代码导入并使用的路径」,不是定义路径。很多人在函数定义处 patch,结果白忙活。

比如你写了 from utils import format_date,然后在 main.py 里调用了它,那 patch 必须写成 @patch('main.format_date'),而不是 @patch('utils.format_date')

立即学习Python免费学习笔记(深入)”;

佳可商务购物程序 2004
佳可商务购物程序 2004

在原版的基础上做了一下修正评论没有提交正文的问题特价商品的调用连接问题去掉了一个后门补了SQL注入补了一个过滤漏洞浮动价不能删除的问题不能够搜索问题收藏时放入购物车时出错点放入购物车弹出2个窗口修正主题添加问题商家注册页导航连接问题销售排行不能显示更多问题热点商品不能显示更多问题增加了服务器探测 增加了空间使用查看 增加了在线文件编辑增加了后台管理里两处全选功能更新说明:后台的部分功能已经改过前台

下载
  • 查失效原因,先 print 出被测函数体内的 format_date 对象 ID:print(id(format_date)),再 print mock 对象 ID,看是不是同一个
  • autospec=True 能提前暴露签名不匹配问题,比如 mock 了带参数的函数却没设 return_value
  • 避免在类方法里用 patch.object(self, 'xxx')——self 是实例,patch.object 会 patch 实例属性,不是类方法

mock 返回值写死,掩盖真实逻辑分支

return_value=42 硬编码返回值,容易让测试漏掉条件判断路径。更糟的是,当真实函数返回 None 或空列表时,mock 却返回非空,导致 if 分支永远不进。

典型场景:mock db.query() 总返回 [{'id': 1}],结果 if not results: 分支压根没被覆盖。

  • 按测试目标动态构造返回值:用 side_effect 返回不同值,或抛异常模拟失败路径
  • 对返回结构复杂的对象(如 ORM 模型),优先用真实轻量对象(如 namedtupletypes.SimpleNamespace),别全用 Mock()
  • 检查覆盖率报告里的 branch coverage,特别盯住 if/elsetry/except 是否都被触发过

async 函数里用普通 mock,await 直接卡住

对协程函数(async def)打普通 Mock() 补丁,调用时不会自动 await,而是返回一个 Mock 对象——接着你就看到 RuntimeWarning: coroutine 'Mock' was never awaited,或者测试挂起不动。

根本原因是:普通 mock 不是协程,不能被 await

  • 必须用 AsyncMock() 替代 Mock(),它实现了 __await__,能被正常 await
  • 如果用 patch,记得传 new_callable=AsyncMock,例如:@patch('api.fetch_data', new_callable=AsyncMock)
  • side_effect 里若要抛异常,得抛在 await 之后,所以推荐用 return_value=coroutineside_effect=[some_coro, ...],别直接 return 异常

最常被忽略的一点:mock 不是万能胶,它解决不了设计问题。当你需要 mock 一堆内部函数才能测通一个方法时,那个方法本身已经越界了——它既做决策,又管 IO,还操心格式化。这时候删掉 mock,先重构函数,比补十个 patch 更省时间。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

192

2023.09.27

python print用法与作用
python print用法与作用

本专题整合了python print的用法、作用、函数功能相关内容,阅读专题下面的文章了解更多详细教程。

12

2026.02.03

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

814

2023.08.22

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

418

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

591

2023.08.10

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

372

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2093

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

355

2023.08.31

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

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

145

2026.02.13

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 4.3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.6万人学习

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

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