Pytest框架 — 04、Pytest的断言

yizhihongxing

1、前言

Pytest使用python自带关键字assert进行断言,断言内容为一个表达式,只要表达式的最终结果为True,那么断言通过,用例执行成功,否则用例执行失败。
assert + 表达式

2、常用断言

  • assert xx:判断xx为真
  • assert not xx: 判断xx不为真
  • assert a in b:判断b包含a
  • assert a == b: 判断a等于b
  • assert a != b: 判断a不等于b

3、预期异常断言

除了支持对代码正常运行的结果断言之外,Pytest也能够对 Exception 和 Warnning 进行断言。有时候断言会引发我们意料之中的异常,借助pytest.raises可以捕获匹配到的异常,避免该条用例执行Failed。

  • 示例1:如果抛出ZeroDivisionError测试结果是Pass,否则为Failed
def test_zero():
    # 捕获预期异常
    with pytest.raises(ZeroDivisionError) as ec:
        res = 1 / 0
    # 断言异常信息, 官方提示, raise 的异常应该是当前代码块最后一行,如果在其后面还有代码,那么将不会被执行。
    assert "zero" in str(ec.value)
  • 示例2:将异常信息存储到一个变量中,从而可以进一步断言
def test_zero():
    # 捕获预期异常
    with pytest.raises(ValueError) as ec:
        raise ValueError("Zero Error")
	# 官方提示, raise 的异常应该是当前代码块最后一行,如果在其后面还有代码,那么将不会被执行。
    print("错误说明", ec.value)
    print("错误回溯", ec.traceback)
    print("错误类型",ec.type)
    assert str(ec.value) == "Zero Error"

"""
执行结果
collected 1 item                                                                                                                              

test_temp.py::test_zero 错误说明 Zero Error
错误回溯 [<TracebackEntry /Users/qishuai/Desktop/笔记/web自动化测试/pytest/demo/test_temp.py:30>]
错误类型 <class 'ValueError'>
PASSED

"""
  • 示例3:预期异常还可以传递一个元祖
def test_Error_tuple():
   with pytest.raises((ValueError, ZeroDivisionError)):
       # res = 1/0
       raise ValueError
  • 示例4:通过match关键字进行正则表达式更精确断言异常
def match_error():
    raise ValueError("This is Test Error")

def match_error_2():
    raise ValueError

def test_match():
    with pytest.raises(ValueError,match=r".* Test Error") as ec:
        match_error_2()
    assert ec.type == ValueError
    assert str(ec.value) == "This is Test Error"

上面示例4代码中由于添加了match关键字,所以match_error引发的异常能被pytest.raise捕获到,match_error_2引发的异常不能被pytest.raise捕获到。

更多异常断言:https://docs.pytest.org/en/latest/how-to/assert.html#assertions-about-expected-exceptions

4、优化断言提示

在断言时加入注释字符串,在报错时注释能够被打印出来

def test_assert_fail():
    assert 1 > 2, "断言1是否大于2"

"""
执行结果
============================ test session starts ==============================
collecting ... collected 1 item

test_1.py::test_assert_fail FAILED                                       [100%]
test_1.py:41 (test_assert_fail)
def test_assert_fail():
>       assert 1 > 2, "断言1是否大于2"
E       AssertionError: 断言1是否大于2
E       assert 1 > 2

test_1.py:43: AssertionError


============================== 1 failed in 0.06s ===============================
"""

5、自定义失败断言提示

通过在conftest.py中添加pytest_assertrepr_compare钩子来添加您自己的详细解释,如下:

# content of conftest.py
def pytest_assertrepr_compare(op, left, right):
    """
    :param op: 操作符
    :param left: 操作符左边内容
    :param right: 操作符右边内容
    :return: 
    """
    if op == ">":
        return ["比较大小",f"{left}不大于{right}"]
# content of test_compare.py
def test_compare():
    a = 1
    b = 2
    assert a > b
"""
执行结果:
collected 1 item                                                                                                                              

temp/test_compare_foo.py::test_compare FAILED

================================================================== FAILURES ===================================================================
________________________________________________________________ test_compare _________________________________________________________________

    def test_compare():
        a = 1
        b = 2
>       assert a > b
E       assert 比较大小
E         1不大于2

temp/test_compare_foo.py:19: AssertionError
=========================================================== short test summary info ===========================================================
FAILED temp/test_compare_foo.py::test_compare - assert 比较大小
============================================================== 1 failed in 0.08s ==============================================================
"""

参考:
https://cloud.tencent.com/developer/article/1693769
http://www.360doc.com/content/22/0211/10/78594709_1016826734.shtml
https://docs.pytest.org/en/latest/how-to/assert.html#assertions-about-expected-exceptions

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Pytest框架 — 04、Pytest的断言 - Python技术站

(0)
上一篇 2023年4月2日
下一篇 2023年4月2日

相关文章

  • Pytest框架 — 08、Pytest的Fixture(部分前后置)(三)

    目录 8、Fixture带返回值 9、Fixture实现参数化 10、可靠的Fixture写法 (一)一个不可靠Fixture的例子 (二)修改成可靠Fixture的例子 8、Fixture带返回值 在fixture中我们可以使用yield或者return来返回我们需要的东西,如测试数据,数据库连接对象,文件对象等。 没有后置处理 直接采用return的方式…

    Python开发 2023年4月2日
    00
  • Allure定制报告

    目录 1、定制报告常用的装饰器 2、allure.dynamic在测试方法中动态添加定制 3、用例等级的定制 4、用例描述的定制 5、链接的定制 6、步骤的定制 7、附件的定制 1、定制报告常用的装饰器 结合表和示例图查看 使用方法 参数值 参数说明 @allure.epic() 项目名称 项目名称,树结构第一层 @allure.feature() 模块名称…

    2023年4月2日
    00
  • Pytest框架 — 16、Pytest的测试报告(pytest-html插件和Allure框架)

    目录 1、前言 2、pytest-html生成测试报告 (1)pytest-html插件安装 (2)pytest-html的使用 (3)报告独立显示 3、Allure框架生成测试报告 (1)说明 (2)环境准备 (3)执行测试并生成测试报告 1、前言 在pytest中常用的测试报告生成方法有两种,一种是通过pytest-html插件来完成,另一种通过Allu…

    2023年4月2日
    00
  • Pytest框架 — 09、Pytest的conftest.py文件

    目录 1、conftest.py介绍 2、conftest.py的特点 3、conftest.py文件的使用 4、conftest.py的作用域 1、conftest.py介绍 conftest.py是pytest框架的一种固定写法,把fixture或者自己定义的插件写到这个文件里就会自动去调用。我们前面都是将fixture写到测试用例文件里,在实际工作中更…

    Python开发 2023年4月2日
    00
  • Pytest框架 — 12、Pytest的标记(三)(重复执行)

    目录 1、前言 2、–count参数使用 (一)在命令行或者main函数使用 (二)在全局配置文件中使用 3、–repeat-scope参数使用 4、@pytest.mark.repeat(count)装饰器使用 5、结合参数x使重复执行在失败时停止 1、前言 在自动化测试的时候我们可能会遇到某些原因,如模块不稳定等,出现一些测试失败,此时我们想要针对单…

    Python开发 2023年4月2日
    00
  • Pytest框架 — 10、Pytest的标记(一)(跳过和预期失败)

    目录 1、前言 2、标记跳过 (一)无条件跳过skip (二)有条件跳过skipif (三)使用pytest.skip(reason)函数标记跳过 (四)跳过整个模块 3、标记预期失败 (一)参数详解 (二)使用pytest.xfail(reason)函数标记预期失败 (三)示例 (四)忽略xfail标识 (五)xfail总结 1、前言 引用自官方文档您可以…

    Python开发 2023年4月2日
    00
  • Pytest框架 — 05、setup和teardown(全部前后置)

    目录 1、前言 2、各级别详解 3、总结 1、前言 在自动化测试过程中经常需要进行初始化和后期处理等工作,如电商加购物车测试需要先登录,测试完毕需要关闭浏览器等。Pytest提供了5种类型的setup和teardown的方法,具体如下: 模块级别:setup_module,teardown_module 函数级别:setup_function,teardow…

    Python开发 2023年4月2日
    00
  • Pytest框架 — 14、Pytest的标记(五)(控制测试用例执行顺序)

    目录 1、前言 2、使用 3、标记最先执行和最后执行 1、前言 在执行自动化测试时,我们通常都希望能够控制执行测试用例的顺序。 在unittest框架中默认按照ACSII码的顺序加载测试用例并执行,顺序为:0~9、A~Z、a~z,测试目录、测试模块、测试类、测试方法/测试函数都按照这个规则来加载测试用例。 在pytest测试框架中,默认从上至下执行,也可以通…

    Python开发 2023年4月2日
    00
合作推广
合作推广
分享本页
返回顶部