扩展pytest接口自动化框架-MS数据解析功能

2023-09-22 14:48:26

【软件测试行业现状】2023年了你还敢学软件测试?未来已寄..测试人该何去何从?【自动化测试、测试开发、性能测试】

开篇
MeterSphere的数据源通过html页面上传后,需要将请求方式进行拆分。

get接口的参数,常以params的方式进行传参,也就是在url后带上参数。

post接口一般是以json字符串的形式传参,也有params方式进行传参的。而在MeterSphere里面,post可以使用它所自带的jsonSchema的界面功能来定义参数,也就是key-value的方式。也可以手写json。这里我们以jsonSchema的方式进行解析。

基于这两种类型的接口(put、delete接口也遵循get接口)来做分支。get接口走get接口参数的生成方法。post同理。

沿着这个思路,就开始着手准备自动化脚本逆向用例生成的第一个函数。

思路梳理
首先确定我们所想要的用例模板以及我们要解析的数据结构。我将两个数据结构的示例都列在了下面。
明确了目标,最先要做的,就是获取数据流
获取到数据流后,判断接口请求的类型
根据请求类型,将数据流分成不同的分支,然后发给所对应的生成参数的方法。
最后将这些参数拼接成我们想要的用例模板
下例为MeterSphere的json格式示例

{
  "projectName": "",
  "protocol": "HTTP",
  "projectId": ",
  "version": "v1.20.6-lts-1e3d1547",
  "data": [
    {
      "id": "",
      "projectId": "",
      "name": "测试",
      "method": "POST",
      "modulePath": "/path1/path2/...",
      "environmentId": null,
      "schedule": null,
      "status": "Underway",
      "moduleId": "",
      "userId": "admin",
      "createTime": 1655860767171,
      "updateTime": 1655860767171,
      "protocol": "HTTP",
      "path": "/api/v1/pub/stop",
      "num": 100666,
      "tags": null,
      "originalState": null,
      "createUser": "Administrator",
      "caseTotal": "0",
      "caseStatus": "-",
      "casePassingRate": "-",
      "deleteTime": null,
      "deleteUserId": null,
      "order": 3155000,
      "refId": "08f6bde7-c906-459d-8a9b-95632bbeb5ee",
      "versionId": "989beb9c-ebc8-45d3-8a80-967b06f2d192",
      "latest": true,
      "description": null,
      "request": "{name:ss,canshu:111}",
      "response": "respone",
      "remark": null
    }
  ],
  "cases": [],
  "mocks": [],
}

下例为最后解析成的用例样式

- api_name: callback_rooms
  case_name: $ddt{case_name}
  content_type: application/json
  parameterize:
  - - case_name
    - 字段1
    - 字段2
    - 字段3
  - - 常规用例
    - oU
    - 70
    - 79
  request:
    base_url: url...
    headers: null
    json:
      root:
        字段1: $ddt{字段1}
        字段2: $ddt{字段2}
        字段3: $ddt{字段3}
    method: POST
    url: /xxx/xxx
  validata:
  - contains: 200

得到MeterSphere数据并做解析

# 得到MeterSphere数据并做解析
def get_ms_data(filename):
    """
        get_data: 数据源
        apis: 接口清单
        get_params: get请求参数
        api_name: 接口名称
        method: 请求方式
        get_apis: get接口
    :return:拼接好的数据集
    """
    # 所有接口的字典数据集合
    apis = {}
    # 获取ms文件流
    with open(filename, "r", encoding="utf-8") as f:
        request_params = json.load(f)
    # 解析参数.判断接口是什么请求
    for i in request_params["data"]:
        get_data = i
        path = get_data["path"]
        api_name = str(path).split("/")
        if len(api_name) > 1:
            api_name = api_name[-2] + "_" + api_name[-1]
        else:
            api_name = api_name[-1]
        method = get_data["method"]
        get_apis = {
            path: {
                "api_name": api_name,
                "method": method,
                "content_type": "application/json"
            }
 
        }
        if method.lower() in ["get", "put", "delete"]:
            # 如果是get请求.调用解析get参数
            try:
              # 调用生成params参数
                get_params = get_arguments(json.loads(get_data["request"])["arguments"])
                get_apis[path].update(get_params)
                apis.update(get_apis)
            except Exception as e:
                print_log(Exception(e))
        else:
            try:
                # 兼容post接口中的请求参数是parasm类型
                if "arguments" in get_data["request"] and "jsonSchema" not in json.loads(get_data["request"])["body"]:
                  # 调用生成params参数
                    get_params = get_arguments(json.loads(get_data["request"])["arguments"])
                    get_apis[path].update(get_params)
                    get_apis[path]["content_type"] = "application/text"
                    apis.update(get_apis)
                else:
                  # 兼容post是jsonSchema对象的参数类型
                    if "jsonSchema" in json.loads(get_data["request"])["body"]:
                        try:
                            global NODE
                            NODE = True
                            post_params = deal_with_data(
                                data=json.loads(get_data["request"])["body"]["jsonSchema"],
                                required_list=json.loads(get_data["request"])["body"]["jsonSchema"][
                                    "required"])
                            get_apis[path].update(post_params)
                            apis.update(get_apis)
                        except KeyError:
                            post_params = deal_with_data(
                                data=json.loads(get_data["request"])["body"]["jsonSchema"])
                            get_apis[path].update(post_params)
                            apis.update(get_apis)
                    else:
                        print("测试")
                        # 后续迭代
                        ...
 
            except Exception as e:
                print_log(Exception(e))
                raise Exception(e)
    return apis

这个函数我把它构想成一个经理,接到需求后,根据每个人的职责不同,分给所对应的人。然后接收这些手下的工作反馈,把这些反馈组装成报告。

在编写过程中,只是一股脑的想把这件事做完。忽略了定义函数时需要遵循的单一职责原则(SRP原则,在python工匠中提到,每个函数应该遵循单一职责。这样方便后期维护)。上面这个函数,即做了类型判断的工作,也做了数据拼接、分配给指定函数的工作。这样如果要修改某一个职责的话。这个函数就需要做好整体维护的准备。基于此大家在编写函数的时候,也尽可能保证函数的单一职责。
下面是配套学习资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!

软件测试面试小程序

被百万人刷爆的软件测试题库!!!谁用谁知道!!!全网最全面试刷题小程序,手机就可以刷题,地铁上公交上,卷起来!

涵盖以下这些面试题板块:

1、软件测试基础理论 ,2、web,app,接口功能测试 ,3、网络 ,4、数据库 ,5、linux

6、web,app,接口自动化 ,7、性能测试 ,8、编程基础,9、hr面试题 ,10、开放性测试题,11、安全测试,12、计算机基础

 

文档获取方式:

这份文档,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!

更多推荐

WSUS 修补程序管理的替代方法

什么是WSUSWindowsServerUpdateServices(WSUS)是MicrosoftforWindowsServer提供的免费附加组件,WSUS从Microsoft更新中下载必要的修补程序和更新,并将其分发到Windows网络中存在的Windows操作系统和相关Microsoft应用程序。WSUS和SC

岩土工程安全监测中振弦采集仪连接振弦传感器时注意事项

岩土工程安全监测中振弦采集仪连接振弦传感器时注意事项岩土工程安全监测是保障工程稳定和安全的重要手段之一,而振弦采集仪则是岩土工程安全监测的常用设备之一,可以用于实时监测地下水位、土体变形、岩体应力等。其中,振弦传感器是振弦采集仪的核心部件之一,负责采集和传输振动信号。在连接振弦传感器时,需要注意以下几点。一、确定传感器

ChatGPT在职业规划中的智能助手

随着科技的不断发展,人工智能(AI)正逐渐成为我们日常生活的一部分。ChatGPT作为一种智能语言模型,可以在职业规划中充当智能助手的角色。本文将探讨ChatGPT在职业规划中的应用,以及它如何成为未来工作的智能伙伴。首先,ChatGPT可以提供职业发展的智能建议。通过与ChatGPT的交互,我们可以咨询关于职业发展的

企业进行品牌推广时怎么才能达到预期广告效应?不如试试软文营销

企业进行品牌推广的目的就在于提升品牌的曝光率,树立该品牌在市场中的形象,加强品牌的影响力与公信力,提高产品的竞争力,那么企业进行品牌推广时怎么才能达到预期效果呢,我们可以试试软文营销,接下来媒介盒子就告诉大家,企业如何利用软文营销来达到预期广告效应。一、 分析市场背景软文营销作为一种营销方式,需要我们在前期分

conda的安装和使用

参考资料:https://www.bilibili.com/read/cv8956636/?spm_id_from=333.999.0.0https://www.bilibili.com/video/BV1Mv411x775/?spm_id_from=333.999.0.0&vd_source=98d31d5c9db8

计算机视觉与深度学习-经典网络解析-AlexNet&ZFNet&VGG&GoogLeNet&ResNet[北邮鲁鹏]

目录标题参考文章LeNet5AlexNet参考文章AlexNet模型结构AlexNet共8层:AlexNet运作流程简单代码实现重要说明重要技巧主要贡献ZFNet主要改进减小第一层卷积核将第二、第三个卷积层的卷积步长都设置为2增加了第三、第四个卷积层的卷积核个数VGG参考VGG网络贡献使用尺寸更小的3×33\times

Vue前端框架11 组件事件与v-mode配合使用、组件数据传递(父传子)、插槽Slot、具名插槽、插槽中的数据传递(双向)

文章目录一、组件事件与v-model配合使用二、组件数据传递(子传父)三、插槽Slots四、具名插槽五、插槽中的数据传递一、组件事件与v-model配合使用组件A的数据变化组件B可以实时显示<template><h3>Main</h3><p>搜索内容为:{{search}}</p><component-b@search

c++文件服务器相关知识点记录-1

1.半同步/半异步模式半同步/半异步模式是一种多线程编程模式,其中一部分线程采用同步方式进行操作,另一部分线程采用异步方式进行操作。在半同步/半异步模式中,通常会有一个主线程和多个工作线程。主线程负责接收和分发任务,它会等待工作线程的完成,并且需要等待所有工作线程完成后才能终止。工作线程负责执行具体的任务,它们可以并行

TikTok的媒体革命:新闻业如何适应短视频时代?

在数字时代,媒体行业一直在不断演变和创新,以适应观众的变化需求和技术的发展。而在这个进化的过程中,短视频应用TikTok已经崭露头角,成为了一个重要的信息传播平台。这篇文章将深入探讨TikTok如何引领了媒体的一场革命,以及新闻业如何适应这个充满挑战和机会的短视频时代。TikTok:媒体的新宠TikTok的成功不仅体现

【xilinx】Versal启动文件简述 pdi bif

Versal启动文件简述FPGA开发圈2022-12-2216:09400浏览0评论0点赞作者:MacMahonStephen,AMD赛灵思开发者Versal™是由多个高度耦合的可配置块组成的自适应计算加速平台(ACAP)。这些块包括NoC、AIE、PL和CIPS(CIPS本身包含不同的域:LPD和FPD)等,启动这些

串口通信遇到的一个问题。

crash信息:W/System.err:java.io.IOException:writefailed:EAGAIN(Tryagain)W/System.err:atlibcore.io.IoBridge.write(IoBridge.java:531)W/System.err:atjava.io.FileOutpu

热文推荐