软件测试最全深入理解 pytest,软件测试编程零基础

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

import pytest
​
@pytest.mark.p0
def test_addition():
    assert 2 + 2 == 4
​
@pytest.mark.p1
def test_subtraction():
    assert 5 - 3 == 2
​
if __name__ == "__main__":
    pytest.main(["-m", "p0"])


在这个示例中,我们使用 @pytest.mark 装饰器为两个测试用例标记了不同的标记。然后,我们在 pytest.main 函数调用时传递了 -m p0 参数,表示只运行被标记为 p0 的测试用例。这样就可以只运行 test_addition 测试用例。

-k
import pytest
​
def test_addition():
    assert 2 + 2 == 4
​
def test_subtraction():
    assert 5 - 3 == 2
​
def test_multiplication():
    assert 2 * 3 == 6
​
if __name__ == "__main__":
    pytest.main(["-k", "addition"])


在这个示例中,我们定义了三个测试用例,分别测试加法、减法和乘法运算的正确性。然后,我们在 pytest.main 函数调用时传递了 -k addition 参数,表示只运行名称中包含 “addition” 关键字的测试用例。这样就可以只运行 test_addition 测试用例。

–ignore

test_demo.py

import pytest
​
def test_addition():
    assert 2 + 2 == 4
​
def test_subtraction():
    assert 5 - 3 == 2
​
if __name__ == "__main__":
    pytest.main(["--ignore=test_contract_controller.py"])


在这个示例中,我们定义了两个测试用例 test_additiontest_subtraction。然后,我们在 pytest.main 函数调用时传递了 --ignore=test_contract_controller.py 参数,表示忽略名为 test_contract_controller.py 的测试模块,不运行其中的测试用例。

–durations
import pytest
import time
​
def test_slow_function():
    time.sleep(2)
    assert True
​
def test_fast_function():
    assert True
​
if __name__ == "__main__":
    pytest.main(["--durations=5"])
​

在这个示例中,我们定义了两个测试用例,test_slow_functiontest_fast_function,分别模拟了一个耗时较长和一个耗时较短的测试。然后,我们在 pytest.main 函数调用时传递了 --durations=5 参数,表示输出最慢的 5 个测试用例的执行时间。这样可以帮助我们识别出执行时间较长的测试用例,进行性能优化或者重点关注。

–collect-only
import pytest
​
def test_addition():
    assert 2 + 2 == 4
​
def test_subtraction():
    assert 5 - 3 == 2
​
if __name__ == "__main__":
    pytest.main(["--collect-only"])

我们在 pytest.main 函数调用时传递了 --collect-only 参数,这样只会收集用例,而不会执行。

运行指定用例
运行指定目录下的case
pytest.main(["--collect-only", "/panda-test/peilian/test_dir/"])
运行指定模块下的case
pytest.main(["--collect-only", "/panda-test/peilian/test_dir/test_demo.py"])
运行指定的case
pytest.main(["--collect-only", "/panda-test/peilian/test_dir/test_demo.py::test_01"])
plugins参数

我们自定义的插件放到 conftest.py 会被pytest查找到,如果不是写到conftest.py 的插件内容,可以通过 plugins 参数指定加载。我们看个案例:

import pytest
​
​
class MyPlugin(object):
    def pytest_sessionstart(self):
        print("*** test run start ***")
​
​
def test_division():
    assert 10 / 2 == 5
​
​
if __name__ == "__main__":
    pytest.main(["/panda-test/peilian/test_dir/test_demo.py::test_division"], plugins=[MyPlugin()])

这里又涉及到一个新的钩子函数pytest_sessionstart,先不用管,之后写一篇文章来介绍。我们运行case,会发现在执行最开始会输出*** test run start ***。说明已经加载插件成功了。

plugins参数的作用就是指定需加载的插件,也可以指定多个。

最后

pytest.main 是一个非常有用的函数,它允许我们以编程的方式执行测试用例。通过灵活运用 pytest.main,我们可以更好地集成测试流程和自动化工具,提高测试效率和质量。

最后: 可以在我的VX公众号:【自动化测试老司机】免费领取一份216页软件测试工程师面试宝典文档资料。以及相对应的视频学习教程免费分享!,其中包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。

如果我的文章对你有所帮助的话,可以点赞三联支持一下哈!

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

到真正的技术提升。**

需要这份系统化的资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 16
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值