Benchmarking Release Management

29
March, 2018

by Niall Crawford

“It goes without saying, that the backbone of all organizations today is digital and independent of the end-products you provide”.

 

Digital the Backbone of Business /

It goes without saying, that the backbone of all organizations today is digital and independent of the end-products you provide, there is an inherent need to drive your features and solutions from conception (the initial idea) through to production (the end customer) as quickly, safely and efficiently as possible.

  • That is, every organization requires effective IT Release Management.

So, what is IT Release Management? Let us start with a definition (or two):

From Wikipedia:

Release management is the process of managing, planning, scheduling and controlling a software build through different stages and environments; including testing and deploying software releases.

Enterprise release management is a multi-disciplinary IT governance framework for managing software delivery and software change across multiple departments in a large organization.

The former is what a DevOps engineer might gravitate to i.e. someone with the task of building and deploying code to their individual system or services.

And the latter something that might be handled by an Enterprise Release Manager (or Portfolio Manager), that is someone interested in coordinating a family of system/project releases using methods like SAFe (Scaled Agiile Framework) “Agile Release Trains” to maintain collective velocity, phase alignment, and a unified implementation.

A Visual Definition of Release Management

Alternatively, consider the following diagram.

Holistic Release Management is a combination of Vertical Practices responsible for supporting delivery through the system lifecycle (i.e. Analysis, Design, Development, Test, and Implementation), a set of Horizontal Practices responsible for driving transformation across the enterprise (or divisions).

Measuring Release Management

Independent of whether your perspective is vertical (system focused) and/or horizontal (enterprise focused), there is little argument in the importance of getting both activities completed correctly and having the various teams working together as effectively as possible.

However, agreeing on benchmarking may not be trivial as the two tasks, although obviously related, are quite different.  With the above in mind, we decided to put together two sets of release metrics that we thought would be useful in providing insight with respect to current release behaviour and capability.

  • The ten best metrics for Enterprise Release Management (ERM)
  • The ten best metrics for Release Management (aka System Deployment)

Note: Special thanks to some of our enov8 customers for sharing some of these.

Enterprise Release Management (ERM) Metrics

Whom: Typically, the responsibility of an IT Enterprise Release Manager the main goals are to ensure that a family of project releases (changes), which are often related and contain dependencies, can move through the software development lifecycle, from conception to production, in a controlled and aligned fashion.

Key data & trends, to be captured would be:

  1. Size of Enterprise Release by Projects (Project Releases Registered)
  2. Size of Enterprise Release by System Deployments
  3. Size of Enterprise Release by Features (or Stories)
  4. Project Releases Status (Success/Failure)
  5. Project Releases Delivered on Time
  6. Project Release Delay
  7. Number of Project De-Scoped*
  8. Number of Systems De-Scoped*
  9. Number of Features De-Scoped*
  10. Root Cause of Project Release Delay

*Note: In Enterprise release management, de-scoping is most typically caused by a project failing to meet its release gate obligations and being removed from the enterprise release as quickly as possible and thus avoid an impending “train crash’.

Release Management (System Deployment) Metrics

Whom – Typically, the responsibility of a DevOps “System Release” Engineer, the main goals are reliability and velocity i.e. the engineer wants to get the job done as safely and quickly as possible.

Key system deployment data & trends would be:

  1. System Deployment Frequency
  2. System Deployment Feature (Story) Size
  3. System Deployment Status (Success/Failure)
  4. System Deployment Time (ideally versus SLA)
  5. System Deployment Outage Time (outage time for deployment itself)
  6. System Post-Deployment Outage Time (outage caused by unsuccessful deployment)
  7. System Post-Deployment Incidents (Tickets) due to a deployment
  8. Mean Time to issue detection
  9. Root Cause of System Deployment Issue (Delay, Incident or Outage)
  10. Mean Time to remediation

Note: In the case of DevOps you would expect these metrics to be of use across the lifecycle. Therefore, the word ‘System’ could quite logically be replaced with ‘System Instance’, where you would have Instances in Integration, UAT, Staging & Production.

Food for thought

Hopefully, you found some of the above release metrics useful & maybe thought-provoking.

Ultimately metrics need to be aligned with your own operating model.

However, in closing we’d say this:

Good release metrics should always do the following:

  • Clarify release strategy i.e. direct good practice
  • Understand existing release capability i.e. strengths & weaknesses and
  • Drive release enhancement i.e. continuous improvement

What else would you add to the above “Release Management” Metrics?

Further Reading

  • Understand the association between Enterprise release management & DevOps:

Ref: ERM – The bridge between corporate strategy & DevOps

  • Releases need Environments, Non-Production Environment Metrics:

Ref: Test Environment Management Metrics

Learn More or Share Ideas about Release Management & Enterprise Release Management

If you’d like to learn more about Release Management or perhaps just share your own ideas then feel free to contact the enov8 team. Enov8 provides a complete platform for addressing organizations “DevOps at Scale” requirements. Providing advanced “out of the box” IT & Test Environment ManagementRelease Management and Holistic Data Management capabilities.

Our Key solutions include

 

 

 

 

 

 

Niall Crawford

Niall is the Co-Founder and CIO of Enov8. He has 25 years of experience working across the IT industry from Software Engineering, Architecture, IT & Test Environment Management and Executive Leadership. Niall has worked with, and advised, many global organisations covering verticals like Banking, Defence, Telecom and Information Technology Services.

Relevant Articles

Types of Test Data: 4 to Use for Your Software Tests

Types of Test Data: 4 to Use for Your Software Tests

Testing is an integral and vital part of creating software. In fact, test code is as important as your production code. When you create test code, you need to create test data for your code to work against. This post is about the different types of test...

SAFe Release Management in the Enterprise

SAFe Release Management in the Enterprise

In the world of enterprise software, release management is a crucial process that ensures the successful planning, execution, and monitoring of software releases. As the name suggests, release managers are responsible for coordinating various stakeholders, including...

11 Data Masking Tools to Ensure Data Privacy

11 Data Masking Tools to Ensure Data Privacy

As organizations collect, process, and replicate data across more systems than ever before, the risk of exposure increases dramatically. Sensitive information that’s safely stored in production databases often becomes vulnerable when copied into test, training, or...

DevSecOps vs Cybersecurity: Understanding the Relationship

DevSecOps vs Cybersecurity: Understanding the Relationship

Both DevSecOps and cybersecurity are gaining a lot of interest and demand in the IT industry. With everything going digital, security has become one of the main focuses of every organization. And DevSecOps and cybersecurity are the supreme practices to achieve high...

What is Test Data? Understanding Its Role in Testing

What is Test Data? Understanding Its Role in Testing

Test data is the lifeblood of testing – it’s what enables us to evaluate the quality of software applications across various industries such as healthcare, insurance, finance, government, and corporate organizations. And, reminiscent of actual lifeblood, testing would...

11 Important Application Rationalization Benefits

11 Important Application Rationalization Benefits

In most enterprises, the number of applications in use has grown far beyond what’s practical to manage. And that's putting it mildly. Each department tends to adopt tools to meet its own needs, sometimes duplicating functionality that already exists elsewhere. Over...