Pytest参数详解 — 基于命令行模式

1、--collect-only

查看在给定的配置下哪些测试用例会被执行

2、-k

使用表达式来指定希望运行的测试用例。如果测试名是唯一的或者多个测试名的前缀或者后缀相同,可以使用表达式来快速定位,例如:

命令行-k参数.png

3、-m

标记(marker)用于标记测试并且分组,以便快速选中并运行。使用 @pytest.mark 来标记。

可以使用 -m "mark1 and mark2" 同时选中贷有这两个标记的所有测试用例。
使用 -m "mark1 and not mark2" 则会选中有mark1的测试用例,而过滤掉 mark2 的测试用例。
使用 -m "mark1 or mark2" 选中带有 mark1 或者 mark2 的所有测试用例
4、-x

正常情况下 pytest 会运行每一个搜集到的测试用例。如果某个测试用例断言失败,或者触发了异常,那么该测试用例的运行就会到此停止。pytest 会将其标记为失败后继续运行下一个测试用例。但是在 debug 时,如果需要遇到失败立即停止整个会话可以加上 -x。调试完成后可以去掉 -x,可以使用 -tb=no 关闭错误信息回溯。

5、--maxfail=num

-x 是遇到失败就停止运行,而 --maxfail 则可以指定允许失败几次,达到最大失败次数以后停止运行

6、-s 与 --capture=method

-s 等价于 --capture=no ,关闭了输出捕获。正常情况下,任何符合标准的输出流信息都会被捕获。--capture=fd 时,若文件描述符(file descriptor)为1或者2,则会被输出至临时文件中。使用 --capture=sys 时sys.stdout/stderr 将会被输出至内存。

7、-l/--showlocals

在测试失败时会打印出局部变量名和他们的值以避免不必要的 print 语句

8、--if/--ff

当一个或者多个测试用例失败时,如果希望定位到最后一个失败的用例重新运行,可以使用 --lf。--ff 与 --lf 基本相同,不同的在于 --ff 会运行完剩余的测试用例

9、-v

使得输出信息更详细,不加的情况下每个文件显示一行,加了以后每条用例显示一行,测试名与结果都会显示出来而不仅仅是一个点或者一个字符

10、-q

与 -v 相反,简化输出信息。

11、--tb=style

--tb=style:决定捕捉到的失败时输出信息的显示方式。
--tb=no:屏蔽全部回溯信息
--tb=line:打印错误的位置
--tb=short:较 no 和 line 更详细,给出错误信息
--tb=long:输出最为详细的信息
--tb=auto:默认值,如果有多个用例失败,仅打印第一个和最后一个用例的回溯信息,格式为 long
--tb=native:只输出 Python 标准库的回溯信息
12、--duration=N

可以加快测试节奏,统计测试过程中哪个阶段时最慢的,包括测试用例的 call、setup、teardown。他会显示最慢的 N 各阶段,耗时越长越靠前,如果 N = 0,则会将所有阶段按照耗时从长到短排序后显示

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
pytest参数化是pytest框架提供的一种功能,可以在测试用例中使用多组数据进行测试,以便更全面地验证代码的正确性。参数化的使用方式有多种,包括装饰器、fixture等,下面是使用装饰器方式的详解。 首先,我们需要安装pytest库: ``` pip install pytest ``` 然后,在测试文件中引入pytest库: ```python import pytest ``` 接下来,我们定义一个测试函数,并使用@pytest.mark.parametrize装饰器对该函数进行参数化: ```python @pytest.mark.parametrize("num1, num2, result", [(1, 2, 3), (2, 3, 5), (3, 4, 7)]) def test_add(num1, num2, result): assert num1 + num2 == result ``` 上述代码中,我们定义了一个名为test_add的测试函数,该函数接受三个参数:num1、num2和result。然后,我们使用@pytest.mark.parametrize装饰器来对该函数进行参数化,传入了三组数据,分别是(1, 2, 3)、(2, 3, 5)和(3, 4, 7)。这样,pytest就会遍历这三组数据,按照num1、num2、result的顺序依次传入test_add函数中进行测试。 最后,我们可以使用pytest命令来运行测试: ``` pytest test_demo.py ``` 运行结果如下: ``` collected 3 items test_demo.py ... [100%] =================================== 3 passed in 0.01s =================================== ``` 可以看到,三个测试用例都通过了。其中,第一个测试用例传入的是(1, 2, 3),即1+2=3,符合预期;第二个测试用例传入的是(2, 3, 5),即2+3=5,也符合预期;第三个测试用例传入的是(3, 4, 7),即3+4=7,同样符合预期。 通过上述示例,我们可以看到pytest参数化的使用非常简单,只需要在测试函数上添加@pytest.mark.parametrize装饰器即可。另外,如果需要使用fixture来传递参数,也可以通过pytest.fixture装饰器来实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值