Integrating Visual Studio App Center and Trello using Azure FunctionsNovember 3, 2017
UPDATE (11/15/17): Today Microsoft announced the general availability of Visual Studio App Center. Mobile Center is now App Center.
My current project is an awesome project. We’re using Xamarin.Forms to build beautiful native iOS and Android apps. And, if that isn’t awesome enough, we’ve totally automated the build and distribution process of these apps using Visual Studio App Center. I absolutely love App Center and how simple it makes setting up CI/CD. You can literally setup a build job in less than 5 minutes with no build host machines or any of those types of complexities that normally come with setting up CI. As you can tell I’m pretty excited we’re using App Center to automate the app builds and releases for this project. But there was one thing I was still having to do manually - updating the Trello board after each build. Clearly this must be automated as well!
On this project we use Trello for managing our backlog and current work. It is a pretty standard workflow. There are Trello cards for features, tasks, and bugs. The cards start off in the “Backlog” list and then they move to the “Doing” list when they are in progress by a developer and then they finally move to a “Done/Ready for Testing” list when they are in a build release and ready to be tested by the QA team. So while the entire build process is automated (kicked off when a PR is merged into the main develop branch) I was still having to go into Trello after each build and move the card to the “Done/Ready for Testing” list and update it with a comment containing the version and build number of the app release - a manual and tedious process that is easy to forget, so I decided to automate it as well.
Enter webhooks and Azure Functions
The App Center team is constantly adding new capabilities making it more robust and easier to use.
They recently added the ability to use scripts in build definitions which was one of my number one feature requests since App Center debuted. I’ve already started taking advantage of this feature and it’s great! In fact, I initially set out to automate the process of updating Trello cards using a post-build script. Well, until I discovered a couple weeks ago that App Center snuck in webhook triggers!
As of this post, App Center has the ability to trigger a webhook when a new crash group is created and/or when a new build release is available. This is perfect for solving my problem - When a new build is released I need to do something.
Creating a webhook triggered Azure Function
It turns out Azure Functions make setting up a webhook triggered function super easy. I’m new to Azure Functions, so this was a great excuse for me to dive in and play with them. For what I needed to do I simply used the “Webhook + API” quickstart function template and selected C# for my language preference. This set me up with a blank function that I could start adding logic to.
Below is a quick logic flow that I defined for the Azure Function:
- Get the release’s notes, version number, build number and platform (this comes through with the webhook’s json payload)
- Extract the pull request number from the release notes
- Get the pull request details from GitHub using the GitHub API
- Extract the Trello card identifier from the pull request body
- Add a comment to the Trello card containing the release details using the Trello API
- Move the Trello card to the “Done/Ready for Testing” list using the Trello API
As you can see, this logic relies on some specific procedures, for example, including the Trello card URL in pull requests. In my experience, it is not uncommon to include some sort of card or issue identifier in a pull request description - the easiest way to do this with a Trello card is to just copy and paste in the card’s share URL.
The actual code for this Azure Function is pretty simple - just some basic pattern matching and HTTP calls. I’ve made the function I used available in a Gist.
Once you’ve added your Azure Function the only thing you need to do is copy the function’s URL and add it to a new webhook in your app’s settings in App Center.