CI for APIs with the Kong Insomnia CLI and GitHub Actions

Tyler Hawkins - Jan 31 '22 - - Dev Community

Insomnia is a desktop app from Kong that’s great for building, debugging, and testing backend APIs. While ad hoc manual testing is nice, wouldn’t it be even better to include our API tests in our continuous integration (CI) pipelines? With Inso, Kong Insomnia’s CLI tool, we can!

Inso allows you to run your automated API tests directly from the command line, which means setting up a workflow with GitHub Actions is a snap.

In this article, we’ll create a simple server with Node.js and Express, write API tests using Kong Insomnia, and then run these tests in our CI pipeline with Inso and GitHub Actions.


Demo App: A Nintendo Game Database

We’ve built a game database that contains info about every NES game ever published. The app is a server that implements a REST API with endpoints to get data about the games, categories, developers, publishers, and release years.

You can find the complete code on GitHub.


Using Kong Insomnia for Manual Testing

While developing an API, rapid feedback cycles help ensure your API works the way you want and returns the data you expect. Kong Insomnia is perfect for this kind of ad hoc testing.

To get started with our NES game API, we created a new Design Document inside Kong Insomnia. We left the information in the Design tab blank and headed over to the Debug tab to start making requests. Below, we have requests for each API endpoint our server provides. We can run each request inside Kong Insomnia, and the resulting data is displayed in the UI.

Example API request in Insomnia

Example API request in Insomnia

Writing Tests with Kong Insomnia

Manually hitting our API endpoints is great for ad hoc testing and debugging, but ultimately what we want is an automated test suite that ensures our app is behaving correctly. Kong Insomnia allows you to write tests in the Test tab within the desktop app.

The tests are written by selecting one of the requests from the Debug tab and then making assertions about the data the server returns. You can run individual tests or an entire suite of tests.

As you can see below, we’ve written tests for each of our API endpoints for a total of 11 tests in our test suite.

API tests in Insomnia

API tests in Insomnia

These tests (and the information in our Design Document) can be synced with Git and included in our code repo. That way, anyone with the Kong Insomnia desktop app can also run these requests and tests.

To sync Kong Insomnia with Git, simply click the “Setup Git Sync” button at the top of the app.

Setup Git Sync button in Insomnia

Setup Git Sync button in Insomnia

From there, you can provide the relevant details to connect Kong Insomnia with your project’s Git repo.

Linking Insomnia with your GitHub repo

Linking Insomnia with your GitHub repo

Syncing Kong Insomnia with your Git repo requires an authentication token. You can easily create a personal access token within your account settings in GitHub.

Creating a personal access token in GitHub

Creating a personal access token in GitHub

Running Tests from the Command Line with Inso

We now have a set of requests and a suite of tests within Kong Insomnia that help us with our debugging and testing. But we haven’t automated the running of these tests yet, so let’s do that now. This is where Kong Insomnia’s CLI, Inso, comes into play.

Inso is installable as an npm package, so we’ve added that as a dev dependency to our project: yarn add --dev insomnia-inso.

To make running our test suite simple, we’ve created an npm script in our package.json file. The following script runs our tests with Inso: "test": "inso run test \"NES Games API Test Suite\"". That means we can simply run yarn test to run our tests from the command line any time we want.


Integrating Inso with GitHub Actions

Now for the culmination of everything we’ve set up so far: running our automated tests as part of a continuous integration pipeline. It’s nice that we can run our tests from the command line, but right now, we don’t have them running automatically for us anywhere. We really want our test suite to be run on every new pull request. Doing so will ensure that the tests pass before merging any new code into the master branch. This is continuous integration at its finest.

GitHub Actions allow us to configure any continuous integration we’d like by using YAML files. We’ve created a .github/workflows directory and a unit-tests.yml file inside it. This file is reproduced in full below:

name: NES Games API CI

on:
  push:
    branches:
      - master
  pull_request:
    branches:
      - master

jobs:
  test:
    runs-on: ubuntu-latest
    steps:
      - name: Checkout branch
        uses: actions/checkout@v2

      - name: Use Node.js 14.x
        uses: actions/setup-node@v2
        with:
          node-version: 14.x
          cache: 'yarn'

      - name: Install dependencies
        run: yarn install --frozen-lockfile

      - name: Start server and run unit tests
        run: yarn ci:start-and-test
Enter fullscreen mode Exit fullscreen mode

As you can see, our workflow checks out our current branch, uses Node v14, installs our dependencies with yarn, and then runs a custom script to start our app’s server and run the API tests. This workflow is triggered whenever code is pushed to the master branch or a new pull request is opened against the master branch.

This ci:start-and-test script is another npm script we’ve added to our package.json file. Using the npm packages wait-on and concurrently, we use this script to start our server, run the API tests, and then kill the server once the tests finish. The full list of npm scripts in our package.json file is reproduced below:

"scripts": {
  "ci:start-and-test": "concurrently -k -s=first \"yarn start\" \"yarn ci:test\"",
  "ci:test": "wait-on http://localhost:3000 && yarn test",
  "format": "prettier --write .",
  "format-watch": "onchange . -- prettier --write {{changed}}",
  "start": "node index.js",
  "test": "inso run test \"NES Games API Test Suite\""
},
Enter fullscreen mode Exit fullscreen mode

And now, we have a beautiful working CI pipeline!

We can test that everything is working properly by creating a small pull request in our repo. After making the pull request, we can see that our CI pipeline is running:

CI pipeline is running for our pull request in GitHub

CI pipeline is running for our pull request in GitHub

If we click the Details button to see more info, we can see the individual steps of our workflow being run:

CI pipeline steps

CI pipeline steps

Once the job passes, the results are reported back to the pull request as seen below:

CI pipeline has passed for our pull request

CI pipeline has passed for our pull request

We did it! All checks have passed.

The last thing we could do for completeness is require that all checks pass in GitHub before pull requests can be merged. We can do this in the repo’s settings within GitHub:

Require status checks to pass before merging pull requests in GitHub

Require status checks to pass before merging pull requests in GitHub

If you’d like to explore another potential CI setup, the Kong team also has their own example workflow you can use that installs Inso as part of a job in the CI pipeline with their setup-inso GitHub Action.


Conclusion

So, what have we accomplished today? Quite a lot, actually! We’ve created a server using Node.js and Express. We’ve created ad hoc requests within Kong Insomnia to help with the development and debugging of our API. We’ve written tests inside Kong Insomnia and learned to run them from the command line using Inso. And finally, we’ve created a CI pipeline with GitHub Actions to run our API tests as part of every pull request for our repo.

Kong Insomnia, Inso, and GitHub Actions have worked together to help us develop our app with confidence. Our continuous integration pipeline has prepared us to deploy our app at any time. Success!

To go further, we could merge this workflow into a broader strategy for managing the entire API development lifecycle — design and development within Kong Insomnia, deployment with Inso integrated with our CI pipeline, and management and maintenance with a tool like Kong Gateway.

Thanks for reading, and happy coding!

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .