Thursday, 18 September 2014
Friday, 4 July 2014
Refactoring for Software Design Smells: Managing Technical Debt
"Refactoring for Software Design Smells: Managing Technical Debt" presents 25 structural design smells, their role in identifying design issues, and potential refactoring solutions. Organized across common areas of software design, each smell is presented with diagrams and examples illustrating the poor design practices and the problems that result, creating a catalog of nuggets of readily usable information that developers or engineers can apply in their projects. The authors distill their research and experience as consultants and trainers, providing insights that have been used to improve refactoring and reduce the time and costs of managing software projects. Along the way they recount anecdotes from actual projects on which the relevant smell helped address a design issue.
Salient features:
- A comprehensive catalogue of structural design smells and their refactoring solutions to solve problems occurring in design
- Explains the importance of smells in managing technical debt, an area of increased concern at software engineering conferences
- Each smell includes examples, source code, and visualization diagrams to facilitate understanding
- Describes solutions across common software design concepts and smells that cross multiple domains
Tuesday, 3 June 2014
Refactoring for Design Smells: ICSE 2014 Tutorial
This is the slide-deck we used for our tutorial in ICSE 2014.
Here is the handout that we shared with all the participants during the tutorial. You may download and print it for personal use.
Here is the handout that we shared with all the participants during the tutorial. You may download and print it for personal use.
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:
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.
Subscribe to:
Posts (Atom)