最最重要,处理case依赖、字段依赖

# -*- coding: utf-8 -*-
# @Time : 2020/2/13 21:14
# @File : data_depend_17.py
# @Author: Hero Liu
from day_20200208_mooc.tools.do_excel_openpyxl_14 import DoExcel
from day_20200208_mooc.base.interface_request_class_5 import RunMain
from day_20200208_mooc.tools.do_mock_18 import mock_test

class DependData:

    """
    case_id: 依赖case的id
    present_case_id: 当前case的id
    file: case数据来源file
    sheet:case数据来源sheet
    在需要完成“获取依赖case数据、执行依赖测试、返回依赖字段值、根据依赖字段对当前case发起请求”
    这一整套流程时,直接调用 run_present_case, 因为这个方法中已经包含了其他方法的调用
    """
    def __init__(self, case_id, present_case_id, file, sheet):
        self.case_id = case_id
        self.present_case_id = present_case_id
        self.file = file
        self.sheet = sheet

    # 根据依赖case_id去获取依赖的case数据
    def get_depend_case(self):
        depend_case = DoExcel().get_data(self.file, self.sheet)[self.case_id-1]
        return depend_case

    # 根据依赖的case数据,执行依赖测试
    def run_depend_case(self):
        header = None
        url = self.get_depend_case()["url"]
        method = self.get_depend_case()["method"]
        data = self.get_depend_case()["data"]
        header = self.get_depend_case()["header"]
        res = mock_test(RunMain().run_main, url, method, data, data, header)
        res["out_trade_no"] = "我是自定义的字段返回值"
        print("数据加成功了吗?", res)
        return res

    # 获取当前用例数据,即需要依赖的用例
    # present_case_id是当前的caseid,是需要用到依赖case的用例id
    # present_case_id-1是因为第n条用例在列表中的索引是n-1
    def get_present_case(self):
        present_case = DoExcel().get_data(self.file, self.sheet)[self.present_case_id-1]
        return present_case

    # 提取当前case的依赖数据,去依赖case里匹配结果, 得到值
    # 匹配时需要知道目标值的位置
    # 这里假设要匹配的值就是返回的json数据中第一个层级的某个键值,
    # 如果json数据有多层,根据实际情况修改
    # 注意依赖数据和依赖字段的关系
    # 依赖数据和依赖case的响应结果的字段是一样的
    # 依赖字段是当前case的请求数据中的一个字段
    # 依赖数据和依赖字段值是一样的,但是意义不同
    def get_depend_case_key(self):
        # 获取当前case的依赖数据,case_depend_data列即依赖数据, 即depend_key
        depend_key = self.get_present_case()["case_depend_data"]
        # 根据依赖key去依赖case匹配值,存到key_data
        key_data = self.run_depend_case()[depend_key]
        print("key data:", key_data)
        # 获取当前case的依赖字段key
        present_key = self.get_present_case()["depend_data_belong_new_key"]
        print("present_key:", present_key)
        # 依赖字段只是作为当前case请求数据中的一个字段,把这个字段更新到当前case的data数据中去
        # 通过添加键值的方式来更新
        print("数据类型:", type(self.get_present_case()["data"]))
        dic_ = self.get_present_case()["data"]
        dic_[present_key] = key_data
        print("请求字段添加成功了吗", dic_)
        return dic_

    # 根据依赖case字段的值对当前case发起请求
    def run_present_case(self):
        url = self.get_present_case()["url"]
        method = self.get_present_case()["method"]
        data = self.get_depend_case_key()
        header = self.get_depend_case()["header"]
        res = mock_test(RunMain().run_main, url, method, data, data, header)
        print("'函数里的响应数据", res)
        return res

MOOC(7)- case依赖、读取json配置文件进行多个接口请求-解决用例间依赖问题(17)的更多相关文章

  1. MOOC(7)- case依赖、读取json配置文件进行多个接口请求-读取json封装成类(13)

    把读取json数据的函数封装成类 # -*- coding: utf-8 -*- # @Time : 2020/2/12 16:44 # @File : do_json_13.py # @Author ...

  2. MOOC(7)- case依赖、读取json配置文件进行多个接口请求-openpyxl读取excel(14)

    从excel中读取数据 # -*- coding: utf-8 -*- # @Time : 2020/2/12 17:23 # @File : do_excel_openpyxl_14.py # @A ...

  3. MOOC(7)- case依赖、读取json配置文件进行多个接口请求-执行测试用例(16)

    执行测试用例 # -*- coding: utf-8 -*- # @Time : 2020/2/12 22:56 # @File : run_test_16.py # @Author: Hero Li ...

  4. MOOC(7)- case依赖、读取json配置文件进行多个接口请求-完整的测试类,含依赖测试(15)

    ddt.依赖测试.断言.测试数据写回 # -*- coding: utf-8 -*- # @Time : 2020/2/12 23:07 # @File : test_class_15.py # @A ...

  5. MOOC(7)- case依赖、读取json配置文件进行多个接口请求-发送测试报告邮件(19)

    给多个人发邮件时,可以传入邮箱列表 把多个收件人用分号隔开 # -*- coding: utf-8 -*-# @Time : 2020/2/15 17:02# @File : send_mail_19 ...

  6. MOOC(7)- case依赖、读取json配置文件进行多个接口请求-模拟接口响应数据(18)

    这里是把传入的请求数据作为响应值返回 # -*- coding: utf-8 -*- # @Time : 2020/2/15 9:47 # @File : do_mock_18.py # @Autho ...

  7. MOOC(7)- case依赖、读取json配置文件进行多个接口请求-xlrd操作excel(11)

    xlrd操作excel # -*- coding: utf-8 -*- # @Time : 2020/2/12 9:14 # @File : do_excel_xlrd_11.py # @Author ...

  8. MOOC(7)- case依赖、读取json配置文件进行多个接口请求-测试类中调用封装的mock(10)

    封装mock后,在单元测试中调用 # -*- coding: utf-8 -*- # @Time : 2020/2/11 8:35 # @File : test_class_10.py.py # @A ...

  9. MOOC(7)- case依赖、读取json配置文件进行多个接口请求-封装mock(9)

    封装mock # -*- coding: utf-8 -*- # @Time : 2020/2/12 8:51 # @File : mock_demo_9.py # @Author: Hero Liu ...

随机推荐

  1. 测网速 fping Linux查看网络即时网速 linux性能问题(CPU,内存,磁盘I/O,网络)

    Linux查看网络即时网速 fping 是ping 工具的加强版本 例出局域网中存活的主机 (Ubuntu apt-get装上  cnetos装不上) zzx@zzx11:~$ fping -a 19 ...

  2. 创建DateFrame的常用四种方式

    import pandas as pd %pylab 一.使用numpy创建 df = pd.DataFrame(np.arange(16).reshape((4,4)), index=list('a ...

  3. CSS 之pseudo-classes 与pseudo-element的异同

    从W3School找到相关资料如下: 伪类: 伪类存在的意义是为了通过选择器找到那些不存在与DOM树中的信息以及不能被常规CSS选择器获取到的信息. 伪类由一个冒号:开头,冒号后面是伪类的名称和包含在 ...

  4. Spring Cloud Alibaba 教程 | Nacos(五)

    扩展配置(extended configurations) 通过之前的学习,我们知道应用引入nacos配置中心之后默认将会加载Data ID= ${prefix} - ${spring.profile ...

  5. python使用进程池多进程时,如何打印错误信息

    一.说明 1.python进程池进行多进程运行时,如果有错误,该进程会直接跳过,并且不会打印错误信息. 2.如果需要了解到进程内的错误信息,此时就需要通过捕获异常来输出错误信息了. 二.具体方法如下: ...

  6. Djang_框架

  7. 二分查找(python)

    #!/usr/bin/env python # -*- coding: utf-8 -*- # @Time : 2018/4/29 9:11 # @Author : Jackendoff # @Sit ...

  8. RSAUtils加密解密

    import org.apache.commons.codec.binary.Base64; import org.apache.commons.io.IOUtils; import javax.cr ...

  9. 分布式ID的简单总结

    来源:郴州网站优化 简单总结一下流行的分布式id的实现方法 雪花算法 snowflake是twitter开源的分布式ID生成算法. 核心思想是:分布式ID固定是一个long型的数字,一个long型占8 ...

  10. 爬虫基本库request使用—爬取猫眼电影信息

    使用request库和正则表达式爬取猫眼电影信息. 1.爬取目标 猫眼电影TOP100的电影名称,时间,评分,等信息,将结果以文件存储. 2.准备工作 安装request库. 3.代码实现 impor ...