1、概念
pytest 是 Python 的一种单元测试框架,同自带的UnitTest 测试框架类似,相比于 UnitTest 框架使用起来更简洁,效率更高。
2、特点
- 简单易上手,文档丰富,入门简单,文档中有很多实例可以参考
- 支持简单的单元测试和复杂的功能测试
- 支持参数化
- 执行测试过程中可以将某些测试跳过,或者对某些预期失败的 Case 标记成失败
- 支持重复执行失败的 Case
- 支持运行由 Nose,UnitTest 编写的测试Case(UnitTest代码可以直接用pytest运行)
- 具有很多第三方插件,并且可以自定义拓展
- 方便的和持续集成工具集成
3、安装
安装:pip3 install pytest
查看:pip show pytest
确认版本:pytest --version
或者直接在pycharm中安装pytest
注:如果出现pytest 命令不可用,则需要使用管理员身份打开终端重新安装pytest
4、代码格式
class Testxxx: # Test 开头的测试类
def testxxx(self): # test 开头的测试方法
pass
5、运行方式
(1)命令行模式
命令行中执行 pytest -s test.py(文件名)
(2)主函数模式
在Python文件中增加主函数:
if __name__ == '__main__'
pytest.main(['-s',"文件名"])
-s 表示支持控制台打印,如果不加 print不会出现任何内容
6、特殊方法(跟 UnitTest 框架中 fixture 效果一样)
(1)方法级别
# 初始化(前置处理)
def setup(self): --> 首先自动执行
# 销毁(后置处理)
def teardown(self): --> 最后自动执行
# 运行于测试方法的始末,即:运行一次测试方法就会运行一次setUp和tearDown
(2)类级别
# 初始化(前置处理)
def setup_class(self): --> 首先自动执行
# 销毁(后置处理):
def teardown_class(self): --> 最后自动执行
# 运行于测试类的始末,即:每个测试类只会运行一次setup_class和teardown_class
7、配置文件
应用场景:使用配置文件后可以快速的使用配置的项来选择执行哪些测试模块
使用方法:在根目录创建 pytest.ini 文件(tox.ini 或者 setup.cfg 文件也可以)
文件内容:
[pytest]
testpaths = ./study/pytest # 文件搜索路径,即文件所在位置
addopts = -s # 添加命令行参数
python_files = test*.py # 指定文件名称
python_classes = Test* # 指定类名称
python_functions = test* # 指定方法名称
注:
1. 在Windows 系统下,pytest 配置文件中,不允许写注释信息
2. 一个工程只需要一个 pytest 配置文件,并且需要保证文件名正确
3. 一般情况下只需要将 pytest 配置文件置于工程根目录下
4. 配置有 pytest 配置文件的工程,只需要打开命令行,输入 pytest 指令即可执行测试
8、 pytest 常用插件
(1)生成 pytest-html 测试报告插件
Instalación: Instale a través de pip3 install pytest-html o instale el complemento pytes-html a través de pycharm
Uso: Agregue --html=report path/report.html al parámetro de línea de comando addopts en el archivo de configuración
Si desea fusionar archivos css, agregue --self-contained-html después
(2) Complementos que controlan el orden de ejecución de las funciones de pytest
Instalación: instale a través de pip3 instale pytest-ordering o instale el complemento pytest-ordering a través de pycharm
Uso: marca y función probada, @pytest.mark.run(order=x)
orden Ya sea todo positivo o todo negativo, cuanto menor sea el valor, mayor será la prioridad; cuando los números positivos y negativos existen al mismo tiempo, el número positivo tiene mayor prioridad
(3) complemento de reintento de falla de pytest
Instalación: instale a través de pip3 instale pytest-rerunfailures o instale el complemento pytest-rerunfailures a través de pycharm
Uso: Agregue --reruns -n al parámetro de la línea de comando addopts en el archivo de configuración (n determina el número de reintentos, no más de 3)
9. Saltar operación
# 跳过测试函数
# 参数:
# condition:跳过的条件,必传参数
# reason:标注原因,必传参数
@pytest.mark.skipif(condition , reason=None)
Uso: agregue el decorador @pytest.mark.skipif(condición,razón="xxx") al script de prueba que debe omitirse
10. Parametrización
# 数据参数化
# 参数:
# argnames:参数名
# argvalues:参数对应值,类型必须为可迭代类型,一般用list
@pytest.mark.parametrize(argnames,argvalues,indirect=False,ids=None,scope=None)
Uso: agregue el decorador @pytest.mark.parametrize(argnames,argvalues) encima de la función de prueba que necesita ser parametrizada
Ejemplo de un solo parámetro:
import pytest
class Test1:
@pytest.mark.parametrize("name",["小明","小李","小张"])
def test_method(self,name):
print(name)
Ejemplo con múltiples parámetros:
import pytest
class TestLogin:
# 拓展:另一种写法
# @pytest.mark.parametrize(("admin","passwd"),[("admin",123456),("test",456789)])
@pytest.mark.parametrize("admin,passwd",[("admin",123456),("test",456789),("xxx","yyy")])
def test_method(self,admin,passwd):
print(admin)
print(passwd)
11, Afirmación
Método: afirmar xxx que viene con el sistema (el método de afirmación que viene con el marco UnitTest)
Ejemplo:
assert 1==2 # 判断是否相等
assert "name" in "my name is student" # 判断是否包含
assert 2 > 1 # 判断大小