pytest中的断言

python 复制代码
assert '{"deviceId":..."value":Null}' == '{"deviceId":...,"value":"0"}'
  
  Skipping 39 identical leading characters in diff, use -v to show
  - ","value":"0"}
  ?           ^^^
  + ","value":Null}

上面是pytest运行过程中,自动打印出的断言失败的日志。对应在测试场景中是在等待25秒后,从沙盒日志中获取设备的休眠状态,期望是:

复制代码
{"deviceId":"xxxxxxxxxx","dp":"149","value":"0"}

可能的状态有:

{"deviceId":"xxxxxxxxxx","dp":"149","value":"0"}、{"deviceId":"xxxxxxxxxx","dp":"149","value":"failed"}、{"deviceId":"xxxxxxxxxx","dp":"149","value":Null}

上面的日志是命中了第3种状态。基于测试场景,来分析一下断言失败的日志,首先这段断言日志是pytest的格式,虽然在pytest中断言跟python中的断言的写法一致,都是assert,但是在断言失败的错误信息上有很大的差异,pytest 断言错误信息比较详细,python中的断言错误信息只有assertionError.

上面断言错误中,

第一行:说明了assert断言失败的原因是两个JSON字符串的value字段值不一致,

第二行:前39个字符是一致的,

第三行:"-" 表示期望的值,是:","value":"0"}

第五行:"+" 表示实际的值,是:"value":Null}

第四行:"?"标志行,显示了不同之处。上方的"^^^"符号和下方的"Null"位置,表明期望值是"0",而实际值是Null。

后来又了解了一下pytest断言,整理如下:

1、pytest 中的断言和 Python 自带的 assert 语句非常相似,但 pytest 增加了一些功能,使得断言在测试中更易读和调试。

2、pytest断言会自动输出断言失败的详细信息

在纯 Python 中,assert 只在条件为 False 时抛出一个 AssertionError,并不提供条件的具体信息。而 pytest 在断言失败时,会自动捕获断言表达式中的变量值和详细的比较信息,让报错信息更直观。

3、pytest不需要使用 assert 后的消息参数

Python 原生 assert 支持可选的消息参数,用于在失败时输出自定义消息,例如 assert condition, "message".pytest 通常不需要,因为它会自动生成详细的错误消息,便于调试。

4、pytest 断言可以和插件(例如 pytest-mock, pytest.raises 等)很好地集成,支持更强大的测试功能。

5、pytest 的生态系统中有很多插件和扩展,支持更复杂的断言(如对异常、文件内容、浮点数等的检查)。

相关推荐
CHANG_THE_WORLD1 小时前
python 批量终止进程exe
开发语言·python
liann1191 小时前
3.2_红队攻击框架--MITRE ATT&CK‌
python·网络协议·安全·网络安全·系统安全·信息与通信
云天AI实战派1 小时前
AI 智能体问题排查指南:ChatGPT、API 调用到 Agent 上线失灵的全流程修复手册
大数据·人工智能·python·chatgpt·aigc
我的xiaodoujiao2 小时前
API 接口自动化测试详细图文教程学习系列15--项目实战演练2
python·学习·测试工具·pytest
多思考少编码3 小时前
PAT甲级真题1001 - 1005题详细题解(C++)(个人题解)
c++·python·最短路·pat·算法竞赛
ZhengEnCi3 小时前
M5-markconv自定义CSS样式指南 📝
前端·css·python
ZhengEnCi3 小时前
M4-更新日志v0.1.3-Mermaid图表支持 📝
python
hsjcjh4 小时前
多模态长文本协同:用Gemini 3.1 Pro镜像官网破解复杂办公场景的效率困局(国内实测方案)
python
凯瑟琳.奥古斯特4 小时前
SQLAlchemy核心功能解析
开发语言·python·flask
卷Java4 小时前
GPTQ vs AWQ vs GGUF:模型量化工具横向测评
开发语言·windows·python