Skip to main content

How to Fix Software Product Delivery

The Way I Approach Software Delivery When There Are Signs of Issues

I've yet to see a company that is entirely happy with its pace of software delivery. In scaled organizations, delivery bottlenecks often emerge, slowing down releases, frustrating teams, and impacting business outcomes. Many companies attempt quick fixes—throwing more resources at the problem, increasing deadlines, or tweaking processes—but often, these do not address the root cause of delivery issues.

A more structured approach is needed to diagnose problems in software delivery. One of the most comprehensive studies on this topic comes from Delft University, conducted for ING. Their research identifies key factors influencing on-time delivery in large-scale Agile software development. In this article, I'll walk through how I approach analyzing delivery issues in scaled product and software development organizations, using insights from this research and my own experience.

Analyze First: Identifying Root Causes of Delivery Issues

Before jumping to solutions, it's critical to analyze the root causes of delivery slowdowns. My approach involves a multi-dimensional analysis based on structured data collection, conversations, and self-assessments.

The Dimensions of Root Cause Analysis

From my experience, the most effective root cause analysis covers a wide range of factors. The Delft University study categorizes these into five key dimensions:

  1. Organizational Factors – Alignment, executive support, and company-wide priorities.
  2. Process Factors – Agile maturity, workflow efficiency, and backlog management.
  3. Project Factors – Dependencies, complexity, and security requirements.
  4. People Factors – Team stability, experience, and communication effectiveness.
  5. Technical Factors – Code quality, test automation, and deployment pipeline robustness.

Each of these dimensions can significantly impact delivery timelines, and analyzing them holistically provides a clearer picture of what is slowing down releases.

How to Gather Insights

To conduct a root cause analysis effectively, I typically use a combination of methods:

  • Surveys – Collecting structured responses from engineers, product managers, and other stakeholders.
  • One-on-One Conversations – Speaking directly with team members to understand the practical challenges they face.
  • Self-Assessments – Encouraging teams to score themselves across key delivery criteria.
  • Data Analysis – Reviewing historical delivery performance, cycle times, and dependency graphs.

Scoring and Benchmarking

Each of these criteria is evaluated using a scoring system. This provides an objective way to compare different teams, projects, and areas of improvement. It also helps identify systemic issues rather than treating every delivery problem as an isolated case.

Next Steps: Prioritizing and Addressing the Root Causes

Once you’ve identified the key bottlenecks, the next step is to prioritize and address them systematically. In my next post, I’ll discuss how to design interventions that lead to sustained improvements in software and product delivery performance.

By taking a data-driven and structured approach, organizations can move beyond gut feelings and knee-jerk reactions, creating a more predictable and efficient software delivery process.


Full criteria catalog

OrganizationOrganizational alignment across departments
Dealing with geographic distribution
Organizational politics
Executive support
Stability of the organization
ProcessRefinement of requirements
Agile Maturity
Regular Software delivery
Management of work in progress
User / customer involvement
ProjectProject newness
Project Size
Task dependencies
Project security or regulatory constraints
PeopleCommunication
Team familiarity
Team commitment
Team stability
Skills and knowledge
TechnicalInfrastructure reliability
Code documentation
Technical dependencies
Bug or incident handling
Code quality
Testing

Reference

This article is based on the research conducted by Delft University for ING:

Kula, E., Greuter, E., van Deursen, A., & Gousios, G. (2022). Factors Affecting On-Time Delivery in Large-Scale Agile Software Development. IEEE Transactions on Software Engineering, 48(9), 3573-3586. DOI: 10.1109/TSE.2021.3101192