Hello! I posted a question a while back on a related topic - and done a bit of followup searching... Couldn't find anything great to start with, so I figured I'd just throw out a discussion about it - tracking metrics over time.
We've got some obvious metrics that would be nice to capture/compare in a long-term manner - eg: to help us see the progress we're making working through old tech debt in the form of fewer linter warnings, improved code coverage and the like...
We've got a couple of ways of doing this in mind so far:
Just wondering how much I've missed - something in Pipelines that can store this information (I'd seen mention of Metrics, but not as something functional). It'd be great to hear from anyone who's had some success to get some ideas (and warnings of what not to do!)
For context - my old post about failing builds for a "no new eslint warnings" quality gate - got there in the end, but the specific solution we used won't transfer to all types of metric:
Just to follow up on this, I think we're likely to go with a shell-scripted option - probably Azure Table Storage due to already having Azure CLI hooked up for these builds (though AWS DynamoDB looked like another perfectly good option). Rough script is below (though it's not tested so probably won't work as-is!)
- step: &linter
script:
# Insert some scripts here that run a linter
- echo 10>metrics/lintWarnings
- echo 0>metrics/lintErrors
artifacts:
- metrics/**
- step: &metrics
name: Store Code Metrics
image: mcr.microsoft.com/azure-cli
script:
- az login --service-principal --username ${AZURE_APP_ID} --password ${AZURE_PASSWORD} --tenant ${AZURE_TENANT_ID}
- az storage entity insert --account-name vlqrdevstorage --table-name CIBuildMetrics --entity PartitionKey=${$BITBUCKET_REPO_SLUG} RowId=${BITBUCKET_COMMIT} LintWarnings=$(cat metrics/lintWarnings) LintErrors=$(cat metrics/lintErrors)
That can then give us a central drop-point for build-info, which we can then either link into a reporting tool, or definitely-not-a-reporting-tool-but-it'll-do-for-now (ie: Excel).
I'm aware the cross-step state handling isn't perfect - but just left in as an example.
Online forums and learning are now in one easy-to-use experience.
By continuing, you accept the updated Community Terms of Use and acknowledge the Privacy Policy. Your public name, photo, and achievements may be publicly visible and available in search engines.
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.