So you’ve decided to go CI/CD. You read all about the org changes, understand the ins and outs of the development pipeline, and feel confident you can get it done.
Congratulations!
After you set up your pipelines, document your dev practices, and start pushing to prod, there’s still a major piece of the puzzle that needs addressing. The changelog.
How do you do it? Do you add a tech writer to your development team who can keep up with 5, 10, 20 pushes to production a day? You could, yes. But what if there was a way to automate it?
You already have an issue tracking system. We use Jira at my office. Whether you use Jira, GitHub, or Trello to track issues, they all have one thing in common - webhooks.
Each one of these systems fires events when certain actions take place in the system. And we’re going to use them to automate our changelog.
There are three systems in play for a continuous changelog:
In our automation, the events flow like this:
Seem simple? It is!
This is the kind of integration that pays off 1000x in the long run. It is a low cost to implement, high return on value integration.
In my GitHub repo, I provide the source to deploy the microservice from the architecture diagram above. It uses AWS API Gateway and DynamoDB as the two primary services for storing and retrieving data.
The back end only has two endpoints, one to create an item in the changelog, and another to load items from it.
Saving and loading are done in VTL, omitting the need for lambda functions entirely. This gives us the fastest response times possible.
Since we don’t want malicious users discovering our API and posting bogus or inappropriate changes to our changelog, we need to add an API key. We can’t add standard auth to verify our users since these requests are going to be coming through a webhook.
Jira provides the ability to include headers when publishing to a webhook, so we will take advantage of this and include an AWS API key. This key is included in the CloudFormation script in the repository.
If you follow the README in the GitHub repo, you will be up and running with minimal effort. It comes all pre-wired, so no setup is necessary besides deploying into your AWS account.
Now that we have our API up and running, it’s time to configure Jira to feed the changelog data.
We need to add a custom field to our Jira issues. From within Jira, navigate to Settings > Jira Administration > Issues.
Once you are viewing the issues admin page, navigate to Fields > Custom Fields > Add custom field.
Changelog descriptions can get a little wordy, so select a Text Field (multi-line), give it the name Changelog
and add a description that lets the users know the format they should type in their change details.
Next, choose your screens you want the changelog field visible on. If you want it in all your Jira projects, select them all!
With the custom field in place, it’s time to build the automation trigger that posts to the webhook.
In your Jira project, go to Project Settings > Project Automation > Create Rule.
Select the Issue transitioned trigger type and optionally set the From status and To status on the next screen.
Note - The To status field should be set to whatever the final status is in your workflow. On my project, our final workflow status is Done.
Once you have configured the trigger, it’s time to set up the action for Jira to take. Click on New Action to bring up the list of options.
Select the Send web request action to bring up the configuration screen.
Now we need to take a trip back into the AWS console. First, we need to get the url of the webhook we created.
/details
at the end.x-api-key
and paste the api key in the value field.Give your automation a meaningful name on the next screen and hit the Turn it on button to complete your integration!
At this point, the integration and API are connected, and you can start closing issues! It will automatically add changelog details along with the issue type and date it was completed.
Once you have some issues moved over, let’s take a peek at what it looks like. I have provided a skeleton Angular front end in the GitHub repo so you can view the changelog right away.
The changelog is grouped by day and has an icon next to the details based on the Jira type that was closed. For my project, a New Feature Jira type will display the NEW icon, while a Bug issue type displays a bug icon.
These are customizable to your project, so feel free to play around with icons and issue types.
I could cut you loose right here, but what kind of responsible blogger would I be if I didn’t talk about the organizational governance needed for this?
Following this route leaves a few questions you need to have answered by your organization:
These are for you and your org to figure out. Sure it’s easiest to let the developers add in the details and be done, but is it the safest? Do you want all changes to be logged for the public to see?
This is a fast integration to set up and leads to some pretty fun results. I hope you give it a try and bring a continuous changelog to your project.
Do you do something like this? Do you do something totally different? Let me know your thoughts and opinions!
Thank you for subscribing!
View past issues.