美文网首页
python自动化框架pytest(四)--其他

python自动化框架pytest(四)--其他

作者: 小啊小狼 | 来源:发表于2020-10-21 09:48 被阅读0次

    一、pytest中的skip和xfail

    skip 跳过测试函数

    skip 意味着您希望只有在满足某些条件时测试才能通过,否则pytest应该跳过运行测试。常见的例子是跳过非Windows平台上的仅限Windows的测试,或者跳过依赖于当前不可用的外部资源(例如数据库)的测试。

    (1)skip

    跳过测试函数的最简单方法是用 skip,可以传递可选参数 reason :

    import pytest
    
    @pytest.mark.skip(reason="此用例跳过")
    def test_001():
        print("测试用例1")
        assert 1 == 1
    def test_002():
        print("测试用例2")
        assert 1 == 1
    def test_003():
        print("测试用例3")
        assert 1 == 1
    
    if __name__ == '__main__':
        pytest.main(["-s", "demo.py","-v"])
    

    输出:

    collecting ... collected 3 items
    
    demo.py::test_001 SKIPPED
    demo.py::test_002 测试用例2
    PASSED
    demo.py::test_003 测试用例3
    PASSED
    
    ======================== 2 passed, 1 skipped in 0.06s =========================
    
    (2)skipif

    如果您希望有条件地跳过某些内容,则可以使用 skipif

    方法:
         skipif(condition, reason=None)
     参数:
         condition:跳过的条件,必传参数
         reason:标注原因,必传参数
     使用方法:
         @pytest.mark.skipif(condition, reason="xxx")
    

    xfail 将测试功能标记为预期失败

    xfail 意味着您希望某个测试由于某种原因而失败。一个常见的例子是对尚未实现的特性或尚未修复的错误的测试。当测试通过时,尽管预期会失败(标记为 pytest.mark.xfail 这是一个 XPASS 并将在测试总结中报告。

    方法:
         xfail(condition=None, reason=None, raises=None, run=True, strict=False)
     常用参数:
         condition:预期失败的条件,必传参数
         reason:失败的原因,必传参数
     使用方法:
         @pytest.mark.xfail(condition, reason="xx")
    

    示例:

    import pytest
    
    def test_001():
        print("测试用例1")
        assert 1 == 1
    
    @pytest.mark.xfail(2>1,reason="标记为xfail")
    def test_002():
        print("测试用例2")
        assert 1 == 1
    def test_003():
        print("测试用例3")
        assert 1 == 1
    
    if __name__ == '__main__':
        pytest.main(["-s", "demo.py","-v"])
    

    输出:

    collecting ... collected 3 items
    
    demo.py::test_001 测试用例1
    PASSED
    demo.py::test_002 测试用例2
    XPASS
    demo.py::test_003 测试用例3
    PASSED
    
    ======================== 2 passed, 1 xpassed in 0.09s =========================
    

    二、pytest的conftest.py介绍

    conftest.py就是存放fixture的地方。准确的说,是存放自定义fixture的地方。

    conftest.py的作用范围

    其作用范围是当前目录包括子目录里的测试模块。
    比如在测试系统的根目录创建conftest.py文件,其文件中的fixture的作用范围是所有测试模块。
    比如在某个单独的测试文件夹里创建conftest.py文件,该文件中fixture的作用范围就仅局限于该测试文件夹里的测试模块。该测试文件夹外的测试模块或者该测试文件夹外的测试文件夹,是无法调用到这个conftest.py文件中的fixture。
    Tips:如果测试根目录和测试子目录都有conftest.py,并且这两个conftest.py中都有一个同名的fixture,测试子目录中的测试用例使用这个命名的fixture,实际生效的是测试子目录下的conftest.py中的fixture。

    conftest.py的注意事项

    1.conftest.py是python的模块,但是不能被导入。import conftest操作是非法的。
    2.建议把测试项目的所有fixture都存放在conftest.py中,把conftest.py当作pytest的fixture仓库。
    3.如果希望fixture共享给所有测试,则把该fixture放在测试根目录下的conftest.py是最合适的。

    相关文章

      网友评论

          本文标题:python自动化框架pytest(四)--其他

          本文链接:https://www.haomeiwen.com/subject/ggvkmktx.html