• pytest(3)测试命名规则


    前言

    在自动化测试项目中,单元测试框架运行时需要先搜索测试模块(即测试用例所在的.py文件),然后在测试模块中搜索测试类或测试函数,接着在测试类中搜索测试方法,最后加入到队列中,再按执行顺序执行测试。

    所以,只有测试模块、测试类/测试函数、测试方法都符合命名规则,框架才能去识别测试用例。

    那么,接下来我们来了解 pytest 框架中的测试命名规则。

    命名规则

    在了解pytest的测试命名规则之前,我们先需要知道 pytest 搜索用例的规则,它默认搜索规则如下:

    • 如果pytest执行命令中指定了目录,则从该指定目录中开始查找测试用例文件,如果没有指定,则从当前运行目录开始查找文件,最终的结果是找到整个项目中符合命名规则的测试用例。
    • 会查找整个项目中符合命令规则的测试模块,再由 测试模块-->测试类/测试函数-->测试方法 一层一层递归查找。

    默认命名规则

    pytest 的测试命名规则如下:

    • 测试模块:以 test_ 开头命名,如:test_login.py,或以 _test 结尾,如:login_test.py
    • 测试类:必须以Test开头命名,且测试类中不能有 init 方法
    • 测试方法/测试函数:必须以test开头,如:test_login() 或 testRegister()

    最好是将测试模块、测试方法/函数都以 test_ 开头命名,这样可读性更强,如下图:

    自定义命名规则

    pytest 框架可以通过pytest.ini配置文件自定义命名规则,在某些特定场景下可能会用到。

    在测试项目的根目录下创建pytest.ini文件,并进行如下配置:

    [pytest]
    # 更改测试模块命名规则
    python_files = CS*
    # 更改测试类命名规则
    python_classes = CS*
    # 更改测试方法/测试函数命名规则
    python_functions = CS*
    

    注意,在.ini文件中直接使用中文注释执行的时候会报错,实际使用如上代码时,需要将中文注释去掉。

    新建测试模块CS_register.py,示例如下:

    import pytest
    import requests, json
    
    class CSRegister:
    
        def CS_register(self):
            '''注册用户'''
            headers = {"Content-Type": "application/json;charset=utf8"}
            url = "http://127.0.0.1:5000/register"
            data = {
                "username": "张学友",
                "password": "123456",
                "sex": "0",
                "telephone": "13823456789",
                "address": "北京东城区"
            }
            res = requests.post(url=url, headers=headers, json=data).text
            res = json.loads(res)
            assert res['code'] == 0
    
    
    if __name__ == '__main__':
        pytest.main()
    

    执行结果如下:

    除非是特殊情况,否则不太建议自定义命名规则。

    总结

    从个人实际经验来看,不管是pytest还是unittest自动化项目,命名方式最好如下:

    1. 测试模块名以test开头,如 test_login.py
    2. 测试类名以Test开头,如 TestLogin()
    3. 测试函数/方法名以test开头,如 test_login()

    这样的命名方式,既简单又清晰,而自定义命名其实较为少用,除非项目比较特殊。

  • 相关阅读:
    [译]Node.js Interview Questions and Answers (2017 Edition)
    XUnit
    Inline Route Constraints in ASP.NET Core MVC
    [译]Object.getPrototypeOf
    [译]IIS 8.0应用初始化
    C++的那些事:你真的了解引用吗
    C++的那些事:表达式与语句
    C++的那些事:数据与类型
    神经网络:卷积神经网络
    图像分析:投影曲线的波峰查找
  • 原文地址:https://www.cnblogs.com/lfr0123/p/15888563.html
Copyright © 2020-2023  润新知