pytest基础005-assert 断言
什么是断言
assert断言是用于判断一个表达式,在表达式条件为 false 的时候触发异常。
语法格式:
assert expression(表达式):
表达式的结果为 true,断言成功;
表达式的结果为 false,断言失败。
常用断言
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
案例如下:
1 assert 'h' in 'hello' 2 assert 7 > 6 3 assert 1 == 1 4 assert {'0', '1', '3', '8'} == {'0', '3', '5', '8'}
异常断言:
可以使用 pytest.raises 作为上下文管理器,当抛出异常时可以获取到对应的异常实例。
常见异常:
NameError:name未定义,触发异常
ZeroDivisionError:除数不能为0,触发异常
TypeError:错误的类型相加等操作,触发异常
1 # 断言异常 2 def test_type_error(): 3 with pytest.raises(TypeError): 4 '2' + 2
断言场景:断言它抛的异常是不是预期想要的
代码执行:1/0
预期结果:抛的异常是ZeroDivisionError: division by zero
如何断言:通常是断言异常的 type 和 value 值了
具体方式:这里 1/0 的异常类型是 ZeroDivisionError,异常的 value 值是 divisionby zero
1 # 详细断言异常 2 def test_type_error2(): 3 with pytest.raises(TypeError) as exc: 4 '2' + 2 5 6 # 断言异常类型 type 7 assert exc.type == TypeError 8 # 断言异常 value 值 9 assert "can only concatenate" in str(exc.value)
exc :是一个异常信息实例
主要属性: .type 、 .value 、 .traceback
注意:断言 type 的时候,异常类型是不需要加引号的,断言 value值的时候需转 str
检查断言装饰器
1 # 断言装饰器 2 @pytest.mark.xfail(raises=TypeError) 3 def test_type_error3(): 4 '2' + 2
执行结果:
1 XFAIL 2 @pytest.mark.xfail(raises=TypeError) 3 def test_type_error3(): 4 > '2' + 2 5 E TypeError: can only concatenate str (not "int") to str
知识点
- 代码抛出异常,但是和raises指定的异常类相匹配,所以不会断言失败
- 它相当于一个检查异常装饰器,功能:检查是否有异常,不确定是否有异常
- with pytest.raise(TypeError) 对于故意测试异常代码的情况,使用可能会更好
- 而 @pytest.mark.xfail(raises=TypeError) 对于检查未修复的错误(即,可能会发生异常),使用检查断言可能会更好
写在最后的话:小白同学愿意和大家一起成长~