Pytest框架 —— Mark分组执行测试用例

(1)Pytest中的Mark介绍

Mark主要用于在测试用例/测试类中给用例打标记,实现测试分组功能,并能和其它插件配合设置测试方法执行顺序等。

在实际工作当中,我们要写的自动化用例会比较多,而且不会都放在一个.py文件里。

如下图,现在需要只执行红色部分的测试方法,其它方法不执行。

(2)Mark的使用

在Pytest当中,先给用例打标记,在运行时,通过标记名来过滤测试用例。

步骤:

  1. @pytest.mark.标签名标记在需要执行的用力上。(标签名自定义)
  2. 执行测试:pytest 测试套件名 -m 标签名
  3. 这样执行会有警告,提示标签未注册。

示例:


# 如:在test_01.py文件的testa()方法上进行mark标识。

@pytest.mark.hellotest

def test_a():

"""购物下单"""

print("test_01文件的函数a")

assert True


# 其他两个文件中的方法同理。

执行命令 

 

if __name__ == '__main__':

pytest.main(["-vs", "-m", "hellotest"])


# 同理也可以用命令行的方式执行。


"""

执行结果:


test_01.py::test_a test_01文件的函数a

PASSED

test_02.py::test_b test_02文件的函数b

PASSED

test_03.py::test_a test_03文件的函数a

PASSED


3 passed, 3 deselected, 3 warnings

说明:3个用例通过,3个用例没有选择,有3个警告

"""

这样就简单的实现了Mark标记的使用,但是我们在工作中不这样用,我们需要把Mark标记进行注册。

(3)Mark的注册和使用

Mark标签官方提供的注册方式有2种,这里只提供一种最简单直接的方式:

通过pytest.ini配置文件注册。

pytest.ini文件当中配置:


[pytest] # 固定的section名

markers= # 固定的option名称,注意缩进。

标签名1: 标签名的说明内容。

标签名2: 不写也可以

标签名N

示例:还是上面的练习

pytest.ini配置文件内容如下:

 

[pytest]

addopts = -vs

testpaths = scripts

python_files = test*

python_classes = Test*

python_functions = test*

markers=

hellotest: Mark Description

smoke

执行命令 

 

if __name__ == '__main__':

pytest.main(["-m", "hellotest"])


"""

执行结果:


test_01.py::test_a test_01文件的函数a

PASSED

test_02.py::test_b test_02文件的函数b

PASSED

test_03.py::test_a test_03文件的函数a

PASSED


3 passed, 3 deselected,

说明:3个用例通过,3个用例没有选择,没有警告了。

"""
(4)使用Mark完成失败重试

只执行test_01.py文件中的测试用例:

 

import pytest



@pytest.mark.hellotest

def test_a():

"""购物下单"""

print("test_01文件的函数a")

assert True



@pytest.mark.Fail_retry

def test_b():

"""购物下单"""

print("test_01文件的函数b")

assert False



if __name__ == '__main__':

pytest.main(["-m", "Fail_retry"])




"""

执行结果:


test_01.py::test_b test_01文件的函数b

RERUN

test_01.py::test_b test_01文件的函数b

RERUN

test_01.py::test_b test_01文件的函数b

FAILED


1 failed, 1 deselected, 2 rerun

说明:1个失败,1个取消选择,2次重跑用例

"""

'

运行

运行

下面是pytest.ini配置文件内容: 


[pytest]

addopts = -vs --reruns 2(配置重跑两次)

testpaths = scripts

python_files = test_01.py

python_classes = Test*

python_functions = test*

markers=

hellotest: Mark Description

Fail_retry:
(5)扩展

1)多个Mark标签可以用在同一个用例上。


@pytest.mark.hello

@pytest.mark.world

def test_a():

"""购物下单"""

print("test_01文件的函数a")

assert True

2)Mark标签也可以用到测试类上。 


@pytest.mark.hello

class Test_Mark:


@pytest.mark.world

def test_a(self):

"""购物下单"""

print("test_01文件的函数a")

assert True

工作中的使用场景:冒烟测试,分模块执行测试用例,分接接口执行测试用例等。 

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:【文末小卡片领取】

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值