Home > Research > Publications & Outputs > Unveiling and Taming Liabilities of Aspects in ...
View graph of relations

Unveiling and Taming Liabilities of Aspects in the Presence of Exceptions: A Static Analysis Based Approach

Research output: Contribution to journalJournal article


  • Roberta Coelho
  • Arndt von Staa
  • Uirá Kulesza
  • Awais Rashid
  • Carlos Lucena
<mark>Journal publication date</mark>07/2011
<mark>Journal</mark>Information Sciences
Issue number13
Number of pages21
Pages (from-to)2700-2720
<mark>Original language</mark>English


As aspects extend or replace existing functionality at specific join points in the code, their behavior may raise new exceptions, which can flow through the program execution in unexpected ways. Assuring the reliability of exception handling code in aspect-oriented (AO) systems is a challenging task. Testing the exception handling code is inherently difficult, since it is tricky to provoke all exceptions during tests, and the large number of different exceptions that can happen in a system may lead to the test-case explosion problem. Moreover, we have observed that some properties of AO programming (e.g., quantification, obliviousness) may conflict with characteristics of exception handling mechanisms, exacerbating existing problems (e.g., uncaught exceptions). The lack of verification approaches for exception handling code in AO systems stimulated the present work. This work presents a verification approach based on a static analysis tool, called SAFE, to check the reliability of exception handling code in AspectJ programs. We evaluated the effectiveness and feasibility of our approach in two complementary ways (i) by investigating if the SAFE tool is precise enough to uncover exception flow information and (ii) by applying the approach to three medium-sized ApectJ systems from different application domains.