首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

通过JSONSchema完成接口自动化测试的数据验证

通过JSONSchema完成接口自动化测试的数据验证

一:什么是JSON Schema

JSON Schema,也称为JSON模式。JSON Schema是描述你的JSON数据格式;JSON模式(应用程序/模式+ JSON)有多种用途,其中之一就是实例验证。验证过程可以是交互式或非交互式的。

例如,应用程序可以使用JSON模式来构建用户界面使互动的内容生成除了用户输入检查或验证各种来源获取的数据。 一般使用JSON Schema来进行JSON数据格式验证,在数据提交到业务层次之前进行JSON格式的验证。

JSON Schema是基于JSON格式定义JSON数据结构的规范,用于描述现有的数据格式(JSON数据),清晰的人机可读文档:定义的JSON Schema具有人类和机器都可读的特性,使用JSON Schema可完成完整的JSON结构和数据验证,可用于自动化测试和确保客户提交的数据质量(如下我们只讨论在自动化测试中的应用)。

下面是一段JSON示例,文档中包含如下信息:一个老师的唯一标识符:teacherId,一个老师的名称:teacherName,老师的年龄:age,老师的标签:tags。

二:开始写JSON Schema

例子很简单,但是中间有些问题有待解决,这也是我们在自动化测试中可能会关注的信息,比如以下这些:

teacherId是什么?

teacherName是必需的吗?

龄字段age可以为0吗?

所有的标签都是字符串类型的值吗?

如果在自动化测试中需要来验证上述问题,方法一可以通过提取数据的方式完成。

参考之前的文章: 使用 JsonPath完成接口自动化测试中参数关联和数据验证 ,使用JsonPath更适合关键信息的提取和验证,JSON Schema更适合回答上面的这些问题。

三:JSON Schema关键词

首先我们从如下一些关键字开始:

$schema:该关键字声明该模式是根据标准的特定草案编写的,主要用于版本控制,可省略。

$id:该关键字定义模式的URI,可省略。

title和description:该JSON Schema的注释和描述信息,不会向验证的数据调节约束。

type:该关键字会定义JSON数据的第一个约束,比如是JSON对象还是数组。

针对上述JSON 案例初步编写的JSON Schema如下:

四:定义属性

teacherId属性:teacherId是老师的唯一标识符,是不可缺少的,teacherId类型是整型。

根据约束我们在上面JSON Schema更新如下:添加一个属性验证的关键字(key):properties

添加一个teacherId的key,描述和约束如下:

description:描述这个属性

type:属性类型

添加一个required关键字(key),在列表中加入teacherId,表示teacherId是必需的。

最后的JSON Schema如下:

teacherName 属性:teacherName是老师的名称,老师的名称也是一个老师必需的信息,老师的名称是字符串类型。

添加对teacherName属性的约束后,JSON Schema如下,其中:往properties中加入了teacherName的描述和约束信,往required列表中加入teacherName字段。

age属性:age字段是数值类型,使用number约束,约定柠檬班老师的年龄不能不能小于18岁,否则就算雇佣童工了,使用exclusiveMinimum关键字表示年龄必须大于18(不包含18),使用minimum关键字指定年龄最小为18岁(包含18岁) 升级后JSON Schema如下。

tags属性:老师标签不是必需的,如果有tags,那么至少要有一个标签,所有的标签必需要是唯一的,一个老师的标签不能重复,所有的标签必须要是文本。

JSON Schema需要做如下修改:在properties中添加一个tags属性,tags的类型设置为array,引入items的约束关键字定义数组中的元素,如下约束类型为string,引入minItems关键字用于约束数组中最少元素数量,引入uniqueItems关键字用于约束数组所有元素值是唯一的,因为tags可选的,所有在required中我们没有添加该属性

升级后JSON Schema如下

JAVA中的JSON Schema的校验,通过maven引入相关的jar包。

编写程序校验。

输出结果如下:

五:校验结果成功

最后校验的结果为true,表述校验通过。说明我们的JSON数据不管从结果还是数据上都是符合要求的。如果我们把老师的信息调整如下:

校验结果为:

六:校验结果失败

校验结果false,表述失败。处理报告中对校验不通过的地方也有原因描述,至此,大家可以在自己的自动化测试框架应用上JSON Schema。对响应结果为JSON格式的数据进行完整的结构和数据校验,

更多关于JSON Schema的知识可参考:

http://json-schema.org/

github:java-json-tools/json-schema-validator

如果这篇文章对你有帮助的话,就给我点个赞吧!欢迎关注点评,让我有动力为你们输出更多优秀的文章!

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20190103A0C7EU00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券