K6 — Custom Slack Integration: Metrics are the Magic of Tests
data:image/s3,"s3://crabby-images/58f0e/58f0ea6e414773ee037bf76f0f10dc525f108b8e" alt=""
In my previous article, I talked about how we can easily load tests with the k6 tool. You can find it here. This article will talk about how we can send our test results with k6 to slack.
Metrics are magic for us in these types of tests. Because we can make sense of everything with metrics. These metrics need to be available at all times. There are many methods for this, you can achieve this with the different methods that k6 offers us. You can get an output as JSON or you can see the outputs retrospectively with a time-based database. But slack has become especially important for us developers, we can set up alert mechanisms over slack, we can set up slack-bot or notification systems as we want. In this article, we will add a new one to these systems.
Example of the Basic Script
This article shows how we can send the metrics we want from the k6 results as a message on slack. First, let’s write a simple test on k6 again.
data:image/s3,"s3://crabby-images/3a1d8/3a1d8fe3f25f81f817365b76ecbd78babe6dda79" alt=""
As you can see, we completed our test with a very simple script. Now when you run k6 in this way, it provides us an output via the terminal. But we want to get only certain data through this output. For this, k6 helps us with an excellent function. It allows us to get test results as JS object with handleSummary() function.
Magic of handleSummary() function
Let’s check it out with an example. As in our example script below, the data parameter automatically provides us with the output from within the function, you can use it the way you want to use the output in this section. For example, you can get a JSON or XML output at the same time, thanks to this function.
data:image/s3,"s3://crabby-images/e01a6/e01a677e06515e3fd8bf26b42e66b111bacba6ee" alt=""
As I mentioned above, we can normally get the results as JS objects. You can see an example of this in the output below.
data:image/s3,"s3://crabby-images/ea06d/ea06d4b1d658dff1fa9f33bf1fc2462770ced019" alt=""
We make sense of this output and determine the values we want to use. In this article, we will pull Max Throughput, HTTP Failures, Avg Response Time, and VUs values from this object as an example. We have defined the metrics we want from the data object as follows.
data:image/s3,"s3://crabby-images/a203b/a203bef96783ca9bb375affb6d8b4f85c86611a2" alt=""
Custom Slack Integration
Now let’s come to the best part of the job and create and send a custom message with slack. Here we will benefit from Slack API and Slack Block Kit Builder. First of all, we create a message template via Slack Block Kit Builder in a simple way. Then we copy this template and assign it to a variable called payload. Because this variable will be the payload that we will send through the Slack API.
Here you can find the use of Slack API and Slack Block Kit Builder.
data:image/s3,"s3://crabby-images/26299/262993adcb39bba78be843fd1f4f6bd3a28c8783" alt=""
After making the definition, we create a simple function and send a Slack API request. Before doing this, create a bot and you must transmit your bot token as a bearer token in the Authorization HTTP header. You can find more detailed procedures in the slack document.
data:image/s3,"s3://crabby-images/9b180/9b18036702c1e72514e47e5e1a791fd6e0bd43be" alt=""
As you can see in the function below, we first change the message we will send in the payload we defined according to our own metrics.
data:image/s3,"s3://crabby-images/bc42f/bc42fb2d9730102ae10f084ded462a6eef32b343" alt=""
And finally, we send the slack API request. Now we call this slack function from handleSummary() and we get our slack message.
data:image/s3,"s3://crabby-images/991aa/991aa00f4113d99ed9216a040d57eef1652f7fe0" alt=""
Let’s see the result……
data:image/s3,"s3://crabby-images/d17e7/d17e70a1750196e5d12c4eeb129945f027f168ea" alt=""
Now you can send the results you want as a slack message. 🥳