当前位置: 首页>编程语言>正文

pytest Test 开头的类中为什么不用有__init__方法 pytest 用例

今日分享主题:Python + Pytest 自动化框架中测试用例依赖的探索与实践,今天分享的内容以“依赖别名+scope=’package’”进行演示。

1、安装 pytest-dependency

安装命令:pip install pytest-dependency,它是一个 pytest 第三方插件,主要解决用例之间的依赖关系。

2、dependency 可作用的范围说明

(1).session:作用于全局,可跨目录调用。但被依赖的用例必须先执行,否则用例会执行跳过。

(2).package:作用于当前目录同级的依赖函数,跨目录无法找到依赖的函数。

(3).module:不传递scope,默认参数是'module',作用于当前文件,只会查找当前文件的符合条件的文件名,类里同名的方法不会被依赖。

(4).class:作用于所属的类,外部类不会被关联。

3、使用步骤

(1).首先,需要在用例开始的位置打上一个装饰器 @pytest.mark.dependency(),这是代表这条用例作为主条件,如果这条用例失败,关联它的用例会跳过执行。

(2).在被关联的用例上,也打上带参数的装饰器@pytest.mark.dependency(),depends 接受的参数是关联的依赖用例名。

(3).在 depends 也可以用别名的方式指定用例名。

4、代码演示 

test_dep_01.py:这是一个被依赖的文件,用来做权限检查的(这是我模拟的一个本地的 ip 访问校验使用的)

#test_dep_01.py文件内容如下:

import pytest
from commons.HandleJson import handle_json
import commons.configs as config
from commons.log import logger
from commons.HandleCompare import compareTest
from commons.ApiRequest import apiRequest

baseFileName = '../../testdata/check_premission_data.json'
testCaseData = handle_json.load_json(baseFileName)

class TestDep1():
    @pytest.mark.dependency(name='testUserCheck')
    @pytest.mark.parametrize('case_data', testCaseData['testcase'])
    def testUserCheck(self, case_data):
        api_response = apiRequest.api_request(config.apiurl, testCaseData, case_data)
        for case_validate in case_data['validate']:
            logger.info('断言期望相关参数:check:{},comparator:{},expect:{}'.format(case_validate['check'], case_validate['comparator'],case_validate['expect']))
            compareTest.compare_Assert(api_response, case_validate['check'], case_validate['comparator'],case_validate['expect'])

check_premission_data.json:用例数据文件只有1条用例,如下所示:

pytest Test 开头的类中为什么不用有__init__方法 pytest 用例,pytest Test 开头的类中为什么不用有__init__方法 pytest 用例_Python,第1张

test_dep_02.py:这个是依赖上面的代码内容,逻辑是当前面的检查校验通过后,才可以允许做登录。

#test_dep_02.py文件内容如下:

import pytest
from commons.HandleJson import handle_json
import commons.configs as config
from commons.log import logger
from commons.HandleCompare import compareTest
from commons.ApiRequest import apiRequest

baseFileName = '../../testdata/post_user_login_data.json'
testCaseData = handle_json.load_json(baseFileName)

class TestDep2():
    @pytest.mark.dependency(depends=["testUserCheck"], scope='package')
    @pytest.mark.parametrize('case_data', testCaseData['testcase'])
    def testUserLogin(self, case_data):
        api_response = apiRequest.api_request(config.apiurl, testCaseData, case_data)
        for case_validate in case_data['validate']:
            logger.info('断言期望相关参数:check:{},comparator:{},expect:{}'.format(case_validate['check'], case_validate['comparator'],case_validate['expect']))
            compareTest.compare_Assert(api_response, case_validate['check'], case_validate['comparator'],case_validate['expect'])

if __name__ == '__main__':
    pytest.main(['-sv'])

post_user_login_data.json:用例数据文件一共有4条用例,如下所示:

pytest Test 开头的类中为什么不用有__init__方法 pytest 用例,pytest Test 开头的类中为什么不用有__init__方法 pytest 用例_用例_02,第2张

5、执行test_dep_02.py文件结果如下

pytest Test 开头的类中为什么不用有__init__方法 pytest 用例,pytest Test 开头的类中为什么不用有__init__方法 pytest 用例_json_03,第3张

总结:

今天分享的是 Python + Pytest 框架中的用例依赖关系及使用


https://www.xamrdz.com/lan/5vg1934229.html

相关文章: