一、pytest中的skip和xfail
skip 跳过测试函数
skip 意味着您希望只有在满足某些条件时测试才能通过,否则pytest应该跳过运行测试。常见的例子是跳过非Windows平台上的仅限Windows的测试,或者跳过依赖于当前不可用的外部资源(例如数据库)的测试。
(1)skip
跳过测试函数的最简单方法是用 skip,可以传递可选参数 reason :
输出:
(2)skipif
如果您希望有条件地跳过某些内容,则可以使用 skipif
xfail 将测试功能标记为预期失败
xfail 意味着您希望某个测试由于某种原因而失败。一个常见的例子是对尚未实现的特性或尚未修复的错误的测试。当测试通过时,尽管预期会失败(标记为 pytest.mark.xfail 这是一个 XPASS 并将在测试总结中报告。
方法:
xfail(condition=None, reason=None, raises=None, run=True, strict=False)
常用参数:
condition:预期失败的条件,必传参数
reason:失败的原因,必传参数
使用方法:
@pytest.mark.xfail(condition, reason="xx")
示例:
import pytest
def test_001():
print("测试用例1")
assert 1 == 1
@pytest.mark.xfail(2>1,reason="标记为xfail")
def test_002():
print("测试用例2")
assert 1 == 1
def test_003():
print("测试用例3")
assert 1 == 1
if __name__ == '__main__':
pytest.main(["-s", "demo.py","-v"])
输出:
collecting ... collected 3 items
demo.py::test_001 测试用例1
PASSED
demo.py::test_002 测试用例2
XPASS
demo.py::test_003 测试用例3
PASSED
======================== 2 passed, 1 xpassed in 0.09s =========================
二、pytest的conftest.py介绍
conftest.py就是存放fixture的地方。准确的说,是存放自定义fixture的地方。
conftest.py的作用范围
其作用范围是当前目录包括子目录里的测试模块。
比如在测试系统的根目录创建conftest.py文件,其文件中的fixture的作用范围是所有测试模块。
比如在某个单独的测试文件夹里创建conftest.py文件,该文件中fixture的作用范围就仅局限于该测试文件夹里的测试模块。该测试文件夹外的测试模块或者该测试文件夹外的测试文件夹,是无法调用到这个conftest.py文件中的fixture。
Tips:如果测试根目录和测试子目录都有conftest.py,并且这两个conftest.py中都有一个同名的fixture,测试子目录中的测试用例使用这个命名的fixture,实际生效的是测试子目录下的conftest.py中的fixture。
conftest.py的注意事项
1.conftest.py是python的模块,但是不能被导入。import conftest操作是非法的。
2.建议把测试项目的所有fixture都存放在conftest.py中,把conftest.py当作pytest的fixture仓库。
3.如果希望fixture共享给所有测试,则把该fixture放在测试根目录下的conftest.py是最合适的。