一、前言
上一篇内容介绍了用例编写的规则以及执行用例,执行用例时我们发现有些print输出内容,结果没有给我们展示,这是因为什么原因呢?接下来我们会针对这些问题进行阐述。
二、参数大全
我们可以在cmd中通过输入 pytest -h 或者pytest --help 来查看帮助里面打印出来的都有哪些参数:
1、参数打印
- general:
data:image/s3,"s3://crabby-images/953da/953da66eb03dc230b504e09fd8afed1a2d8c4b43" alt=""
- Reporting:
data:image/s3,"s3://crabby-images/f056a/f056aff21bca498ab9b19cbee6bc4732dfe903f5" alt=""
- pytest-warnings:
data:image/s3,"s3://crabby-images/16290/16290a718f3e29d82df7c4da8719b0ac0720e13f" alt=""
- collection:
data:image/s3,"s3://crabby-images/4171e/4171e62895360a26beaa8f114c2dc7416f4a2d36" alt=""
- test session debugging and configuration:
data:image/s3,"s3://crabby-images/ba36c/ba36c86f6fadb3d22fa0517fd0386ec6209c5ae4" alt=""
- logging:
data:image/s3,"s3://crabby-images/e4a4a/e4a4a0a4237df7d0e3e28e8ac18f4bbcf6bbbd53" alt=""
- reporting:
data:image/s3,"s3://crabby-images/9b11c/9b11c26625bd8815ad62436d4b0379727c7a84b9" alt=""
- pytest-metadata:
data:image/s3,"s3://crabby-images/cf54c/cf54cf2412b0724c12abf40c859700a217c7c57d" alt=""
- testreport:
data:image/s3,"s3://crabby-images/d9a94/d9a94a924b924031c8c4713db786d7697cdaa661" alt=""
- distributed and subprocess testing:
data:image/s3,"s3://crabby-images/8c00d/8c00d57a8e56eedc633d9165cba010bc2b09e5f5" alt=""
- [pytest] ini-options in the first pytest.ini|tox.ini|setup.cfg|pyproject.toml file found:
data:image/s3,"s3://crabby-images/b3551/b3551b7847fb5994667b1811b3b26211465f4ade" alt=""
data:image/s3,"s3://crabby-images/de9d0/de9d04f341a6f6b2985652d7ae02052d2493bf49" alt=""
- Environment variables:
data:image/s3,"s3://crabby-images/c71f1/c71f19a5e9969c7580e21ec5ecbdfe0f2884c8da" alt=""
2、常用的参数
1)pytest - s
-s:执行用例,携带详细信息,比如打印的print内容
通过cmd进行执行,发现已经详细内容展示出来了
data:image/s3,"s3://crabby-images/5fc38/5fc383959b9f80c4f38076d0038b668d4fbe6885" alt=""
2)pytest -x
-x:遇到错误的用例,立即退出执行,并输出结果
data:image/s3,"s3://crabby-images/e3e7e/e3e7e879cc056a50b5cde1a8aa981111038ab682" alt=""
从上图可以看到一共3条用例,执行了2条,其中执行到第2条的时候就已经程序就退出了。
3)pytest -k
-k:表示加需要执行的用例项,-k后面可以是测试函数名,也可以是类名,也可以是模块名,以及目录名称
data:image/s3,"s3://crabby-images/fe849/fe8498e80aac9009ed9b51ce73ad5321fabbe654" alt=""
也可以通过加入not来不执行一些用例,这里的not要和用例名放在一起用引号
data:image/s3,"s3://crabby-images/ba555/ba5555eb6a2a6fcf92ce17355c03b4fdeee59686" alt=""
4)pytest xxx.py
::类::用例:可以通过这种形式进行指定用例执行
data:image/s3,"s3://crabby-images/1fbc1/1fbc15f3a6e962fb3738c55670f01f4ada129a85" alt=""
5)pytest -m
-m:执行被标记的用例
标记需要用到pytest中的装饰器 @pytest.mark.标记名称
python
import pytest
class Test_01:
@pytest.mark.anjing
def test_001(self):
print('Test_01下的用例001')
assert 1 == 1
def test_002(self):
print('Test_01下的用例002')
assert 1 == 2
@pytest.mark.anjing
def test_003(self):
print('Test_01下的用例003')
assert 3 == 3
if __name__ == '__main__':
pytest.main()
data:image/s3,"s3://crabby-images/099fb/099fb2a08612e5c772c31aa606f3c24eb1634f12" alt=""
6)pytest -v
-v:表示查看详细的报告内容
data:image/s3,"s3://crabby-images/0cd79/0cd7966e4f479220c1c6b41e811df220fad665a3" alt=""
7)pytest -q
-q:表示简则的测试报告,运行成功通过"."表示,运行失败通过"F"表示
data:image/s3,"s3://crabby-images/92f20/92f20cf4fbe54bf018a0553ff5249553f1b0b7c2" alt=""
8)pytest --collect-only
--collect-only:表示把待执行的用例全部展示出来。
data:image/s3,"s3://crabby-images/82219/822195539e3364421c36e94d1d78f16db86a1345" alt=""
9)pytest --maxfail=n
--maxfail=n:其中n表示失败的次数,运行失败n次后,进行停止测试
python
# coding:utf-8
class Test:
def test_01(self):
print('这是用例01')
assert 1 == 1
def test_02(self):
print('这是用例02')
assert 1 == 2
def test_03(self):
print('这是用例03')
assert 3 == 4
def test_04(self):
print('这是用例04')
assert 4 == 4
data:image/s3,"s3://crabby-images/eed2f/eed2fc050bab60cafe95b6042d536a5a12ea0dc8" alt=""
10)pytest --lf
--lf:只执行上次失败的用例
data:image/s3,"s3://crabby-images/8491f/8491f231a0070ade86c357e0e029c2d7bd0cb0f1" alt=""
11)pytest --tb
--tb=no:不展示用例失败的错误详情
data:image/s3,"s3://crabby-images/0b231/0b231c9df5a569d9a25541773a3496f19ce2c6bc" alt=""
--tb=line:展示用例失败的代码具体行数。下图结果是在11行
data:image/s3,"s3://crabby-images/0deb7/0deb729a2644caf7e0368944b52e4f960e6e6214" alt=""
--tb=short:展示更加详细的错误信息
data:image/s3,"s3://crabby-images/36f86/36f8616b10b84e1bea291ef55dbd9869c39b9195" alt=""
12)pytest --durations
--duration=N:表示把最耗时间的用例展示出来,N表示最慢的N个
安静的代码运行都很快,把其中一个代码加上睡眠,从图中可以看出来,test_01文件中的test_03运行最慢。
data:image/s3,"s3://crabby-images/23f68/23f68f5d4c810b81f0f32fa1e22177962d0ef5d1" alt=""
上面简单描述了常用的一些参数,pytest插件多样,大家有想了解的可以参考官方文档。我后面也会有针对性的进行补充,敬请期待哈!