pytest中文文档教程(二)用例标记和用例执行
教程一中主要介绍了pytest的入门使用和测试用例编写,这个一节主要给大家介绍pytest中的标记机制和用例执行的方法。pytest可以通过标记将数据传入于测试函数中,也可以通过标记中对执行的用例做筛选,接下来直接进入正题。
一、pytest中内置的标记
pytest标记使用需要通过pytest.mark.标记
来使用,pytest中为应对各种测试场景也内置了很多的标记。
1.1、pytest.mark.parametrize:用例参数化的标记
通过parametrize
可以将用例数据和用例执行的逻辑代码分离,并实现根据用例,自动生成测试用例。
Demo:
@pytest.mark.parametrize('item',[11,22,33,44,55,66])
def test_demo(item)
assert item > 50
1.2、pytest.mark.skip:跳过用例执行
通过skip
装饰的用例,在执行的时候会无条件跳过,
参数reason:跳过测试函数的原因。
Demo
# 不写跳过原因
@pytest.mark.skip
def test_demo()
assert item > 50
# 写跳过原因
@pytest.mark.skip(reason='不需要执行')
def test_demo()
assert item > 50
1.3、pytest.mark.skipif:根据条件跳过用例
skipif
可以根据条件来决定是否跳过用例的执行, 如果条件为True
则跳过测试函数执行。
参数 :condition —跳过的条件
参数 : reason —跳过的原因
Demo
a = 10
@pytest.mark.skipif(a > 20,reason='条件不成立,不执行')
def test_demo()
assert item > 50
1.4、pytest.mark.xfail:标记预期失败的用例
xfail
可以将测试函数标记为预期执行失败的用例。
参数 :condition — 将测试函数标记为 xfail 的条件(True/False
)
参数 : reason — 测试函数被标记为 xfail 的原因
参数 : raises — 预期失败的异常类型
参数 : run — 是否应该实际执行测试函数。如果False
,该函数将始终 xfail 并且不会被执行 。
参数 : strict — 严格模式(True/False
)
Demo
a = 10
@pytest.mark.xfail(a > 20,reason='条件不成立,不执行' raises=AssertionError )
def test_demo()
assert item > 50
1.5、pytest.mark.usefixtures:给测试类或模块设置测试夹具
usefixtures
标记一般用于给测试类下面的测试方法统一设置测试夹具。
Demo
# TestDome这个测试类的所有测试用例均执行my_fixture这个夹具
@pytest.mark.usefixtures('my_fixture这个夹具')
class TestDome:
# 函数用例 指定测试夹具
def test_02(self):
print('----测试用例:test_01------')
# 函数用例 指定测试夹具
def test_03(self):
print('----测试用例:test_02------')
二、自定义标记
pytest支持通过pytest.ini文件注册自定义的标记。以满足执行用例时,通过标记对用例进行筛选.,
2.1、注册标记
pytest.ini文件注册标记的语法如下:
[pytest]
markers =
标记1
标记2
2.2、标记函数
Demo:
# 用例前面加载标签:@pytest.mark.标签名
@pytest.mark.main
def test_demo():
pass
2.3、标记类
Demo:
# 方式一:直接类上面打标记
@pytest.mark.main
class TestClass(object):
def test_demo1(self):
assert 10 > 20
# 方式二:通过类属性pytestmark,可以同时添加多个标记
class TestClass(object):
pytestmark = [pytest.mark.main, pytest.mark.main]
def test_demo1(self):
assert 10 > 20
三、通过标记筛选用例执行
Demo:现有用例如下:
import pytest
@pytest.mark.mk1
@pytest.mark.mk2
def test_01():
print("用例一")
def test_02():
print("用例二")
@pytest.mark.mk2
def test_03():
print("用例三")
@pytest.mark.mk2
def test_04():
print("用例四")
@pytest.mark.mk1
def test_05():
print("用例五")
@pytest.mark.mk1
def test_06():
print("用例六")
上面Demo中有6条测试用例,分别通过pytest.mark.mk1
和pytest.mark.mk2
进行标记了,接下来我们一起来看看如何通过标记选择用例执行。
3.1、通过单个标记筛选
语法:pytest -m '标签名'
Demo:
pytest -m mk2
执行结果如下:
========================== test session starts ==========================
platform win32 -- Python 3.7.3, pytest-5.4.2, py-1.8.0, pluggy-0.13.0
rootdir: C:\project\, inifile: pytest.ini
plugins: allure-pytest-2.8.15, Faker-8.11.0, metadata-1.9.0, parallel-0.0.8, repeat-0.8.0, rerunfailures-9.0, testreport-1.1.2
collected 6 items / 3 deselected / 3 selected
test_mode.py ... [100%]
========================== 3 passed, 3 deselected in 0.29s ==========================
可以看到执行结果执行了3条用例,3条未选中。
3.2、同时选中多个标记
语法:pytest -m "标记1 or 标记2"
命令: pytest -m "mk2 ro mk1"
执行通过mk2或者mk1 标记的的用例。执行结果如下:
========================== test session starts ==========================
platform win32 -- Python 3.7.3, pytest-5.4.2, py-1.8.0, pluggy-0.13.0
rootdir: C:\project\, inifile: pytest.ini
plugins: allure-pytest-2.8.15, Faker-8.11.0, metadata-1.9.0, parallel-0.0.8, repeat-0.8.0, rerunfailures-9.0, testreport-1.1.2
collected 6 items / 1 deselected / 5 selected
test_mode.py ..... [100%]
========================== 5 passed, 1 deselected in 0.29s ==========================
从上述结果可以看到,只要加了mk2或mk1这两个标记中的任意一个
语法: pytest -m "标记1 and 标记2"
命令: pytest -m "mk2 and mk1"
执行通过mk2和mk1这两个标记同时标记的用例。执行结果如下
========================== test session starts ==========================
platform win32 -- Python 3.7.3, pytest-5.4.2, py-1.8.0, pluggy-0.13.0
rootdir: C:\project\, inifile: pytest.ini
plugins: allure-pytest-2.8.15, Faker-8.11.0, metadata-1.9.0, parallel-0.0.8, repeat-0.8.0, rerunfailures-9.0, testreport-1.1.2
collected 6 items / 5 deselected / 1 selected
test_mode.py . [100%]
========================== 1 passed, 5 deselected in 0.29s ==========================
原文地址:https://www.cnblogs.com/musen6/p/16555632.html
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 第2章—装配Bean—通过java代码装配bean
- oauth2.0的授权流程详解
- 第3章—高级装配—bean的作用域
- SpringSecurity自定义用户登录
- 第3章—高级装配—运行时注入
- 快速创建SpringBoot+SSM解析
- 第3章—高级装配—条件化的Bean
- Springsecurity搭建自定义登录页面
- SpringBoot项目中加入jsp页面
- Springboot用官方建议访问Html页面并接传值
- Spring Security OAuth 2开发者指南译
- oauth2.0通过JdbcClientDetailsService从数据库读取相应的配置
- security和oauth2.0的整合
- feign中的hytrix和turbin配置
- SpringSecurity之记住我功能的实现