当前位置: 首页 > news >正文

【接口自动化测试】---YAML、JSON Schema

目录

1、YMAL

2、JSON Schema

2.1、为什么要使用JSON Schema?

2.2、数据类型

2.3、给校验值进行约束:

2.3.1、最小值和最大值:

2.3.2、字符串特殊校验:

2.3.3、数组

2.3.4、对象约束

2.4.5、必需属性

2.4.6、依赖关系


1、YMAL

YAML语言类似于XML和JSON文件,但是使用更简洁的语法。不是编程语言,主要用于存储配置信息。

配置文件:
pytest.ini-----配置一些参数 

yaml文件通常作为配置文件。可以使用yaml库来写入或者读取YAML文件

pip install PyYAML==6.0.1

读取和写入yaml文件:

import yaml
# 追加写⼊
def write_yaml(filename, data):with open(filename, encoding="utf-8", mode="a+") as f:#使用with打开文件yaml.safe_dump(data, stream=f) #使用yaml.safe_dump将数据写入文件流f#会将data转化为yaml格式的字符串并写入文件# 读取
def read_yaml(filename, key):with open(filename, encoding="utf-8", mode="r") as f:data = yaml.safe_load(f)#使用yaml.safe_load解析文本内容:将ymal格式统一转换为python字典/列表;safe_load避免了恶意加载文件的风险return data[key]#返回解析之后数据key对应的值# 清空
def clear_yaml(filename):with open(filename, encoding="utf-8", mode="w") as f:f.truncate()#调用truncate()方法清空文件内容(即使文件原本有内容,也会被清空为 0 字节)。def test_yml():#写⼊yaml⽂件data = {"str":"12345"}write_yaml('test.yml',data)#读取yaml⽂件ret = read_yaml('test.yml',"str")print("ret:", ret)#清空yaml⽂件clear_yaml('test.yml')

书写不同:

注意:YAML冒号之后都有空格

列表:列表中的每一项换行写,每行前面都要加上- 和空格,同时注意缩进。

注意:记住列表和字典格式即可!

如果有复杂的json格式怎么办?

可以使用工具进行转:(转完之后记着要检查)

https://www.jashtool.com/json/to-yaml

2、JSON Schema

2.1、为什么要使用JSON Schema?

JSON Schema⼀个⽤来定义和校验JSON的web规范,简⽽⾔之,JSON Schema是⽤来校验json是否符合预期
接口返回值校验:
1、校验关键字段的值(但是会漏掉一些重要字段/值的校验)
2、json返回值完整校验(但是万一很多要写很多)
必须要校验所有的值是固定信息的话是不现实的,接口的返回值对应的值每次可能是不同的,但是同一个接口返回的字段名一定是不变的。

因此大多数需要校验:

校验接口返回值:
1、需要返回的字段是否都存在
2、返回的值的类型是否正确

因此我们就要需要使用JSON Schema

下载:pip install jsonschema==4.23.0

json转接送schema太麻烦了,我们就可以使用现成的工具。(注意转完之后要进行检查)在线JSON转Schema工具 - ToolTT在线工具箱

检验博客列表页返回的json数据:

import requests
from jsonschema.validators import validate
def test_json():schema = { "type": "object","required": [],"properties": {"code": {"type": "string"},"errMsg": {"type": "string"},"data": {"type": "array","items": {"type": "object","required": [],"properties": {"id": {"type": "number"},"title": {"type": "string"},"content": {"type": "string"},"userId": {"type": "number"},"deleteFlag": {"type": "number"},"createTime": {"type": "string"},"updateTime": {"type": "string"},"loginUser": {"type": "boolean"}}}}}}url = "http://8.137.19.140:9090/blog/getList"header = {"user_token_header": "eyJhbGciOiJIUzI1NiJ9.eyJpZCI6MSwidXNlck5hbWUiOiJ6aGFuZ3NhbiIsImV4cCI6MTc0MDczOTIzOH0.lYiI6 - fPBqIyTVItvUQRyD7OKruSXR6I5tNOEmorWw8"}r = requests.get(url=url, headers=header)validate(r.json(), schema)#通过r.json()可以打印当前的返回值信息#将返回的json和jsonschema进行匹配。  上面的jsonschema的格式可以通过复制我们的返回值,去工具里面进行转换

那么jsonschema到底要怎么写?

2.2、数据类型

integer表示整数,而number表示数字,可以是整数、浮点数。。。

当pycharm有时候缓存出现问题,导致无法出现代码补全----重建项目索引

2.3、给校验值进行约束:

2.3.1、最小值和最大值:

JSON Schema:

{"type": "object","properties": {"age": {"type": "integer","minimum": 0,"maximum": 120}}
}

2.3.2、字符串特殊校验:

pattern :使⽤正则表达式来验证字符串是否符合特定的模式。
\s:匹配所有的空白符,包括换行
\S:非空白字符,不包括换行
限定字符串长度:\S{3,}  最少匹配是3个字符,最多不受限制
\S{3,6}:最少匹配是3个字符,最多匹配6个字符

JSON Schema:

{"type": "object","properties": {"email": {"type": "string"},"username": {"type": "string","pattern": "\S+"}}
}

2.3.3、数组

"uniqueItems": True  数组的元素必须是唯一的

 "minItems": 1, 数组的最小长度

minItems 和 maxItems :指定数组的最⼩和最⼤⻓度。
uniqueItems :确保数组中的元素是唯⼀的。 数组中的元素是否可以重复
uniqueItems设置为True表示元素必须是唯一的,设置为False表示元素可以是唯一的(也可以是不唯一的)     默认情况,允许存在重复的数据。
items :定义数组中每个元素的类型和约束。   数组中元素的类型

JSON Schema:

{"type": "object","properties": {"tags": {"type": "array","items": { "type": "string" },"minItems": 1,"uniqueItems": True}}
}

2.3.4、对象约束

"additionalProperties": False 放在哪就限制的是哪个层级的字段

"minProperties": 1  最小的属性数量

minProperties maxProperties :指定对象的最⼩和最⼤属性数量。
additionalProperties :控制是否允许对象中存在未在 properties (这是JSON schema中的属性)中定义的额外属性,默认为True。(默认是允许在json返回数据里面存在未在schema中的properties中的)

JSON Schema:

{"type": "object","properties": {"name": { "type": "string" }},"minProperties": 1,"additionalProperties": False #设置为False 不允许在json返回值中出现 没有在properties中写的参数
}

注意:配置里面不要存在其他字符或者空格,会导致识别不出来当前的配置,意味着配置是失效的。

2.4.5、必需属性

通过required关键字,JSON Schema可以指定哪些属性是必须的。如果JSON属性中缺少这些必须属性,则验证失败。 如果不加的话,你没有返回也会认为是正确的。

{"type": "object","properties": {"name": { "type": "string" },"email": { "type": "string" }},"required": ["name", "email"]
}

2.4.6、依赖关系

dependentRequired可以定义属性之间的依赖关系。例如,如果某个属性存在,则必须存在另一个属性

{"type": "object","properties": {"creditCard": { "type": "string" },"billingAddress": { "type": "string" }},"dependentRequired": {"creditCard": ["billingAddress"]}
}

补充:若没有返回前者,后者字段返回不返回都可以

http://www.dtcms.com/a/326694.html

相关文章:

  • 逐际动力开源运控 tron1-rl-isaacgym 解读与改进
  • VMD例程(Matlab 2021b可直接使用)
  • 从“目标烂尾”到“100%交付”:谷歌OKR追踪系统如何用“透明化+强问责”打造职场责任闭环
  • 小白入门指南:Edge SCDN 轻松上手
  • Dify 从入门到精通(第 28/100 篇):Dify 的多租户架构
  • 【学习嵌入式day-21-Linux编程-shell命令】
  • 第九篇:调试工具:Three.js Inspector使用
  • 武汉火影数字|VR大空间是什么?如何打造VR大空间项目
  • 【华为机试】648. 单词替换
  • SciChart图形库应用
  • 专题:2025人形机器人与服务机器人技术及市场报告|附130+份报告PDF汇总下载
  • TCGA数据集下载工具gdc-client下载慢解决方案
  • mysql参数调优之 innodb_buffer_pool_size和innodb_buffer_pool_instances (三)
  • Java AI生成长篇小说的实用
  • VirtualBox虚拟机网卡配置
  • NR,LTE基于CSI的PMI-RI码本选择
  • 【算法训练营Day23】贪心算法part1
  • nginx高新能web服务器
  • UVM验证—UVM 简述
  • 从0-1搭建webpack的前端工程化项目
  • MySQL杂项
  • OpenBMC中phosphor-dbus-interfaces深度解析:架构、原理与应用实践
  • 安装AI高性能推理框架llama.cpp
  • Untiy_SpriteShape
  • VSCode编辑器常用24款基础插件
  • QT QVersionNumber 比较版本号大小
  • 自主泊车算法
  • OFD一键转PDF格式,支持批量转换!
  • 客户端连接redis,redis如何配置
  • 钓鱼鱼饵制作的方式(红队)