Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
events:workshops:laosd08:summaries [2008/06/16 16:53] – etanter | events:workshops:laosd08:summaries [2008/06/26 14:09] (current) – etanter | ||
---|---|---|---|
Line 1: | Line 1: | ||
+ | ==== Verification Approaches for AO Programs (Pothier, Masiero, Coelho) ==== | ||
+ | |||
+ | **Goals**: Investigating the impact of verification tools and approaches on the reliability and verification time of AO programs; and proposing tools and approaches to support the verification process. | ||
+ | |||
+ | **Problem**: | ||
+ | During the verification process of an AspectJ system, the developers usually apply ad hoc approaches to check the reliability of the program, such as: writing and executing functional tests, adding logging statements, or performing smoke testing (i.e., they execute the application and uses it until a failure occurs). \\ | ||
+ | Some tools and approaches have been proposed that aim at detecting and diagnosing specific faults in AO programs, but no empirical study was conducted to asses their effectiveness. | ||
+ | |||
+ | **Proposed Approach**: Our approach to tackle this problem is twofold: (i) to conduct an experimental study to assess the effectiveness of a set of tools proposed by our group, and (ii) to evaluate the opportunities of tool integration.\\ | ||
+ | The experimental study is going to be our first short/ | ||
+ | In parallel we are going to evaluate the possibilities of integrating the three tools. Firstly, Roberta and Guillaume will work on integrating the SAFE tool into Eclipse, potentially reusing the data base structure and some GUI components of TOD - it will avoid a bias caused by the non-user-friendly textual output of SAFE. Secondly, we are going to investigate the use of the set of tools (i.e., TOD, SAFE and JABUTi) through a web interface. A third step would be the integration of the data structures of the three tools, as a way of enabling a synergy between static analysis, structural testing and debugging. For instance, the developer could navigate through the data collected during structural tests and static analysis while debugging. | ||
+ | |||
+ | {{laosd08-testing.pdf|Detailed report}}. | ||
+ | |||
+ | |||
+ | ==== Product Line Testing (Maldonado, Rossel, Toledo) ==== | ||
+ | |||
+ | This group has the task to investigate testing criteria, techniques and tools adequate to PL testing. At the very end, the aim is to contribute to the establishment of low-cost, efficient testing strategies in the context of PL development, | ||
+ | |||
+ | {{laosd08-pltesting.pdf|Detailed report}}. | ||
+ | |||
+ | ==== Programming Languages (Borba, Tanter, Tulio) ==== | ||
+ | |||
+ | The main objective of this group is to bring to AO well-known benefits of traditional modularization mechanisms. Particularly, | ||
+ | the implementation of classes and aspects. After that, we have sketched our first proposal of crosscutting interfaces, that addresses the main drawbacks of the existent proposals. | ||
+ | |||
+ | Basically, our proposal unifies the notions of aspects and classes, removing the differences among such concepts. For example, in our proposal classes can declare pointcuts, advices and intertypes. By relying in our interfaces, | ||
+ | developers can work in a independent way, having the right to access interface members implemented by other modules. In a last step, developers can configure an application using the instantiation mechanisms supported by the language. | ||
+ | |||
+ | We have discussed and showed examples of applying our language in the implementation of the Observer design pattern and in automated case tests for software product lines. | ||
+ | |||
+ | Next steps: | ||
+ | - Definition of the language' | ||
+ | - Implementation of more examples using the language. | ||
+ | - Definition of the language' | ||
+ | - Implementation of a prototype compiler or interpreter. | ||
+ | - Paper to a major venue (eg. FSE' | ||
+ | |||
+ | Next meeting: SBLP 2008, August 27-29, Fortaleza | ||
+ | |||
+ | |||
+ | ==== Model Driven Development (Perovich, Piveta, Vignaga) ==== | ||
+ | |||
+ | The objective of this group is to investigate the applicability of aspect-oriented techniques and concepts to Model Driven Development. On a first stage we focus on model transformations, | ||
+ | |||
+ | A widely known classification of model transformation approaches acknowledges that aspects and reflection mechanisms can be used with model transformation languages. However we found that aspects are explicitly addressed, but not precisely specified, in one transformation language only, which is not rule-based. | ||
+ | |||
+ | The first research question to investigate is what targets of aspects in model transformation languages could be. We considered two alternatives: | ||
+ | |||
+ | Aspect-orientation concepts extended traditional software development in a useful way. We aim for finding if similar benefits can be introduced in model transformation development. As we found that this issue is not obvious, we plan to summarize the result of the research described above as a challenge to be submitted to the Challenges in Model Driven Engineering (ChaMDE) workshop associated to MoDELS' | ||
+ | |||
+ | |||
+ | |||
+ | ==== Product Lines (Bastarrica, | ||
+ | |||
+ | The main goal of this group is to define a model-based aspect-oriented software product | ||
+ | line (SPL) development environment, | ||
+ | Product Line Architecture), | ||
+ | architecture. MaRiPLA applies (i) aspect-oriented software development (AOSD) to | ||
+ | modularize variability and (ii) model-driven development (MDD) to express models of | ||
+ | each software activity and to define model transformations between requirements and | ||
+ | architecture activities. | ||
+ | |||
+ | {{laosd08-pla.pdf|Detailed report}}. |