Tuesday, 4 February 2014

Our Tutorial in ICSE2014 - "Refactoring for Design Smells"



Tutorial title: Software Design Quality in Practice: Refactoring for Design Smells
To be presented in ICSE 2014 (Hyderabad, India) on 3rd June 2014

We will be presenting the tutorial in ICSE (International Conference on Software Engineering) 2014 - the most prestigious software engineering conference on the planet. 
 The details of the tutorial are provided below:

Abstract:
Fred Brooks in his book “The Mythical Man Month” describes how the inherent properties of software (i.e. complexity, conformity, changeability, and invisibility) make its design an “essential” difficulty. Good design practices are fundamental requisites to address this difficulty. One such good design practice is identifying and addressing ‘smells’. Most practitioners know about identifying and refactoring code smells. However, there is a lack of awareness on refactoring design smells and architecture smells, which are also equally important for creating high quality software. In this tutorial, we introduce a comprehensive catalog, classification, and naming scheme for design smells to the participants. We discuss important structural design smells based on how they violate the four key object oriented design principles (abstraction, encapsulation, modularization, and hierarchy). Each of these smells are illustrated through design smells found in OpenJDK  (Open source Java Development Kit) code base, with detailed discussions on refactoring strategies for addressing them. By attending this session, the participants will get a good understanding on design smells and how to refactor them in real-world projects.

Tutorial structure
The tutorial is structured as follows:
1.       Introduction
1.1.    Fundamental principles of software construction
1.2.    What are ‘design smells’?
1.3.    Why care about smells?
1.4.    Common causes of smells
1.5.    The scope of smells
1.6.    The effect of smells
2.       A Classification of Design Smells
2.1.    A design principle based classification of smells
2.2.    A naming scheme for smells
2.3.    A template for documenting smells
3.       Refactoring Design Smells
3.1.    Refactoring for abstraction smells
3.2.    Refactoring for encapsulation smells
3.3.    Refactoring for modularization smells
3.4.    Refactoring for hierarchy smells
4.       Conclusion and Key Takeaways
4.1.    Tools for detecting design smells
4.2.    Refactoring considerations in industrial projects
4.3.    Relationship between smells
4.4.    Relationship between design smells and design patterns
4.5.    Research directions for the community

Key takeaways
The tutorial provides many insights on design smells and the refactoring strategies for addressing the smells in real-world software. The key takeaways of this tutorial are:
a.  The comprehensive catalog presented in this tutorial will help practitioners understand the kind of problems that could be occurring in their design.
b.  The detailed description of smells included in the tutorial will help the practitioner understand via suitable examples how those smells manifest, how they are caused, their impact on quality attributes, and the potential refactoring that can address those smells.
c.  The tutorial provides a simple and intuitive naming scheme for smells which will be easy for practitioners to remember.
d.  The catalog of is a readily-usable guide for use in design reviews or for identifying refactoring opportunities.