pytest(5)-断言

2023-05-06,

前言

断言是完整的测试用例中不可或缺的因素,用例只有加入断言,将实际结果与预期结果进行比对,才能判断它的通过与否。

unittest 框架提供了其特有的断言方式,如:assertEqual、assertTrue、assertIn等,pytest 同样有自己的断言方式,即使用assert进行断言。

assert

pytest 中使用python源生态assert字段进行断言。

常用断言方式

pytest常用的断言方式如下:

判断是否相等,assert Actual(实际结果) == Expected(期望结果)
判断是否不相等,assert Actual != Expected,其他如 >、<、>=、<= 都可直接使用。
判断xx是否为真,assert xx
判断xx是否不为真,assert not xx
判断b是否包含a,assert a in b
判断b不包含a,assert a not in b

assert 断言的对象可以是字符串、int、float、list、dict、tuple 任一类型。

使用示例

自定义了一个查询所有用户信息接口,返回参数格式如下:

{
"code": 1000,
"data": [
{"id": 1, "username": "刘德华", "sex": 0, "telephone": "12306", "address": "香港九龙区"},
{"id": 2, "username": "梅艳芳", "sex": 1, "telephone": "95511", "address": "上海黄浦区"},
{"id": 3, "username": "陈百强", "sex": 0, "telephone": "10086", "address": "北京海淀区"},
]
}

用例断言如下:

def test_get_all_users():
'''查询所有用户信息'''
url = "http://127.0.0.1:5000/users"
res = requests.get(url=url).text
res = json.loads(res)
# 断言是否相等
assert res['code'] == 1000
# 断言返回结果中data是否为True(这里其实就是判断是否为空)
assert res['data'] Andy = {"id": 1, "username": "刘德华", "sex": 0, "telephone": "12306", "address": "香港九龙区"}
# 断言返回结果中data是否包含刘德华的信息
assert Andy in res['data']

断言通过:

我们修改一下脚本让断言不通过,如下:

def test_get_all_users():
'''查询所有用户信息'''
url = "http://127.0.0.1:5000/users"
res = requests.get(url=url).text
res = json.loads(res)
# 断言是否相等
assert res['code'] == 1001
# 断言返回结果中data是否为True(这里其实就是判断是否为空)
assert not res['data'] Andy = {"id": 1, "username": "刘德华", "sex": 0, "telephone": "12306", "address": "香港九龙区"}
# 断言返回结果中data是否包含刘德华的信息
assert Andy not in res['data']

运行结果如下:

可以看到,code 的 Actual 为1000,而 Excepted 为1001,所以断言直接报错,不继续执行后面的代码。

断言结果添加异常信息

我们可以在断言异常的时候,输出一些提示信息,这样断言报错后,可以方便我们查看原因。

自定义的用户信息接口可以查询某个用户的信息,对它编写测试脚本如下:

def test_get_user():
'''查询所有用户信息'''
url = "http://127.0.0.1:5000/users/1"
res = requests.get(url=url).text
res = json.loads(res)
assert res['code'] == 1000
assert res['data']['username'] == "张学友", "判断返回是否为张学友,实际返回:{}".format(res['data']['username'])

运行结果如下:

总结

pytest 还能对执行过程中产生的 Exception 及 Warnning 进行断言,但这些情况在我们的测试中很少会用到,所以不做过多阐述。

pytest(5)-断言的相关教程结束。

《pytest(5)-断言.doc》

下载本文的Word格式文档,以方便收藏与打印。