前言
上篇说到命令行执行测试用例的部分参数如何使用?今天将继续更新其他一些命令选项的使用,和pytest收集测试用例的规则!
pytest执行用例命令行参数
--collect-only:罗列出所有当前目录下所有的测试模块,测试类及测试函数
--tb=style:屏蔽测试用例执行输出的回溯信息,可以简化用例失败时的输出信息。style可以是 on,line,short,具体区别请自行体验
--lf:当一次用例执行完成后,如果其中存在失败的测试用例,那么我们可以使用此命令重新运行失败的测试用例
我们第一次执行用例,会看到有2个用例失败
我们使用--lf参数再次运行用例,可以发现只有之前失败的两个用例重新执行了一次
--ff:如果上次测试用例出现失败的用例,当使用--ff后,失败的测试用例会首先执行,剩余的用例也会再次执行一次
小结
以上就是命令行运行测试用例时经常使用到的参数,这些参数不仅可以单独使用,也可以组合一起使用,后期还会涉及到使用fixture时的一些命令,现在不需要了解。你可以使用--help来查看一些命令帮助信息!
pytest收集测试用例的规则
1)从一个或者多个目录开始查找,你可以在命令行指定文件或者目录,如果未指定那么从当前目录开始收集用例
2)在该目录和所有子目录下递归查找测试模块
3)测试模块是指文件名为test_*.py或者*_test.py的文件
4)在测试模块中查找以test_开头的函数
5)查找名字以Test开头的类。其中首先筛选掉包含__init__()函数的类,再查找类中以Test_开头的类方法
规则验证
现在我们就依次演示pytest搜索测试用例的过程
首先我们按照以下目录结构新建一个项目
每个文件编写如下代码(我们只是为了验证规则,所以用例些的很简单,实际项目不会存在这样简单的用例)
test_测试模块1.py
# 测试函数 def test_2(): assert 1 == 1 # 普通函数 def func_2(): print('普通函数') # 测试类 class TestClass_2(object): # 测试函数 def test_class_3(self): assert 1 == 1 # 普通函数 def func_class_3(self): assert 1 == 1 # 普通类 class NoTestClass_2(object): # 测试函数 def test_class_4(self): assert 1 == 1 # 普通函数 def func_class_4(self): assert 1 == 1
test_测试模块2.py
# 测试函数 def test_1(): assert 1==1 # 普通函数 def func_1(): print('普通函数') # 测试类 class TestClass_1(object): # 测试函数 def test_class_1(self): assert 1==1 # 普通函数 def func_class_1(self): assert 1==1 # 普通类 class NoTestClass_1(object): # 测试函数 def test_class_2(self): assert 1 == 1 # 普通函数 def func_class_2(self): assert 1 == 1
测试用例.py
# 测试函数 def test_one(): assert 1==1 # 普通函数 def func(): assert 1==1
代码分析
我们现在根据理论分析并结合代码,可以大致计算出,从项目根目录执行用例,应该会执行4条有效测试用例!
我们在项目根目录下执行pytest --collect-only看下情况,可以发现 搜索了test_测试模块1和test_测试模块2文件,并包括TestClass_2和TestClass_1类及内部test_class_3和test_class_1 和外部的测试函数test_2,test_1.
D:\pytest搜索测试用例规则>pytest --collect-only ============================= test session starts ============================= platform win32 -- Python 3.6.4, pytest-3.8.0, py-1.6.0, pluggy-0.7.1 rootdir: D:\pytest搜索测试用例规则, inifile: collected 4 items <Package 'D:\\pytest搜索测试用例规则\\测试用例目录1'> <Module 'test_测试模块1.py'> <Function 'test_2'> <Class 'TestClass_2'> <Instance '()'> <Function 'test_class_3'> <Module 'test_测试模块2.py'> <Function 'test_1'> <Class 'TestClass_1'> <Instance '()'> <Function 'test_class_1'> ======================== no tests ran in 0.14 seconds =========================
我们大致已经能看出pytest的搜索规则,现在们再执行一下所有用例看下 使用命令 pytest -v。可以看出确实只有4个用例被执行了,也就是只识别到了4个用例,根据下面的输出信息可以看出每个用例所在的位置
D:\pytest搜索测试用例规则>pytest -v ============================= test session starts ============================= platform win32 -- Python 3.6.4, pytest-3.8.0, py-1.6.0, pluggy-0.7.1 -- c:\python36\python.exe cachedir: .pytest_cache rootdir: D:\pytest搜索测试用例规则, inifile: collected 4 items 测试用例目录1/test_测试模块1.py::test_2 PASSED [ 25%] 测试用例目录1/test_测试模块1.py::TestClass_2::test_class_3 PASSED [ 50%] 测试用例目录1/test_测试模块2.py::test_1 PASSED [ 75%] 测试用例目录1/test_测试模块2.py::TestClass_1::test_class_1 PASSED [100%] ========================== 4 passed in 0.07 seconds ===========================
大家可以自己试试修改文件,函数,类名称,然后执行用例,查看是否会按照自己的想法执行用例!
总结
ok,通过这两篇文章,我们大概已经知道如何命名测试模块,测试类,测试函数,并且如何使用简单的命令行执行测试用例。那么就赶紧动手试试吧!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]