As new versions of software are developed bugs inevitably arise either due to regression or new functionality. Challenges arise in discovering, managing, and testing the impact of changes on software. These challenges are magnified in software systems that evolve, because the new functionality is piece-wise introduced into a live program with prior state produced by the prior component versions. If new functionality introduced into a live system induces bugs, it can be extremely difficult to analyze at run-time exactly which differences led to the incorrect behavior. In order to help programmers plan for evolution, understand the impact of specific evolutionary steps, and to diagnose evolution gone wrong, herein we propose combining the benefits of Aspect-Oriented Programming and reflection with impact analysis techniques from the OO and software engineering disciplines. We contribute a tool that assists with the deployment of new code to evolving software that gives insight as to precisely the behavioral changes between the new code and the code it is replacing within the running system. This tool is implemented using pure aspect-oriented and reflection techniques, and we discuss how to combine this tool with a load-time aspect weaver to allow precise determination of the cause of bugs introduced in live, evolving systems. We conclude by considering the challenges of implementing and deploying such a tool and outline our plans for future research and evaluation.
[1]
Gregg Rothermel,et al.
Whole program path-based dynamic impact analysis
,
2003,
25th International Conference on Software Engineering, 2003. Proceedings..
[2]
Alessandro Orso,et al.
Leveraging field data for impact analysis and regression testing
,
2003,
ESEC/FSE-11.
[3]
Suresh Jagannathan,et al.
Sieve: A Tool for Automatically Detecting Variations Across Program Versions
,
2006,
21st IEEE/ACM International Conference on Automated Software Engineering (ASE'06).
[4]
A. Orso,et al.
Efficient and precise dynamic impact analysis using execute-after sequences
,
2005,
Proceedings. 27th International Conference on Software Engineering, 2005. ICSE 2005..
[5]
Frank Tip,et al.
Chianti: a tool for change impact analysis of java programs
,
2004,
OOPSLA.