Creating Status Badges and Shields for your Repository
I recently added status badges to the Readme file for the open source project I maintain, RogueSharp. I’ve seen other repositories do this but I wasn’t sure how. After a lot of looking around I compiled a list of services that worked for me. I couldn’t seem to find all this information in one place, so I’m hoping that this post showcasing what worked for me will help others.
Shields.IO
Shields.IO is a service for creating concise, consistent, and legible badges in SVG format. This should be your first stop when looking for a particular badge.
Resource Links
data:image/s3,"s3://crabby-images/a356b/a356b2c0c4fe8c0aa738940a19fa01862d09c65c" alt="MIT license badge alt text"
I use Shields.IO to create badges that link to static resources. To create these you just need a specially formatted URL.
https://img.shields.io/badge/LABEL-MESSAGE-COLOR.svg
To create a blue badge for a BSD 3-Clause license we could use
https://img.shields.io/badge/license-BSD%203--Clause-blue.svg
Because our license has a space and a dash in it we will need to treat those specially. The space will need to be replaced with it’s equivalent URL encoding “%20” and the dash will need to be escaped with a preceding dash.
Finally we need to decorate it with the appropriate markdown to get it to display as an image which links to the license.
[data:image/s3,"s3://crabby-images/3b91d/3b91d6f3b45bb09d9992e268370c3f71cd70ff84" alt="License: BSD 3-Clause"](https://github.com/TechSmith/hyde/blob/master/LICENSE.txt)
data:image/s3,"s3://crabby-images/fba30/fba309df7228c639541e1a93936d2488f9859b94" alt="BSD-3 License badge alt text"
Test Status
data:image/s3,"s3://crabby-images/e10d9/e10d9321009c65c5b840eaa0d42d7ed2379c61fa" alt="Count of passing tests badge alt text"
It’s likely that no matter which service you are using for running continuous builds, Shields.IO also has you covered.
The formatted URL to get a test status badge for an Azure DevOps pipeline project will look like this:
https://img.shields.io/azure-devops/tests/ORGANIZATION/PROJECT/DEFINITION_ID.svg
When I did this for my own repo I wasn’t quite sure how to fill out “ORGANIZATION”, “PROJECT” and “DEFINITION_ID” placeholders.
What I found is that you can pull these directly from the query string when going to Azure DevOps and viewing your continuous build. In my case the URL is:
https://dreamersdesign.visualstudio.com/RogueSharp/_build?definitionId=1
In this example “dreamersdesign” is the organization, “RogueSharp” is the project and “1” is the definition ID.
Code Coverage
data:image/s3,"s3://crabby-images/0866e/0866e72eedecc69d6b2085c078e7f196bc88e837" alt="Test coverage badge alt text"
Shields.IO also supports code coverage badges for multiple build services.
The formatted URL for Azure DevOps looks like this:
https://img.shields.io/azure-devops/coverage/ORGANIZATION/PROJECT/DEFINITION_ID.svg
You’ll notice it looks like the test status badge, only replacing “tests” with “coverage”
BuildStats.info
Even though Shields.IO supported most of what I needed it didn’t support everything. It looks like development keeps happening on the service, so perhaps that will have changed by the time you read this. For my remaining badges I turned to BuildStats.info.
BuildStats.info creates SVG widgets to display build history charts and NuGet badges.
NuGet
data:image/s3,"s3://crabby-images/46d07/46d07dce3b74699153884470c0bbd11595504188" alt="NuGet successful build badge alt text"
This one couldn’t be simpler. Just create a URL to
https://buildstats.info/nuget/PACKAGE_NAME
So for RogueSharp this was just
https://buildstats.info/nuget/roguesharp
It will automatically pull in the latest version number as well as the number of downloads.
Build History Chart
data:image/s3,"s3://crabby-images/8de01/8de019795e5470a4ba19518fc30887f1d0f68d2f" alt="Build history chart alt text"
At the time that I setup my badges, BuildStats.info didn’t support the Build History Chart for Azure DevOps. It does look like this is now supported, but for my chart I used AppVeyor.
The formatted URL looks like this:
https://buildstats.info/BUILD_SYSTEM/chart/ACCOUNT/PROJECT
Substituting the values for my repository this yielded:
https://buildstats.info/appveyor/chart/FaronBracy/roguesharp-20n28
Build Service Specific
It’s worth noting that many build services provide their own status badge links. They probably won’t provide you with anything that you can’t get with Shields.IO, but it may be worth looking into.
Azure DevOps
data:image/s3,"s3://crabby-images/a0f60/a0f60e313f83e0fc81cd89dfbbec26b53ab43127" alt="Azure Pipelines build succeeded badge alt text"
When you are looking at your build pipeline you’ll see an elipsis for the build… click that.
data:image/s3,"s3://crabby-images/3bfd1/3bfd14c4b45c564653df05d26dbe91975ad9a0e0" alt="Azure DevOps edit menu alt text"
Then click on Status badge
data:image/s3,"s3://crabby-images/133d5/133d588378deb910c48ebf18ad9c425b4f69628d" alt="Azure DevOps status badge screen alt text"
This will give you markdown that you can copy and paste directly into your readme.
AppVeyor
data:image/s3,"s3://crabby-images/b7adc/b7adc9434f1b7cd3fa068a3b185fd6c06304adc8" alt="AppVeyor passing build badge alt text"
Click on AppVeyor configuration for a repo (the gear icon). Then select “Badges” from the tabs on the left.
data:image/s3,"s3://crabby-images/fd42e/fd42ed3017595568dc76e9a87f35947b64359cca" alt="AppVeyor configuration screen alt text"
This will give you markdown that you can copy and paste directly into your readme.
About Faron
Faron Bracy is a husband, father, and TechSmith employee. He maintains the open source library RogueSharp as a hobby project. Other hobbies include painting fantasy miniatures, playing board games, and playing retro video games with his family.