【pytest】3.assert断言

断言就是实际结果和期望结果去对比,符合预期那就测试pass,不符合预期那就测试 failed。断言是写自动化测试基本最重要的一步,一个用例没有断言,就失去了自动化测试的意义了。

1、使用assert语句进行断言

1、pytest允许您使用标准的Python断言来验证Python测试中的期望和值。例如:

# content of test_assert1.py
def f():
    return 3
def test_function():
    assert f() == 4

运行会看到断言失败,因为返回的值是3,判断等于4,所以失败了。

2、指定断言失败的返回消息:

assert a % 2 == 0, "判断a为偶数,当前a的值为:%s"%a

这样将不会输出内省信息(断言失败对比信息),而是在traceback中输出指定的断言失败返回信息

2、异常断言

使用pytest.raises作为上下文管理器,来对【抛出的异常】作断言:

# content of test_assert1.py
import pytest
def test_zero_division():
    with pytest.raises(ZeroDivisionError):
        1 / 0

如果要断言它抛的异常是不是预期的,如执行:1/0,预期结果是抛出异常ZeroDivisionError: division by zero。要断言这个异常,通常是断言异常的type和value值。

这里的异常类型是ZeroDivisionError,异常value值是division by zero,于是用例可以这样设计:

# content of test_assert1.py
import pytest
def test_zero_division():
    with pytest.raises(ZeroDivisionError) as excinfo:
        1 / 0
    assert excinfo.type == ZeroDivisionError  # 断言异常类型type
    assert "division by zero" in str(excinfo.value)  # 断言异常value值

excinfo 是一个异常信息实例,里面包含了异常的详细信息。主要属性有:.type、 .value 和 .traceback。注意:断言type的时候,异常类型是不需要加引号的,断言value值的时候需转str。

在上下文管理器中,可以使用参数message来指定自定义失败消息:

>>> with raises(ZeroDivisionError,message="Expecting ZeroDivisionError"):
...     pass
... Failed: Expecting ZeroDivisionError

3、常用断言

pytest里面断言实际上就是python里面的assert断言方法,常用的有以下几种:

  • assert xx 判断xx为真
  • assert not xx 判断xx不为真
  • assert a in b 判断b包含a
  • assert a == b 判断a等于b
  • assert a != b 判断a不等于b
posted @ 2021-11-29 20:33  --D  阅读(165)  评论(0编辑  收藏  举报