- Published on
Blinka - Connecting Heroku CI to Github
- Author
- Name
- David Wessman
- @davidwessman
Heroku CI (continuous integration) runs tests in an environment very similar to an Heroku application, the code is packaged into a slug and runs on a dyno.
With Heroku's Github Integration it can automatically run CI-builds for every commit, then report back to Github with a pass or fail status and a link. The test results can be parsed if they are reported in the TAP-format, but it still stays on Heroku and is not visible on Github.
data:image/s3,"s3://crabby-images/2e174/2e174cce3ec9c4f956efe04e660c367ef5caf25e" alt="Heroku status reported to Github without any test results, just pass or fail."
This is why I built Blinka🚦!
Setup
- Configure your application for Heroku CI.
- Install
blinka-reporter
by adding it toGemfile
using
bundle add blinka-reporter
- Get
BLINKA_TEAM_ID
andBLINKA_TEAM_SECRET
from Blinka🚦 - the only way to do this today is reaching out to me on Twitter Twitterdavidwessman. - Add the values from step 3 to Heroku CI environment variables.
- Add the Github App blinka-bot to the repository.
- Add Blinka-configuration to the testing part of the Heroku configuration in
app.json
. Mine looks like:
"environments": {
"test": {
"addons": [
"heroku-postgresql:in-dyno",
"heroku-redis:in-dyno"
],
"buildpacks": [
{
"url": "https://github.com/heroku/heroku-buildpack-google-chrome"
},
{
"url": "https://github.com/heroku/heroku-buildpack-ruby"
}
],
"env": {
"BLINKA_REPORT": "true",
"BLINKA_REPOSITORY": "davidwessman/synka",
"BLINKA_TAP": "true",
"WD_CHROME_PATH": "/app/.apt/usr/bin/google-chrome-stable"
},
"formation": {
"test": {
"quantity": 1,
"size": "standard-2x"
}
},
"scripts": {
"test-setup": "bin/yarn && bin/rails webpacker:compile",
"test": "bin/rails test:system test"
}
}
}
- Before
blinka-reporter
version 0.3.3 you had to do the reporting in a separate step, this has now been replaced by usingBLINKA_REPORT=true
.
Bonus
The gem blinka-reporter
also supports outputting test results in TAP-format, without depending on anything but minitest.
Enable by setting the envionment variable BLINKA_TAP=true
. This allows Heroku to parse the results and report them in their interface.
Results
With failing tests
The tests run on Heroku CI and with the TAP-format output we get some feedback in the Heroku interface.
data:image/s3,"s3://crabby-images/0dacf/0dacffd639a616925926531cf3ccf420e0c1c2f4" alt="Test results in Heroku CI interface with one failing test"
The test results are reported to Blinka🚦 which results in a Github Status:
data:image/s3,"s3://crabby-images/ba412/ba412f54ad8d52cc38195a169caa12eabb62d271" alt="Blinka reports number of tests passed, failed or skipped as a Github Status."
A comment with the results of the CI-run is posted:
data:image/s3,"s3://crabby-images/641b4/641b46b7e6c0fc15fe848ae0b3796ee61de0285c" alt="Blinka posts a comment on Github pull request with test results."
It can even handle screenshots generated from a failing test, upload them to the service and include them in the comment:
data:image/s3,"s3://crabby-images/ffcd4/ffcd4ed2df656e2295c8dfaa8f73902bd3f6040b" alt="Blinka includes screenshot from failing test in the Github comment"
Please reach out to me on Twitter if you want to learn more!