四、用例数据共享

问题1:接口响应参数提取,并应用于下个请求?同一个接口参数共享减少多余的接口调用?

解决问题:利用conftest.py全局配置文件在pytest中的特性 + globals()函数

 

conftest配置文件实现不同接口数据共享

这里我们利用pytest的conftest全局配置文件,定义我们需要的接口及返回提取的数据。

 

例如我们有以下场景:

实现获取作品详情的接口自动化,根据实际的业务场景,需要先保存作品,才能获取到该作品的详情。

那么我们在conftest文件定义保存接口及返回获取作品详情接口需要的参数。可以看到测试用例文件的第一条case,test_01在调用获取作品详情之前,先调用了定义在conftest文件下「保存作品接口」方法work

#!/usr/bin/python
# -*- coding: UTF-8 -*-
# @Author   :zaygee
# @time     :2020/12/9 14:09
# @file     :conftest.py

@pytest.fixture()
def work():
    """
    作品保存接口提取响应参数
    传入其他账号可添加请求头
    eg: headers= add_headers
    """
    def work_req(data, headers=None):
        if headers is None:
            headers = {'cookie': base.read_cookie()['cookie']}
        res = base.post_req(Work.URL, data=data, headers=headers)
        if res.status_code == 200:
            return base.extract(res.text, '$.id')
        else:
            raise Exception('提取[保存接口]响应参数失败')
    return work_req
# 获取作品详情接口测试用例集

@allure.feature("获取作品详情接口")
class TestKittenWorkIdeLoad:

    @classmethod
    def setup_class(cls):
        base.write_cookie()

    @classmethod
    def headers(cls):
        return {'cookie': base.read_cookie()['cookie']}

    @classmethod
    def load_req(cls, work_id, headers=None):
        if headers is None:
            headers = cls.headers()
        url = WorkIdeLoad.url(work_id)
        res = base.get_req(url, headers=headers)
        return res

    @allure.title("获取无标签作品")
    def test_01(self, work):
        """用例:获取kitten无标签作品>>预期:work_source_label =4"""
        work_id = work(Work().data())
        res = self.load_req(work_id)
        assert res.status_code == 200
        assert base.extract(res.text, '$.work_source_label') == 4

globals()实现相同接口数据共享

可以看下socket接口测试用例示例中,setup定义了基于当前测试用例集的全局变量self.g,后续其他用例如果需要用到此参数即可直接传入,减轻了重复调用接口造测试数据的负担。

@allure.feature("多人协作websocket接口")
class TestSocketCollaborate:
    @classmethod
    def setup_class(cls):
        “”“
        根据业务场景需要,
        调用登陆接口并将cookie、cookie的value写入文件
        ”“”
        base.write_cookie_value()
        base.write_cookie()
        
    @classmethod
    def headers(cls):
        “”“headers添加cookie”“”
        return {'cookie': base.read_cookie()['cookie']}
    
    @classmethod
    def cookie_value(cls):
        “”“读取cookie value用于请求参数”“”
        return base.read_cookie_value()['value']
    
    def setup(self):
        “”“当前环境下的全局变量,用于当前用例集数据共享”“”
        self.g = globals()
        
    @allure.title("传入协作作品的workId")
    def test_01(self, work, coll_work):
        data = Work().data()
        work_id = coll_work(work(data))  # 业务场景需要生成请求参数
        self.g['work_id'] = work_id # 设置全局共享数据
        coll_url = Req.url(work_id, self.cookie_value())
        wss = SocketCon.con(coll_url)
        wss.send('42["join",{}]'.format(work_id))   # 发送socket数据
        assert SocketCon.recv_log(wss, 4).split(',')[2].split(':')[1].strip("\""), True

 

总结

以上两种方式各有弊利,应用场景也不同,conftest配置文件一般用于不同用例文件下调用,可能会造型多次调用业务接口的“负担”。

setup方法或者setup_class方法下定义globals()函数,可实现同文件下数据共享,不过增强了用例之间的耦合,所以吧~可以根据实际合理应用!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值