Yapi is Postman, Insomnia or Bruno for the power user.
Yapi is an OSS command line tool that makes it easy to test APIs from your terminal. Yapi speaks HTTP, gRPC, TCP, GraphQL (and more coming soon).

Heads up! Yapi is early, early alpha software
I use yapi daily in my development workflow. However, yapi is a SUPER young project and will have bugs, missing features and rough edges.
If you download yapi, I would LOVE your feedback on how to make it better. Please open an issue if you have any suggestions or find any bugs!
Show me some examples!
POST
This request:
yapi: v1
method: POST
url: https://api.github.com/repos/jamierpond/yapi/issues
headers:
Accept: application/vnd.github+json
Authorization: Bearer ${GITHUB_PAT}
body:
title: Help! yapi made me too productive.
body: Now I can't stop YAPPIN' about yapi!
expect:
status: 201
assert:
- .body == "Now I can't stop YAPPIN' about yapi!"
Gives you this response:
yapi run create-issue.yapi.yml
{
"active_lock_reason": null,
"assignee": null,
"assignees": [],
"author_association": "OWNER",
"body": "Now I can't stop YAPPIN' about yapi!\n",
}
URL: https:
Time: 579.408625ms
Size: 2.3 kB (1 lines, 2288 chars)
[PASS] status check
[PASS] .body == "Now I can't stop YAPPIN' about yapi!"
(Only the JSON goes to stdout, the rest goes to stderr, so is pipeable!)
Yapi supports chaining requests between protocols
Multi-protocol chaining
Yapi makes it easy to chain requests and share data between them, even if they are different protocols.
yapi: v1
chain:
- name: get_todo
url: https://jsonplaceholder.typicode.com/todos/1
method: GET
- name: grpc_hello
url: grpc://grpcb.in:9000
service: hello.HelloService
rpc: SayHello
plaintext: true
body:
greeting: $get_todo.title
expect:
assert:
- .reply == "hello delectus aut autem"
Run this example in the yapi playground
Integration Testing with yapi
Yapi has built-in support for writing integration tests with expectations and assertions.
yapi: v1
method: GET
url: https://api.github.com/repos/jamierpond/yapi/issues/5
headers:
Accept: application/vnd.github+json
expect:
status: 200
assert:
- .state == "closed"
- .closed_by.login == "jamierpond"
Run this example in the yapi playground
Yapi has an LSP Server for IDE Integration
Yapi comes with a Language Server Protocol (LSP) server that provides syntax highlighting, autocompletion and validation for yapi request files in editors that support LSP (Neovim, etc), you can also use the yapi Neovim plugin (still early days).
At some point I'll write the VSCode extension too, please make an issue if you think this is important!
GitHub Actions Support
I use yapi's GitHub Action to run integraion tests on the CI for this blog!
name: Integration Tests
on: [push, pull_request]
jobs:
test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: '20'
- name: Install dependencies
run: npm ci
- name: Build Application
run: npm build
- name: Run Yapi Integration Tests
uses: jamierpond/yapi/[email protected]
with:
start: npm run start
wait-on: http://localhost:3000/health
command: yapi test ./tests -a
For example, here is the output of yapi running integration tests in GitHub Actions:

Supports for Multiple Environments
Yapi make it easy to manage multiple environments (dev, staging, prod, etc).
Define your environments in a yapi.config.yml file:
yapi: v1
default_environment: local
environments:
local:
url: http://localhost:3000
env_file: .env.local
vars:
some_param: default_value
prod:
url: https://yapi.run
env_file: .env.prod
vars:
some_param: some_value
Then run yapi with the desired environment:
yapi run my-request.yapi.yml --env prod
This also cleans up your request files a little, now you can use paths instead of full URLs:
yapi: v1
method: GET
path: /api/v1/status
Getting Started with Yapi
To get started with yapi, simply install it using the instructions on the yapi GitHub repository and start creating your first request files!
Contributing to Yapi
Yapi is an open-source project maintained by just me, Jamie. If you find bugs or have feature requests, please open an issue on the yapi GitHub repository. Pull requests are very welcome too!