Pytest之测试命名规则的使用


Posted in Python onApril 16, 2021

背景:

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文件,添加配置,达到个性化运行的目的。

到此这篇关于Pytest之测试命名规则的使用的文章就介绍到这了,更多相关Pytest 命名规则内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python中使用PyQt把网页转换成PDF操作代码实例
Apr 23 Python
python基础入门学习笔记(Python环境搭建)
Jan 13 Python
Python增量循环删除MySQL表数据的方法
Sep 23 Python
matplotlib作图添加表格实例代码
Jan 23 Python
Python解决八皇后问题示例
Apr 22 Python
django之状态保持-使用redis存储session的例子
Jul 28 Python
python 爬取疫情数据的源码
Feb 09 Python
Python如何读取、写入CSV数据
Jul 28 Python
Python实现一个简单的递归下降分析器
Aug 01 Python
Ubuntu20.04环境安装tensorflow2的方法步骤
Jan 29 Python
PyQt 如何创建自定义QWidget
Mar 24 Python
Python实现对齐打印 format函数的用法
Apr 28 Python
pycharm debug 断点调试心得分享
Python通过m3u8文件下载合并ts视频的操作
Python实现Telnet自动连接检测密码的示例
AI:如何训练机器学习的模型
python 用递归实现通用爬虫解析器
MATLAB 如何求取离散点的曲率最大值
用Python远程登陆服务器的步骤
You might like
二次元帅气男生排行榜,只想悄悄收藏系列
2020/03/04 日漫
一个php作的文本留言本的例子(五)
2006/10/09 PHP
延长phpmyadmin登录时间的方法
2011/02/06 PHP
php使用str_replace实现输入框回车替换br的方法
2014/11/24 PHP
PHP强制转化的形式整理
2020/05/22 PHP
Javascript中valueOf与toString区别浅析
2013/03/19 Javascript
js操纵dom生成下拉列表框的方法
2014/02/24 Javascript
jQuery中removeData()方法用法实例
2014/12/27 Javascript
javascript连续赋值问题
2015/07/08 Javascript
JS实现支持Ajax验证的表单插件
2016/03/24 Javascript
SWFUpload多文件上传及文件个数限制的方法
2016/05/31 Javascript
jquery easyui dataGrid动态改变排序字段名的方法
2017/03/02 Javascript
深入理解react-router@4.0 使用和源码解析
2017/05/23 Javascript
Vue.js实现微信过渡动画左右切换效果
2017/06/13 Javascript
JS实现的找零张数最小问题示例
2017/11/28 Javascript
layui前端框架之table表数据的刷新方法
2018/08/17 Javascript
微信开发之微信jssdk录音功能开发示例
2018/10/22 Javascript
微信小程序实现菜单左右联动
2020/05/19 Javascript
Vue实现购物小球抛物线的方法实例
2020/11/22 Vue.js
[43:35]TI4 循环赛第二日Liquid vs Fnatic
2014/07/11 DOTA
[54:56]DOTA2上海特级锦标赛主赛事日 - 5 总决赛Liquid VS Secret第三局
2016/03/06 DOTA
[00:37]2016完美“圣”典风云人物:AMS宣传片
2016/12/06 DOTA
python实现读取命令行参数的方法
2015/05/22 Python
在Python程序员面试中被问的最多的10道题
2017/12/05 Python
使用python实现knn算法
2017/12/20 Python
使用jquery实现HTML5响应式导航菜单教程
2014/04/02 HTML / CSS
两则小学生的自我评价分享
2013/11/14 职场文书
写给保洁员表扬信
2014/01/08 职场文书
大学生上课迟到检讨书
2014/10/15 职场文书
自我检讨书怎么写
2015/05/07 职场文书
幼儿园安全教育月活动总结
2015/05/08 职场文书
2015年安置帮教工作总结
2015/05/22 职场文书
2016年共产党员个人承诺书
2016/03/24 职场文书
Dubbo+zookeeper搭配分布式服务的过程详解
2022/04/03 Java/Android
SQL Server携程核心系统无感迁移到MySQL实战
2022/06/01 SQL Server
SpringBoot前端后端分离之Nginx服务器下载安装过程
2022/08/14 Servers