Getting started
This guide gives you all the info to create your first Multistep API check with Checkly. You should have some prior knowledge of working with JavaScript and/or Node.js.
What is a Multistep API check?
A Multistep API check allows you to write Node.js scripts that can run multiple API requests in sequence, with arbitrary code between requests. This allows you to monitor entire API user flows with a single check, working with response data in between requests exactly as a user of your API would to ensure that these interactions result in the correct results.
Examples of API sequences might be:
- Users can authenticate and access restricted data
- Users can get, set and remove data from their account
- Users can add items to a shopping cart, checkout and go through the payment flow.
Monitoring your API user flows instead of individual endpoints gives confidence that your product as a whole works as intended and that the expected interactions between API calls are functional.
Multistep API checks are powered by @playwright/test
’s API Testing mode. Meaning you get all of the power of our typical API tests, in the form of a programmable @playwright/test check
The following code is a valid Multistep API check using Playwright Test.
import { test, expect } from '@playwright/test' // 1
const headers = { // 2
Authorization: `Bearer ${process.env.API_KEY}`,
'x-checkly-account': process.env.ACCOUNT_ID,
}
const baseUrl = process.env.API_URL ?? 'https://api.checklyhq.com/v1'
test('create and delete a check group', async ({ request }) => { // 3
const createdGroup = await test.step('POST /check-groups', async () => { // 4
const response = await request.post(`${baseUrl}/check-groups`, {
data: {
locations: ['eu-west-1'],
name: 'exampleCheckGroup',
},
headers,
})
expect(response).toBeOK() // 5
return response.json() // 6
})
await test.step('DELETE /check-group/{id}', async () => { // 7
const response = await request.delete(`${baseUrl}/check-groups/${createdGroup.id}`, {
headers,
})
expect(response).toBeOK()
})
})
Breaking down a Multistep check
Let’s look at the code above step by step.
1. Initial declarations: To run any multistep check we first import the Playwright test framework.
2. Define our headers: In many cases you will have to authenticate when requesting data by providing authorization data in your header. By using environment variables we avoid having any confidential data in our test.
3. Establish environment: We create a new test using the Playwright request
fixture, which can be used to make API requests in the test steps.
4. Declare our first test.step
: The test step uses the request
to perform a get
request, using the headers we defined earlier.
await
before test.step
, otherwise the test will fail.5. Define our assertion: We use the expect(response)
method to assert if the response was successful (The response code is in the range of 200 - 299) with toBeOK()
. Should the request return anything outside of the ‘OK’ range, this will cause the check to fail and in a production scenario trigger any configured alerts.
6. Return the response for future usage: We return the request response in JSON format, so we can use it in the next test step.
7. Declare our second test.step
: In order to remove the test group we just created, and avoid cluttering our system with test data, we remove it by sending a delete
request using the group ID that was returned in our earlier test step. We use the same assertion as in the previous test step.
If you want to build on the above example, you can add additional assertions, ensuring that the data returned is correct and contains a specific check, or add a PUT
and GET
test step to verify more of the /groups
functionality.
Creating a Multistep check
A valid Multistep API check is based on a valid Playwright API test script. You can create these scripts either in the in-app editor, or write them in your IDE and deploy them using the Checkly CLI. For production, we recommend using the CLI so you can leverage best practices such as version control and code reviews before updating your checks.
Structuring a Multistep check
To preserve test isolation and provide a structured report view of Multistep checks, Checkly relies on the test.step method from Playwright. Your multistep test can have several test steps. API requests and assertions in the same test step will be presented under the same node in the reporting structure.
To provide actionable and easy to read check run reports we recommend using this structure when writing Multistep checks.
import { test, expect } from '@playwright/test'
const baseUrl = 'https://api.checklyhq.com/v1'
test('My test', async ({request}) => {
await test.step('First step', async () => {
const health = await request.get(`${baseUrl}/health`)
expect(health).toBeOK()
await expect(response).toBeOK()
});
await test.step('Second step', async () => {
const response = await request.post(<your request>)
// Assertions for the second step
...
})
})
Building checks in the web editor
When creating a check using the web editor, after each test run you can open up the result tree by clicking on the ‘Test report’ icon on the left side of the editor. Selecting an API response opens the response details. You can also view errors and any failed assertion in the report view.
Multistep result view
When viewing a multistep check run result, you can select any API request in the result tree to view the full response details. If you have your API request and related assertions in the same test.step
, related requests and failing assertions will be grouped under the same header.
Selecting the top node in the check report shows the full job log and the check configuration for the run.
Pricing
During beta, a multistep check is billed based on the number of requests done per check run. Each request in a multistep check run is billed as a single regular API check run, as they are performing the same basic operation.
As an example, let’s say you have 4 API checks, where each check doing one of the GET
, POST
, PUT
and DELETE
operations towards the same endpoint. If you replace these 4 checks with a single multistep API check that runs 4 requests towards the same endpoint, checking each method, and the check run frequency is the same as before, your cost stays the same
A multistep check with 0 requests is billed as if it has 1 request.
Resources
- Checkly’s YouTube channel where we regularly publish tutorials and tips.
- playwright.dev is the official API documentation site for the Playwright framework.
- awesome-playwright is a great GitHub repo full of Playwright-related libraries, tips and resources.
You can contribute to this documentation by editing this page on Github