Algorithmic Analysis of the Impact of Changes to Object-oriented Software

1996 International Conference on Software Maintenance (ICSM '96), pages 171--184, Monterey, CA, November 1996.

Li Li (Michelle Lee) and Jeff Offutt

Abstract

As the software industry has matured, we have shifted from devoting our resources from being primarily devoted to developing new software systems to primary making modifications in evolving software sys tems. A major problem for developers in an evolutionary environment is that seemingly small changes can ripple throughout the system to have major unintended impacts elsewhere. As a result, software developers need mechanisms to understand how a change to a software system will affect the rest of the system. Although the effects of changes in object-oriented are restricted, they are also more subtle and more difficult to detect. This paper presents algorithms to analyze the potential impacts of changes to object-oriented software, taking into account encapsulation, inheritance, and polymorphism. This technique allows software developers to perform "what if" analysis on the effect of proposed changes, and thereby choose the change that has the least influence on the rest of the system. The analysis also adds valuable information to regression testing, by suggesting what classes and methods need to be retested, and to project managers, who can use the results for cost estimation and schedule planning.


Conference presentation:


Back to my home page.