Pytest 测试用例断言

Pytest 测试用例断言

在 pytest 中,断言(assert)是用来验证测试结果是否符合预期的基本手段。其本质其实就是if表达式,通过参数对比来判断结果。

断言语句用的是 Python 内置的 assert 语句,用于验证期望的结果与实际的结果是否相符,它是测试框架中检查测试正确性的基础。

assert 可以检查某个条件是否为 True,如果条件为 False,则会抛出 AssertionError 异常,并且测试失败。


断言的优点

  • 用例名称: Pytest 使用断言可以使测试代码更简洁,省去了验证代码大大提升了代码可读性,并且提供了友好的错误消息和异常处理,可以更好地进行测试和调试。

断言的用法

  • assert <表达式>:

    py 复制代码
       assert <bool expression>
  • assert <表达式>, <描述>:

    py 复制代码
       assert <bool expression>, <message>
  • 代码示例

    py 复制代码
    # 断言实际结果是否等于预期结果。
    def test_equal():
        assert 1 + 1 == 2
        
    # 断言实际结果是否不等于预期结果。
    def test_not_equal():
        assert 2 + 2 != 5
        
    # 断言实际结果是否大于或者小于某个值。
    def test_greater_than():
       # 检查 3 是否大于 2
        assert 3 > 2
    
    def test_less_than():
       # 检查 2 是否小于 3
       assert 2 < 3
    
    # 断言实际结果中是否包含某个值。
    def test_in():
       fruits = ['apple', 'banana', 'cherry']
       # 检查 'apple' 是否在列表 fruits 中
       assert 'apple' in fruits
    
    # 断言实际结果是否为空,或不为空。
    def test_is_none():
       value = None
       # 检查值是否为 None
       assert value is None
    
    def test_is_not_empty():
       value = "hello"
       # 检查字符串是否非空
       assert value
    
    # 可以为 assert 语句指定自定义错误消息,在断言失败时展示。
    def test_addition():
       result = 1 + 1
       # 自定义错误消息
       assert result == 3, f"预期结果是 3, 不是 {result}"

断言的结果

标准的 assert 语句会自动解释失败的断言并显示详细的信息。
pytest 会展示出失败的断言表达式和实际结果,这使得调试非常方便。


相关推荐
程序员小远13 天前
自动化测试基础知识总结
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
程序员三藏14 天前
Web自动化测试详解
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
糖果店的幽灵14 天前
软件测试接口测试从入门到精通:Python接口自动化 - pytest测试框架
软件测试·python·功能测试·自动化·pytest·接口测试
oscar99915 天前
AI 测试用例生成:在 Katalon True Platform 中从需求直达执行
人工智能·测试用例·katalon
2601_9618752415 天前
花生十三资料1200题|题库|刷题
conda·pytest·pillow·pip·web3.py·ipython·gunicorn
某人辛木15 天前
Web自动化测试
前端·python·pycharm·pytest
淡漠的蓝精灵17 天前
pytest-xdist:把 pytest 测试分发到多核 CPU 执行
其他·pytest
weixin_3077791318 天前
从脚本执行到智能体协作:AI辅助测试能力的范式重构
运维·开发语言·人工智能·算法·测试用例
jjjava2.019 天前
软件测试与开发全流程解析
java·功能测试·测试用例