YApi旨在为开发、产品、测试人员提供更优雅的接口管理服务。能够帮助开发者轻松建立、发布、维护 API,包括提供了一系列可视化接口管理,还有自动化测试html
传统的接口自动化测试成本高,大量的项目没有使用自动化测试保证接口的质量,仅仅依靠手动测试,是很是不可靠和容易出错的。node
YApi 为了解决这个问题,开发了可视化接口自动化测试功能,只须要配置每一个接口的入参和对 RESPONSE 断言,便可实现对接口的自动化测试。并且大部分接口支持Swagger导入或者从Idea配置直接导入。大大提高了接口测试的效率。git
使用 YApi 自动化测试,第一步须要作得是建立测试集合和导入接口,点击添加集合建立,建立完成后导入接口(同一个接口能够屡次导入)。github
编写测试用例主要涉及两个方面,一个是请求参数,另一个是断言脚本。json
请求参数能够填写指望的字符串,YApi 还提供了 Mock 参数和 变量参数。Mock参数用来生成随机字符串,变量参数是为了解决请求参数依赖其余接口的返回数据或参数。api
Mock 参数每次请求都会生成随机字符串浏览器
YApi 提供了强大的变量参数功能,你能够在测试的时候使用前面接口的 参数
或 返回值
做为 后面接口的参数
,即便接口之间存在依赖,也能够轻松 一键测试~测试
Tips: 参数只能是测试过程当中排在前面的接口中的变量参数
格式:$.{key}.{params|body}.{path}
url
例如:现有两个接口,分别是“导航标题”和“文章列表”spa
文章列表接口须要传参数: 当前标题(id)
,而这个 id 须要经过 导航标题
的返回值获取,这时应在 文章列表
的参数输入框中根据前者的 key 找到对应 id。导航标题
的参数和返回值有以下结构:
参数:
返回值:
则 文章列表
的参数能够以下配置:
其中 $.** 是使用 **动态变量** 的标志,$.269.params 即表示 key 值为 269 用例的请求参数,$.269.body** 即表示 key 值为 269 用例的返回值。
若是 requestBody 是 json 格式也能够在 json 中写变量参数,以下图:
Tips: 上下拖动测试集合的列表项能够调整测试的顺序。
目前 yapi 中的query
,body
,header
和pathParam
的输入参数已经支持点击选择功能。无需本身填写表达式,只需在弹窗中选择须要展现的表达式便可。 输入选项包括常量
,mock数据
,在测试集合中也支持变量
选择。具体用法:单击编辑按钮打开表达式生成器,点击须要的数据建立表达式,这里也能够实时查看表达式结果。
Tips: 在测试集合中插入变量参数能够会出现下图的提示信息,这是正常现象。由于该参数只能在各个接口顺序执行的时候才能拉到变量参数中的值
编写完请求参数,可经过 js 脚本写断言,实现精准测试,在接口用例页面点击 Test 编辑。
在测试列表能够看到每一个测试用例的 key,还有 开始测试、报告等功能
点击开始测试会按照 case 定义的参数从上往下一个一个进行测试,若是顺序有问题,能够拖动调整
测试完成以后,点击报告查看该次请求的结果
参考:https://nodejs.org/dist/lates...
开始测试功能是在浏览器跑自动化测试,他依赖于浏览器的使用环境。服务端自动化测试功能是在YApi服务端跑自动化测试,不须要依赖浏览器环境,只须要访问 YApi 提供的 url 连接就能跑自动化测试,很是的简单易用,并且能够集成到 jenkins。
点击服务端测试,出现以下弹窗,用户访问该 url 就能够获取当前测试用例的全部测试结果。
而后能够在xxl-job添加这个脚本的地址,能够选择邮件通知,来进行定时的自动化测试
而后就能看到邮件了~
https://zhuanlan.zhihu.com/p/...