Metrics and Dashboards

All about collecting metrics from sfpowerscripts

Metrics should be a key part of your DevOps process. It is through these metrics, one can drive continuous improvement of your delivery process. Almost all commands in sfpowerscripts, are instrumented with StatsD as well as Log Based Metrics.

Getting started with Metrics

Stats D

# Set STATSD Environment Variables for logging metrics about this build
export SFPOWERSCRIPTS_STATSD=true
export SFPOWERSCRIPTS_STATSD_HOST=172.23.95.52
export SFPOWERSCRIPTS_STATSD_PORT=8125 // Optional, defaults to 8125
export SFPOWERSCRIPTS_STATSD_PROTOCOL=UDP // Optional, defualts to UDP, Supports UDP/TCP

Log Based Metrics

sfpowerscripts is also able to generate metrics in a log file. These metrics are written to .sfpowerscripts/metrics.log in your working directory. This log file after every run of a command could be send to a log aggregator for further analysis.

The JSON payload consist of the the following, name of the metric (metric), type of the metric such as count, guage or timers ( type ), timestamp (timestamp) and followed by tags pertaining to the particular metric (tags)

A sample metric is shown below

{"metric":"sfpowerscripts.build.scheduled.packages","type":"count","timestamp":1616475396815,"tags":{"package":"core-crm","type":"Unlocked","is_diffcheck_enabled":"true","is_dependency_validated":"true","pr_mode":"false"}

One could write a parse this file, and then send each individual entries to a logging system that allows JSON based logging.

Metrics available within sfpowerscripts

The following are the list of metrics that are captured.

METRIC

DESCRIPTION

TYPE

sfpowerscripts.deploy.failed

Number of times deploy command failed

COUNT

sfpowerscripts.deploy.duration

Time spent on executing deploy command

GAUGE

sfpowerscripts.deploy.scheduled

Number of times deployment was scheduled to run

COUNT

sfpowerscripts.deploy.scheduled.packages

Number of packages that were scheduled to be deployed by the deploy command

GAUGE

sfpowerscripts.deploy.succeeded

Number of succeeded deploy executions

COUNT

sfpowerscripts.deploy.succeeded.packages

Number of packages that were successfully deployed

GAUGE

sfpowerscripts.deploy.failed

Number of times deploy command failed to execute

COUNT

sfpowerscripts.deploy.failed.packages

Number and details of packages that failed to deploy

GAUGE

sfpowerscripts.build.scheduled

Number of times build was scheduled to run

COUNT

sfpowerscripts.build.duration

Time spent on executing build command

GAUGE

sfpowerscripts.build.scheduled.packages

Number of packages being scheduled to build

GAUGE

sfpowerscripts.build.succeeded.packages

Number of packages successfully built

GAUGE

sfpowerscripts.build.failed.packages

Number of packages failed to build

GAUGE

sfpowerscripts.validate.failed

Number of time validate failed to execute

COUNT

sfpowerscripts.validate.duration

Time spent on executing validate command

GAUGE

sfpowerscripts.publish.duration

Time spent on executing publish command

GAUGE

sfpowerscripts.publish.succeeded

Number of succeeded publish executions

COUNT

sfpowerscripts.package.installation

Number of times a package was installed

COUNT

sfpowerscripts.package.installation.elapsed_time

Time taken to install a package

GAUGE

sfpowerscripts.package.elapsed

Time taken to create a package

GAUGE

sfpowerscripts.package.created

Number of times a particular package was created

COUNT

sfpowerscripts.package.metadatacount

Number of metadata in a package

GAUGE

sfpowerscripts.package.testcoverage

Test Coverage of a package

GAUGE

sfpowerscripts.apextests.triggered

Number of times apex tests were triggered for a package

COUNT

sfpowerscripts.apextest.testtotal

Time taken for Apex Test Execution

GAUGE

sfpowerscripts.apextest.command.time

Time taken for Apex Test Execution (Command Time)

GAUGE

sfpowerscripts.prepare.succeededorgs

Number of orgs that were succeeded during a run of prepare

GAUGE

sfpowerscripts.prepare.failedorgs

Number of orgs that failed during a run of prepare

GAUGE

sfpowerscripts.prepare.duration

Time take to prepare a pool of scratchorgs

GAUGE

sfpowerscripts.pool.remaining

Number of scratch orgs that are remaining in a pool after fetched by validate command

GAUGE

Sample Dashboards

Package Status Dashboard
Package Weekly Status