Pytest之测试命名规则的使用

作者:阿刁阿 时间:2022-09-23 00:51:49 

背景:

pytest以特定规则搜索测试用例,所以测试用例文件、测试类以及类中的方法、测试函数这些命名都必须符合规则,才能被pytest搜索到并加入测试运行队列中。

默认搜索规则:

  • 如果pytest命令行有指定目录,则从该目录中开始查找测试用例文件,如果没有指定,则从当前运行目录开始查找文件。注意,该查找是递归查找,子目录中的文件也会被查找到。

  • 并不是能够查找到目录下的所有文件,只有符合命名规则的文件才会被查找。默认规则是以test_开头或者以_test结尾的.py文件。

  • 在测试文件中查找Test开头的类,以及类中以test_开头的方法,查找测试文件中test_开头的函数。

测试用例默认命名规则

  • 除非pytest命令指定到测试用例文件,否则测试用例文件命名应该以 test_开头或者以_test结尾。

  • 测试函数命名,测试类的方法命名应该以test_开头。

  • 测试类命名应当以Test开头。

tips: 测试类的不应该有构造函数。

笔者习惯装测试用例的文件夹,测试用例文件,测试函数,类中的测试方法都以test_开头。建议保持一种统一的风格。

示例:


# func.py
def add(a,b):
return a+b

# ./test_case/test_func.py
import pytest
from func import *

class TestFunc:

#def __init__(self):
 #self.a = 1

def test_add_by_class(self):
 assert add(2,3) == 5

def test_add_by_func():
assert add(4,6) == 10

'''
# stdout:
============================= test session starts =============================
platform win32 -- Python 3.7.0, pytest-5.3.4, py-1.8.1, pluggy-0.13.1
rootdir: D:\Python3.7\project\pytest
plugins: allure-pytest-2.8.9, rerunfailures-8.0
collected 2 items

test_case\test_func.py ..                                                [100%]

============================== 2 passed in 0.04s ==============================
[Finished in 1.3s]
######################################################################
'''

测试结果中,test_case\test_func.py … 。两个点号代表两个测试用例。

错误示范,当测试类有构造函数时:


# func.py
def add(a,b):
return a+b

# ./test_case/test_func.py
import pytest
from func import *

class TestFunc:

def __init__(self):
 self.a = 1

def test_add_by_class(self):
 assert add(2,3) == 5

def test_add_by_func():
assert add(4,6) == 10

'''
# stdout:
============================= test session starts =============================
platform win32 -- Python 3.7.0, pytest-5.3.4, py-1.8.1, pluggy-0.13.1
rootdir: D:\Python3.7\project\pytest
plugins: allure-pytest-2.8.9, rerunfailures-8.0
collected 1 item

test_case\test_func.py .                                                 [100%]

============================== warnings summary ===============================
test_case\test_func.py:4
 D:\Python3.7\project\pytest\test_case\test_func.py:4: PytestCollectionWarning: cannot collect test class 'TestFunc' because it has a __init__ constructor (from: test_case/test_func.py)
   class TestFunc:

-- Docs: https://docs.pytest.org/en/latest/warnings.html
======================== 1 passed, 1 warning in 0.04s =========================
[Finished in 1.4s]
######################################################################
'''

会报错,pytest只能找到test_开头的函数,但是不能找到Test开头的含有构造函数的测试类。

自定义测试用例命名规则

如果因为某种需要,需要使用其他命名规则命名的测试文件、测试函数、测试类以及测试类的方法,可以通过pytest.ini配置文件做到。

在测试系统的顶层目录创建pytest.ini文件,在pytest.ini文件中写入如下配置:


[pytest]
# 更改测试文件命名规则
python_files = HG*

# 更改测试类命名规则
python_classes = HG*

# 更嗨测试函数命名规则
python_functions = HG*

示例:


# func.py
def add(a,b):
return a+b

# ./test_case/HG_func.py
import pytest
from func import *

class HGFunc:

#def __init__(self):
 #self.a = 1

def HG_add_by_class(self):
 assert add(2,3) == 5

def HG_add_by_func():
assert add(4,6) == 10

'''
stdout:
============================= test session starts =============================
platform win32 -- Python 3.7.0, pytest-5.3.4, py-1.8.1, pluggy-0.13.1 -- D:\Python3.7\python.exe
cachedir: .pytest_cache
rootdir: D:\Python3.7\project\pytest, inifile: pytest.ini
plugins: allure-pytest-2.8.9, rerunfailures-8.0
collecting ... collected 2 items

test_case/HG_func.py::HGFunc::HG_add_by_class PASSED                     [ 50%]
test_case/HG_func.py::HG_add_by_func PASSED                              [100%]

============================== 2 passed in 0.03s ==============================
[Finished in 1.3s]
'''

Tips:

  • pytest.ini是可以改变pytest运行方式的配置文件,但是正常情况下,测试系统里根本不需要存在pytest.ini文件,我们使用默认的运行方式即可工作。

  • pytest.ini还有许多其他个性化配置,当有需要时,可以在自动化测试项目的顶层目录里创建pytest.ini文件,添加配置,达到个性化运行的目的。

来源:https://blog.csdn.net/lc_buzhidao/article/details/105081437

标签:Pytest,命名规则
0
投稿

猜你喜欢

  • 浅析python连接数据库的重要事项

    2024-01-26 19:05:07
  • python爬取微博评论的实例讲解

    2022-01-10 19:53:14
  • python中分组函数groupby和分组运算函数agg的使用

    2023-05-25 03:15:48
  • 在ASP.NET 2.0中操作数据之三十一:使用DataList来一行显示多条记录

    2024-05-11 09:30:00
  • yahoo 页面的标签效果

    2024-04-10 10:38:14
  • Python MySQLdb 执行sql语句时的参数传递方式

    2024-01-28 08:45:33
  • Python numpy实现二维数组和一维数组拼接的方法

    2022-02-24 09:40:53
  • Vue表单验证插件Vue Validator使用方法详解

    2023-07-02 16:56:47
  • django 做 migrate 时 表已存在的处理方法

    2022-02-14 16:11:53
  • 使用keras时input_shape的维度表示问题说明

    2023-05-10 02:52:25
  • Python3获取cookie常用三种方案

    2022-10-20 02:56:19
  • 对python中执行DOS命令的3种方法总结

    2021-10-11 12:22:53
  • Django 忘记管理员或忘记管理员密码 重设登录密码的方法

    2021-02-14 09:40:46
  • 一个免刷新页面的JavaScript日历

    2007-12-26 12:57:00
  • CSS网页布局避免滥用DIV元素

    2011-03-30 12:34:00
  • vue在页面中如何使用window全局变量

    2024-05-09 15:14:49
  • python itchat实现调用微信接口的第三方模块方法

    2023-03-24 07:12:53
  • Go语言将string解析为time.Time时两种常见报错

    2024-05-22 17:45:48
  • vc6编写python扩展的方法分享

    2022-05-12 16:39:30
  • 微信小程序分享海报生成的实现方法

    2024-05-02 17:29:49
  • asp之家 网络编程 m.aspxhome.com