icon-carat-right menu search cmu-wordmark

Locating the Architectural Roots of Technical Debt

Presentation
This talk presents a case study of identifying architecture debts in a large-scale industrial software project by modeling software architecture as design rule spaces.
Publisher

Software Engineering Institute

Topic or Tag

Watch

Abstract

In our studies of many large-scale software systems, we have observed that defective files seldom exist alone. They are usually architecturally connected, and their architectural structures exhibit significant design flaws that propagate bugginess among files. We call these flawed structures the architecture roots, a type of technical debt that incurs high maintenance penalties. Removing the architecture roots of bugginess requires refactoring, but the benefits of refactoring have historically been difficult for architects to quantify or justify. In this talk, we present a case study of identifying and quantifying such architecture debts in a large-scale industrial software project. Our approach is to model and analyze software architecture as a set of design rule spaces (DRSpaces). Using data extracted from the project’s development artifacts, we were able to identify the files implicated in architecture flaws and suggest refactorings based on removing these flaws. Then we built economic models of the before and (predicted) after states, which gave the organization confidence that doing the refactorings made business sense, in terms of a handsome return on investment.

This content was created for a conference series or symposium and does not necessarily reflect the positions and views of the Software Engineering Institute.