**01** **---** Bruno 介绍 ======== **一句话介绍Bruno**:一款全新且创新的 API 客户端,平替Postman。承诺一直离线使用,支持用 Git 或其他任何版本控制系统来进行API版本控制和协作。 data:image/s3,"s3://crabby-images/74981/74981c5c19a29e3e70bfd5dbb5227dae52a86150" alt=""
**? 项目信息**\* \* \* \* ``` #Github地址https://github.com/usebruno/bruno#项目官网https://www.usebruno.com/ ``` 发布一年半不到的时间,目前已经荣获了19K+的Star。 data:image/s3,"s3://crabby-images/f57a8/f57a8ff700d54ce2402dacea0c1f264ab9c62660" alt="" ?**功能特性**
* Bruno 采用一种简单的标记语言,提供界面、CLI,简单易用; * 测试集合中的 API 请求采用纯文本文件方式存储; * 支持 API 测试集合保存在Git代码存储库,通过版本控制系统管理和团队共享。API 测试上的协作可以通过Git请求来完成,使测试人员更轻松了解API的更改。 * 仅限支持离线使用。永不添加云同步功能。保护数据隐私,所以测试数据本地留存。 **? 和Postman对比** ----------------- * **测试集如何保存和团队协作使用** Postman采用云存储(上传云端共享),或者导出JSON共享。 Bruno 采用Git存储共享和控制。 * **API 请求是如何发出的** Postman Web App 使用专有代理服务器发出 API 请求。 Bruno 直接从本地计算机发出 API 请求。 * **在线和离线** Postman 需要在线登录使用。 Bruno 专为离线使用而设计。 * **团队协作** Postman 团队协作功能需付费。 Bruno 是免费且开源,可以使用 git 版本控制来协作。 * **测试集运行** Postman 本地测试集运行有次数限制,不然就需要付费才行。 Bruno 可以无限次地运行集合。 **02** **---** Bruno 安装 ======== **一、下载安装文件进行安装** * 下载地址: * ``` https://www.usebruno.com/downloads ``` data:image/s3,"s3://crabby-images/46dcc/46dcc76e33e5c399fabf84cbef00c98b9f10996a" alt="" **二、通过包管理器安装** \* \* \* \* \* \* \* \* \* \* \* \* \* \* \* \* \* \* \* \* \* ``` # 在 Mac 电脑上用 Homebrew 安装brew install bruno # 在 Windows 上用 Chocolatey 安装choco install bruno # 在 Windows 上用 Scoop 安装scoop bucket add extrasscoop install bruno # 在 Linux 上用 Snap 安装snap install bruno # 在 Linux 上用 Apt 安装sudo mkdir -p /etc/apt/keyringssudo gpg --no-default-keyring --keyring /etc/apt/keyrings/bruno.gpg --keyserver keyserver.ubuntu.com --recv-keys 9FA6017ECABE0266 echo "deb [signed-by=/etc/apt/keyrings/bruno.gpg] http://debian.usebruno.com/ bruno stable" | sudo tee /etc/apt/sources.list.d/bruno.list sudo apt updatesudo apt install bruno ``` **03** **---** Bruno 界面使用 ========== * **打开默认界面** data:image/s3,"s3://crabby-images/07023/07023994a42f993f836e067031fc868e9404af0f" alt="" * **创建测试集** data:image/s3,"s3://crabby-images/c003b/c003b19f827a3dd14728ec32c691adf4353279fe" alt="" * **导入测试集** data:image/s3,"s3://crabby-images/ec348/ec348a15adacbf3409abaea8d1f85a38c8fd303b" alt="" * **在测试集下创建请求** data:image/s3,"s3://crabby-images/5bd66/5bd669571b720205e0f939891a9ee996320fb98d" alt=""*比如创建一个查询北京天气的接口* data:image/s3,"s3://crabby-images/181ce/181cef321054aa51c8eb2f5c78a6441e8317fa94" alt=""*运行结果* * ##### **API 请求转成代码** data:image/s3,"s3://crabby-images/bb006/bb006959b4accfa502306cc2dce7787e359eb6ec" alt="" * **编写断言** ##### 1、声明方式编写断言 data:image/s3,"s3://crabby-images/3187c/3187c27c9fd53a34f3eb4dfae0a83fab3ac8e19f" alt="" 比如判断上海天气是否为"优" data:image/s3,"s3://crabby-images/15e56/15e56724df64a3e8b77ce4fda598d9afb55014b9" alt="" ##### 2、脚本编写断言 ##### 如果声明方式编写断言不能满足需求,可以采用脚本编写断言,比如判断状态码是否为200: * * * * * ``` test("返回码为200", function() { const data = res.getBody(); expect(res.getStatus()).to.equal(200);}); ``` data:image/s3,"s3://crabby-images/aaa9b/aaa9b51f5f3308af9cb0b3a1dad1f9a8543181a0" alt="" * **创建环境变量** data:image/s3,"s3://crabby-images/573e7/573e74510b401da3e7ce31949f0e9fa0cd3358c8" alt="" 在请求中使用{{URL}}替换地址 data:image/s3,"s3://crabby-images/79d65/79d65581a4cde25115bb187a333b4b52fe8b894c" alt="" * **运行 Git 中测试集** 官方提供了一个DEMO: \* ``` https://github.com/usebruno/github-rest-api-collection ``` 使用时,下载代码,然后导入Bruno中: \* \* \* \* ``` # Clone this repo git clone https://github.com/usebruno/github-rest-api-collection.git # open the folder in bruno ``` data:image/s3,"s3://crabby-images/3a006/3a006b5d1ece6b22e84531a059284476338548f5" alt="" * **批量运行测试集** data:image/s3,"s3://crabby-images/e7539/e7539b170540be0f1f410e57e62398ce84607e7b" alt="" * **基于Git可以实现版本管理** data:image/s3,"s3://crabby-images/8a990/8a9900d41fb9faff62899aa6611801c16ad13500" alt=""**03** **---** Bruno CLI 使用 ============ 通过 Bruno CLI,可以使用简单的命令行命令轻松运行 API 集合。可以更轻松地在不同环境中测试 API、自动化测试流程,并将 API 测试与持续集成和部署工作流程集成。 * **安装Bruno命令行** * ``` npm install -g @usebruno/cli ``` * **导航到 API 集合所在的目录,然后运行**运行集合中的所有请求:\*\*\*\* * ``` bru run ``` * **通过指定其文件名来运行单个请求:** * ``` bru run request.bru ``` * **运行文件夹中的所有请求:** * ``` bru run folder ``` * **如果需要使用环境,可以使用 --env 选项指定:** * ``` bru run folder --env Local ``` * **使用 --env-var 选项将环境变量传递到测试集:** * ``` bru run folder --env Local --env-var JWT_TOKEN=1234 ``` * **收集 API 测试的结果,可以指定 --output 选项:** * ``` bru run folder --output results.json ``` * **其他参数选项** data:image/s3,"s3://crabby-images/911ef/911ef6bd245eee19d86c6fdc2291be39b4258764" alt=""**04** **---** Bruno vscode 插件 =============== vscode 应用中直接安装Bruno data:image/s3,"s3://crabby-images/d503f/d503ff720fdc419d00123874a05806dfa0095a0e" alt="" 该插件为 .bru 文件提供语法高亮功能 data:image/s3,"s3://crabby-images/8dad0/8dad0eebe0367b0ea3b2bd296cf1dcd0cb567f74" alt=""**05** **---** 最后 === 工欲善其事,必先利其器,拥有一款优秀的 API 工具能够帮助测试人员和企业大幅度提升测试效率。正如 Bruno 官网所说,Bruno 希望重新定义 API 测试客户端。如果你已经受够了 Postman 的限制或者正在寻找其他的 API 测试工具,那么不防试试 Bruno ,希望给你一个不一样的 API 测试体验。 五一假期前最后一天工作日,收拾好心情,开始happy,祝大家五一假期快乐!