Pytest测试的命名规则是怎样的,测试实现方法是什么
Admin 2022-07-08 群英技术资讯 568 次浏览
pytest以特定规则搜索测试用例,所以测试用例文件、测试类以及类中的方法、测试函数这些命名都必须符合规则,才能被pytest搜索到并加入测试运行队列中。
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:
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
Python二维列表的创建、转换以及访问,下文有实例供大家参考,对大家了解操作过程或相关知识有一定的帮助,而且实用性强,希望这篇文章能帮助大家,下面我们一起来了解看看吧。
多径效应(multipath effect):指电磁波经不同路径传播后,各分量场到达接收端时间不同,按各自相位相互叠加而造成干扰,使得原来的信号失真,或者产生错误。比如电磁波沿不同的两条路径传播,而两条路径的长度正好相差半个波长,那么两路信号到达终点时正好相互抵消了
本章节将一些Python3基础语法整理成手册,方便各位在日常使用和学习是查阅,包含了编码、标识符、保留字、注释、缩进、字符串等常用内容。
多线程概述多线程使得程序内部可以分出多个线程来做多件事情,充分利用CPU空闲时间,提升处理效率。python提供了两个模块来实现多线程threa
if嵌套语句在if的基础上加深了难度,因为需要判断多个条件。相对来说,if嵌套语句的练习题会比if语句难得多。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008