We have over 12,000 students, from over 100 countries, within one of the safest campuses in the UK


97% of Lancaster students go into work or further study within six months of graduating

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

« Back

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
Number of pages21
<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.