pytest自动化测试中,有时候我们并不需要对所有的用例全部执行,比如在写测试用例调试的时候,或者冒烟测试的时候。而pytest就给我们提供了这样一种机制:有选择的挑选用例去执行。
pytest中标记用例分为自定义标记和内置标记
**一、 如何标记
在pytest中,标记用例使用的是marker,一个测试函数可以有多个marker,一个marker可以标记多个测试函数
二、标记分类
在pytest中,标记分为自定义标记和内置标记。自定义标记就是自己定义标记的名称,内置标记就是用官方已经定义好的关键字来标记
- 自定义标记
import pytest
@pytest.mark.smoke
def test_add():
assert 1 + 2 == 3
def test_print():
assert 4 == 4
@pytest.mark.smoke
def test_cat():
assert 6 / 2 == 3
在上图代码中,看到用到了装饰器@pytest.mark.smoke。“@”表示这是一个装饰器,“pytest.mark”是pytest固定的写法,表明给这个测试函数加上装饰器,“smoke”是自己去的名称,可以叫做任何名称,只要不和内置名称一样即可,当我们在运行时,可以通过“-m”参数指定来运行标记的参数
(venv) D:\pythonProject\test_py>pytest -v -m "smoke"
======================================================== test session starts =========================================================
platform win32 -- Python 3.8.2, pytest-6.2.1, py-1.10.0, pluggy-0.13.1 -- d:\pythonproject\venv\scripts\python.exe
cachedir: .pytest_cache
rootdir: D:\pythonProject\test_py, configfile: pytest.ini
collected 4 items / 2 deselected / 2 selected
test_raise.py::test_add PASSED [ 50%]
test_raise.py::test_cat PASSED [100%]
================================================== 2 passed, 2 deselected in 0.07s ===================================================
从运行结果可以看到,只运行了标记为smoke的测试函数,当然可以给一个函数标记多个
@pytest.mark.data
@pytest.mark.smoke
def test_cat():
assert 6 / 2 == 3
两个标记之间不受任何影响,“-m”参数后面可以跟and,or,not
D:\pythonProject\test_py>pytest -v -m "smoke and data"
======================================================== test session starts =========================================================
platform win32 -- Python 3.8.2, pytest-6.2.1, py-1.10.0, pluggy-0.13.1 -- d:\pythonproject\venv\scripts\python.exe
cachedir: .pytest_cache
rootdir: D:\pythonProject\test_py, configfile: pytest.ini
collected 4 items / 3 deselected / 1 selected
test_raise.py::test_cat PASSED
and表示这个测试函数被2个装饰器标记,or表示只要被其中的一个装饰器标记就可以,not表示不含not后面的那个标记
- 内置标记
在pytest中,给我们提供了一些内置标记:skip,skipif,xfail等
1、如果要跳过某个测试,只需要在测试函数上添加“@pytest.mark.skip”即可
import pytest
@pytest.mark.smoke
def test_add():
assert 1 + 2 == 3
@pytest.mark.skip(reason="不执行")
def test_print():
assert 4 == 4
@pytest.mark.data
@pytest.mark.smoke
def test_cat():
assert 6 / 2 == 3
skip后面可以跟上reason参数,表示跳过的原因是什么,也可以选择不加参数
2、满足条件跳过某个测试用例用skipif,统一skipif后面也可以跟参数
3、使用xfail表示我们预期该用例会失败
用xfail标记的用例,表示预期失败,如果实际也失败了,则运行结果标记为 XFAIL,如果预期失败,实际没有失败,则运行结果标记为XPASS