如何高效优雅地管理接口文档

简介: 你是一个测试,你们团队目前开发模式是前后端分离。

 前言

你是一个测试,你们团队目前开发模式是前后端分离。

某一天,版本V1.0接口评审完,发布在了swagger上,前后端各自进行开发。此时你根据接口文档将新接口迁移到JMeter上,然后开始编写接口测试用例。

过了几天,前端先提测了APP,怎么测试前端效果呢, 你想到使用charles抓包,造一些假数据,然后改响应数据。然而界面情况有点多,数据准备起来有点繁琐。这时前端同学向你介绍了Mock工具Rap,他们把接口放在上面,编写mock规则,获得模拟数据进行前端调试。虽然数据也不是很真实,但是类型和结构是对了。

image.gif编辑

又过几天,后端终于提测,连接到测试服务器上运行接口用例,有个接口报错,前端打开价格页也有些显示错乱。你淡定地抓包看数据,查了一下接口文档,原来是后端返回的字段类型错了,于是你在jira上提了bug给后端同学,并有理有据粘贴了文档截图和抓包截图。

\

image.gif编辑

后端同学过了一会跑过来告诉你,”这个字段有变更,我在Postman调试通过的,忘记改文档和通知你们啦,麻烦你转给前端吧。“

后端很无辜,前端很无奈,你心很累,然而只能默默改用例。

\

image.gif编辑

又过了一段时间,你发现,有些自动化用例跑不动了,原来是隔了很久,接口的变动有些没来得及改,脚本的数据跟文档差异变多,看来还要专门找时间检查接口的差异。可是刚好有新人入职,还要给他培训JMeter的用法,看来这周又要加班了 。

你有没有想过,这一切的一切都是因为你的团队没有用过一个可以同时解决数据同步、调试、Mock、自动化测试的 接口文档管理工具。咦,你问我是什么神器吗,那我就告诉你

image.gif编辑

什么是Apifox

Apifox是一个集API 文档管理、接口调试、Mock功能、测试于一体的研发协作平台,简单来说Apifox 是 Postman + Swagger + Mock + JMeter的有机结合,整合多种接口管理流程,为研发团队提供一个开箱即用的Api流程管理的可视化工具。

为什么选Apifox

我们常常讨论敏捷开发、使用数字化工具实现研发项目流程管理。但是在API管理这一块却还处于前、后端、测试各自孤岛式管理的境况:

    • 后端开发通过Swagger管理接口文档,然后通过Postman调试接口
    • 前端开发通过RAP等工具做Mock 接口数据
    • 测试通过JMeter、HttpRunner等工具做接口自动化测试、压力测试

    这种模式下,最突出的问题是数据同步问题,几个工具之间数据彼此隔离,不同的角色各自维护一份接口数据,因接口变更未及时同步导致前后端联调失败、或测试用例失效的情况屡屡发生。因此只有将接口数据中心化,围绕着接口文档,各个角色在同一平台上进行协作,才能最大提升研发效能。因此Apifox的优势非常明显:

    1、数据同步:接口数据发生变更实时自动同步到用例、mock服务,不同角色之间无需再关注数据一致性问题,从而高效管理接口文档;

    2、跨部门协作:平台的测试用例、mock规则、公共脚本等数据可以团队内共享,实现数据沉淀,减少重复工作;

    3、降本提效:常用功能(断言、数据库操作、数据提取等)有便捷的可视化操作,小白也能参与文档管理和自动化测试,避免重复造轮子,降低研发成本,使得研发可以专注于各自的工作。

    Apifox初体验

    话不多说下面带大家上手体验,看一下Apifox是如何兼顾**接口文档管理工具接口文档生成工具接口Mock工具接口调试工具接口自动化测试工具**等多重身份的

    安装注册

    Apifox 是跨平台的工具,支持macOS(Intel+M1)、Linux、windows(32位、64位),在**官网**选择对应系统的安装包下载安装即可用。

    首次使用,可以使用邮箱注册或直接通过微信登录。

    登录apifox,可以看到当前用户加入的团队列表和团队项目列表。点击项目右侧的小飞机设置直达,下次打开Apifox可直达该项目。

    image.gif编辑

    接口文档管理

    我们进入宠物店项目,如下所示:左侧是以树状聚合的接口列表,层级为分类(可多级分类)->接口->用例,三个层级均支持一键复制、删除,列表拖拽修改排序。右侧是项目概览页,可以设置在线文档分享给团队成员或合作伙伴。

    image.gif编辑

    双击接口,右侧显示接口文档页,接口的基本信息、请求参数格式、响应数据格式、示例值。

    image.gif编辑

    点击修改文档/新建接口,可以编辑接口的信息。如图我们编辑登录的接口信息,字段都可以编辑示例值和说明,字段类型下拉表单有多种可选,界面清晰容易上手。

    image.gif编辑

    \

    当然,Apifox的数据结构和数据模型是完全遵守 JSON Schema 规范 的,可以直接编辑 JSON Schema 来定义数据结构。

    image.gif编辑

    在线接口文档

    定义好的接口,**在线文档**效果如下

    image.gif编辑

    接口调试

    当我们接口设计好之后,可以调试看看效果。以登录接口为例,进入运行页,编辑好参数值,选择运行环境,点击运行即可发起一个简单的请求,页面下方可查看接口响应、请求详情。

    \

    image.gif编辑

    接口调试内容可以保存为一个用例,方便下次调试或者团队成员测试用。

    调试和用例都是为了测试接口的正确性,肯定需要验证接口返回的信息、有时还要从响应提取信息供后续请求使用。这时候就需要提取变量和断言操作,现成的0编码的可视化步骤,,入口在后置操作里面,我们从响应提取一token存为环境变量,并断言响应里的city字段值为“广州市”。

    image.gif编辑

    运行,系统会自动校验响应的数据结构是否与文档定义一致,当断言失败时提示并打印期望值和实际值。

    image.gif编辑

    \

    点击控制台看到变量token提取成功

    image.gif编辑

    变量提取来源和断言的对象不只是响应JSON,还有cookie、header等,大大提高了编写断言的效率。

    image.gif编辑

    除了提取和断言,接口前后置操作还支持数据库查询、公共脚本和自定义脚本,满足日常的测试场景下数据库查询取值,自定义功能等需求,这些操作使用门槛低,小白用户也可以优雅从容地进行接口测试~

    image.gif编辑

    除了可以编写JS脚本,还可以直接调用java (.jar)、python (.py)、php (.php)、js (.js)、BeanShell (.bsh)、go (.go)、shell (.sh)、ruby (.rb)、lua (.lua)等语言编写的外部程序,满足进阶用户的定制化需求。

    数据模型

    Apifox文档支持数据模型,可以按分类管理,支持数据模型之间的调用

    image.gif编辑

    \

    环境管理

    每个环境都有自己的前置URL,环境变量,变量的远程值可在团队内共享,本地值只保存在本地不上传云端。当我们运行时,选择环境即发起该环境的请求。使用{{变量名}}即可读取该环境的环境变量值。

    全局变量和全局参数供所有环境使用。

    image.gif编辑

    Mock功能

    通常在前后端并行开发的模式下,前端需要根据API文档,使用 Mock模拟响应数据数据保证前端调用链路的畅通。Apifox运行时Mock 功能即在本地启动,接口文档页可以根据响应结构自动生成mock数据,并且其内置规则使得大部分常用字段,如头像、城市、手机号、IP等, 零配置即可生成非常人性化的 mock 数据。这个功能不仅节省搭建mock服务、编写mock规则的时间,而且大大增强了前端数据的展示效果:

    image.gif编辑

    此外,还可以根据接口/数据结构定义Mock规则配置Mock 期望配置,自动生成模拟数据,且使用者可以根据需要灵活构造各种结构的接口数据。

    测试用例

    当我们要对某个功能做完整流程的测试、或者单一接口的不同情况进行测试时,需要将多个用例串联起来测试。测试管理-测试用例可以满足将用例组合起来自动化测试。我们在测试管理这里创建一个测试用例,点击添加步骤可以选择从接口用例导入或者从接口导入。

    image.gif编辑

    选择从接口用例导入,可导入之前编写的接口用例。导入模式可选择复制或绑定,推荐使用“绑定”,测试管理和接口用例数据同步,当一处发生变化时,另一处的数据自动同步无需再手动修改用例。

    我们做一个简单的登录-签到的例子,导入2个接口用例-登录和签到。

    image.gif编辑

    我们来看看这两个用例的设置:登录用例设置了后置操作,从响应提取token存为变量

    image.gif编辑

    签到用例:token字段参数值读取登录接口提取的token值进行签到

    image.gif编辑

    \

    导入之后,可以调整用例排序,设置循环次数和线程数

    image.gif编辑

    运行,生成测试报告如下:

    image.gif编辑

    点击报告中的接口查看接口的请求、响应信息。可以看到登录接口返回的token值,在签到请求中使用了。这就是一个简单的集成测试的例子。

    image.gif编辑

    image.gif编辑

    测试套件

    套件是测试用例的集合,用于组织更复杂的功能测试,常应用于接口自动化测试、回归测试,操作方法类似测试用例。

    image.gif编辑

    参数化

    在测试用例/套件运行时,设置循环次数和线程数即可对接口进行压力测试。在压力测试中,我们或许还需要对接口使用不同的参数值,Apifox支持接口参数值设置为变量,通过上传CSV/JSON格式的数据文件,实现用例运行参数化,还是以登录为例子,我们把账号密码都设置为变量

    \

    image.gif编辑

    我们创建一个存放账号和密码的CSV文件,第一行是变量名,第二行开始是数据

    account password
    test1@qq.com 123456
    test2@qq.com 123456
    test3@qq.com 123456
    test4@qq.com 123456
    test5@qq.com 123456
    test6@qq.com 123456
    test7@qq.com 123456
    test8@qq.com 123456
    test9@qq.com 123456
    test10@qq.com 123456

    运行用例时上传该csv文件,循环次数会自动填充csv的数据行数

    image.gif编辑

    点击运行,用例会按csv顺序运行,如图,查看运行的第二个接口请求,参数值为第二组数据。

    image.gif编辑

    持续集成

    为了方便集成Jenkins等持续集成工具自动构建、持续运行测试用例,Apifox支持通过命令行运行工具Apifox CLI实现持续集成。主要有下载测试数据运行到本地运行和通过命令下载在线数据运行2种方式。

    在测试用例/测试套件页,点击“持续集成”,即可生成命令,通过Apifox CLI运行该命令实时运行在线测试用例/套件。

    image.gif编辑

    运行结果如图

    image.gif编辑

    也可以导出Apifox CLI格式数据,通过ApifoxCLI读取导出的json数据运行测试用例。

    image.gif编辑

    团队管理

    团队角色分所有者、管理者和普通用户,分别有以下不同的权限:

    image.gif编辑

    每个成员在每个项目中可以设置不同的项目权限:分别是管理员、普通成员、只读成员、禁止访问。

    image.gif编辑

    不同项目权限对应内容如下,满足团队的多层次管理需求。

    image.gif编辑

    生成代码

    Apifox提供基于**OpenAPI Generator**的代码生成功能——根据接口模型定义,自动生成各种语言/框架(如 TypeScript、Java、Go、Swift、ObjectiveC、Kotlin、Dart、C++、C#、Rust 等 130 种语言及框架)的业务代码(如 Model、Controller、单元测试代码等)和接口请求代码。目前 Apifox 支持 130 种语言及框架的代码自动生成。

    更重要的是:可以通过自定义代码模板来生成符合自己团队的架构规范的代码,满足各种个性化的需求。

    image.gif编辑

    总结

    都看到这了,这款既能管理接口又能做自动化测试、好用好看还免费的接口文档工具)还不赶紧用起来,fox在手,效率全有,准点下班不是梦~ ps.更详细的使用说明请前往官方文档

    官网地址::www.apifox.cn

    相关文章
    |
    3月前
    |
    缓存 监控 测试技术
    接口设计的18条军规:打造高效、可靠的API
    【10月更文挑战第2天】在软件开发中,接口设计是连接不同模块、系统乃至服务的桥梁。一个优秀的接口设计不仅能提升开发效率,还能确保系统的稳定性和可扩展性。以下是接口设计的18条军规,旨在帮助你在工作和学习中设计出更加高效、可靠的API。
    201 1
    |
    5月前
    |
    监控 安全 测试技术
    API 管理的概念是什么?Apifox 为什么值得推荐?
    在互联世界中,API如同软件间的“翻译官”,让应用能相互交流、共享数据。随着API数量激增,有效管理变得至关重要。API管理确保API的质量、安全与性能,提升开发效率及用户体验。它覆盖API从设计到废弃的全过程。利用如Apifox这样的工具,可以轻松实现API的设计、测试、文档管理和模拟等。Apifox集多种功能于一体,简化工作流程,提高团队协作效率。在选择API管理工具时,Apifox以全面的功能和友好的使用体验脱颖而出,成为开发者们的优选。随着技术发展,未来API管理将更加智能化和高效。
    API 管理的概念是什么?Apifox 为什么值得推荐?
    |
    4月前
    |
    缓存 测试技术 API
    探索后端开发:构建高效API的实用指南
    【8月更文挑战第31天】 在数字化时代的浪潮中,API(应用程序编程接口)已成为连接不同软件和服务的关键纽带。本文旨在为开发者提供一个简明而深刻的指南,通过深入浅出的方式介绍如何构建高效、可扩展的后端API。我们将从基础概念开始,逐步深入到设计原则和最佳实践,最后通过一个实际的代码示例来演示这些理念的应用。无论你是初学者还是有经验的开发者,这篇文章都将为你提供宝贵的见解和灵感,帮助你在后端开发的道路上更进一步。
    |
    6月前
    |
    缓存 监控 测试技术
    API设计与开发的最佳实践:打造高效、易用的接口服务
    【7月更文挑战第26天】API的设计与开发是一个复杂而重要的过程,它直接影响到系统的可用性和用户体验。通过遵循上述最佳实践,开发者可以构建出高效、易用、可扩展的接口服务,为不同软件和服务之间的集成提供有力支持。在未来的软件开发中,API将扮演越来越重要的角色,因此不断学习和实践API设计与开发的最佳实践,对于开发者来说至关重要。
    |
    8月前
    |
    安全 前端开发 API
    深入理解与实践GraphQL:构建高效、灵活的API
    在本文中,我们将探索GraphQL这一强大的API查询语言及其运行原理。不同于传统的RESTful API设计,GraphQL提供了一种更加高效、灵活的方式来交互数据。通过实例和比较,本文旨在揭示GraphQL如何使前端和后端开发更加紧密协作,同时减少数据传输的冗余。我们将从GraphQL的基本概念入手,深入到查询(Queries)、变更(Mutations)和订阅(Subscriptions)的实现,最后探讨如何在实际项目中部署和优化GraphQL服务。此外,本文还将简要介绍如何利用现有的GraphQL工具和库来加速开发过程。
    111 0
    |
    5月前
    |
    XML JSON 安全
    构建高效API:后端开发最佳实践
    【8月更文挑战第3天】在数字化时代,API(应用程序接口)成为连接不同软件和服务的关键桥梁。本文将深入探讨如何设计、实现和维护高效的API,确保它们既能够快速响应请求,又能保持足够的灵活性以应对未来的变化。我们将通过具体代码示例和实用建议,为后端开发人员提供一套完整的指南,帮助他们构建出高性能、易维护的API系统。文章将从API设计的基本原则出发,逐步深入到具体的实现技术,包括数据格式选择、错误处理策略以及安全性考虑等方面,旨在帮助读者掌握创建和管理高效API的关键技能。
    |
    7月前
    |
    JSON 安全 API
    API开发实战:从设计到部署的全流程指南
    在数字化转型中,API成为系统集成的关键。本文引导读者逐步实践API开发: 1. 设计阶段确定需求,选择RESTful风格,例如天气查询API(/api/weather/{city}),返回JSON数据。 2. 使用Python和Flask实现API,处理GET请求,返回城市天气信息。 3. 进行测试,如用curl请求`http://localhost:5000/api/weather/Beijing`。 4. 文档化API,借助Flask-RESTPlus自动生成文档。 5. 部署到Heroku,创建`Procfile`,通过`heroku`命令推送代码。 【6月更文挑战第28天】
    1042 0
    |
    Java 测试技术 API
    探索Swagger:简化API文档管理与测试的利器
    在现代的应用开发中,API(Application Programming Interface)是不可或缺的一部分,用于实现不同系统之间的通信和数据交换。然而,对于开发者来说,编写和管理API文档以及进行API测试可能是繁琐的任务。Swagger作为一款强大的API文档生成和测试工具,为我们提供了一种简化的解决方案。本文将深入探讨Swagger的基本概念、特点,以及如何在实际应用中使用它进行API文档管理和测试。
    157 1
    |
    数据可视化 API
    Swagger3实现API文档管理:让前后端合作更加顺畅
    Swagger3实现API文档管理:让前后端合作更加顺畅
    336 0
    |
    JSON 数据可视化 Oracle
    比swggaer更好用的接口文档工具
    今天给大家推荐一个新接口工具:YesApi接口大师。 YesApi接口大师(5合1):Admin接口管理后台,看这个名称就知道,这个工具很符合国内程序员、以及技术小白使用。通过网站界面,它能帮你轻松管理API接口,除了可以自动生成接口文档、还能生成API接口源代码、通过界面鼠标就能开发接口,一键、快速发布、管理和开放你的API接口。