When working with APIs, you can either test them with Postman or cURL and they are the right tools for this workflow but what if I say, there is an extension which allows you to test APIs, without leaving the comfort of VSCode, that would be pretty handy. In this article, I'll introduce you to that extension & guide you on how work with it.
The Extension
The extension is called REST Client developed by Huachao Mao along with many contributors.
data:image/s3,"s3://crabby-images/2f5a0/2f5a0dfa96d07bc3ed43c7dbcd67e19ea8e77ac7" alt="REST Client extension for Visual Studio Code"
Installation
The extension can be downloaded using the command palette.
ext install humao.rest-client
You can also find it on Visual Studio Marketplace.
Working
Installing the extension brings in support for two file types - .http
& .rest
. Creating a file with one of those extension will enable you to perform requests.
The JSON Placeholder API is a good place to start. In a new workspace, create a file with either .http
or .rest
as the extension. For this example, I'd be using jsonPlaceholder.rest
, this is where all the API requests will be made throughout this article.
data:image/s3,"s3://crabby-images/9126b/9126bfaf60e931fa0d6e05e9bcc401b3c32d8c4f" alt="New Workspace"
Performing a GET Request
Let's perform a GET request to the /posts
endpoint.
data:image/s3,"s3://crabby-images/0f5c7/0f5c7d6995aaec38feabf036d4c18cd78bcc731e" alt="GET Request to Posts Endpoint"
First line is what initiates the actual request followed by the Content-Type of the response. Usually, when you're dealing with REST APIs, it is set to application/json
.
Those two lines is all that you need to perform a GET request. There will be small text right above the first line with a text of Send Request, click it to initiate the request.
As you initiate the request, a new pane to the right should open along with the response provided by the API. It's that simple.
data:image/s3,"s3://crabby-images/35ba7/35ba7d1a0fd142989f988b1728e0e9ec5fffe4bc" alt="Response from the API when GET request is performed."
Performing a POST Request
While performing a POST request, you generally have to send the data to be posted via the request's body. You can attach the data to the request's body as shown below:
data:image/s3,"s3://crabby-images/9532b/9532b09eb001de5184a60503b87a09ddcbae2a41" alt="POST request to posts endpoint."
On initiating the request, API should respond with the data posted.
data:image/s3,"s3://crabby-images/0188d/0188d1f75842f247a18f04c6b324e5277414eb76" alt="Response from the API when POST request is performed."
You can perform any number of requests from a single file. To seperate multiple requests, just add ###
in between them.
Making Requests to a GraphQL API
Requests to an GraphQL can be made as well. For this example, we'll be using the GitHub API.
data:image/s3,"s3://crabby-images/b77c9/b77c9d0fe88c03deb1e000d60e236138085efd3e" alt="Making request to a GraphQL."
That's it for this article. As I explore more of this extension, I'll keep updating with more actions you can perform with this extension.