DPAT Assignment - Quality Attributes
DPAT Assignment - Quality Attributes
DPAT Assignment - Quality Attributes
Design Patterns
Coursework
Learning Outcomes
Assessment Criteria
Deliverables
Problem Description
Delivering quality software products to the users is among the utmost important
requirements of any organization to succeed as well as to sustain from competitive
pressure. One of the very significant quality model presented by Jim McCall (also
known as the General Electrics Model of 1977) details 11 Quality Factors that
describe the external view of the software, as viewed by the users.
Following are 10 (out of 11) quality factors stated by McCall which are crucial for
any given application.
1. Usability: The ease of using software.
2. Integrity: The protection of program from unauthorized access.
3. Efficiency: The usage of system resources, like processor time, memory.
4. Reliability: The systems ability of not to fail.
5. Maintainability: Effort required to locate and fix a fault in the program within
its operating environment.
6. Testability: The ease of testing program to ensure that it is error-free and meets
its specification, i.e, validating the software requirements.
7. Flexibility: The ease of making changes required as dictated by business by
changes in the operating environment.
8. Reusability: The ease of reusing software in a different context.
9. Portability: The effort required to transfer a program from one environment to
another.
10. Interoperability: The effort required to couple the system to another system.
Many studies indicate that design patterns improve the quality of object-oriented
software systems. You are required to choose one of the stated quality attribute based
on the last digit of your TP number (for instance a student having TP number
TP029207 will choose Flexibility for his/her assignment) and justify with the help
of empirical evidence that the use of design patterns help in improving the selected
quality factor.
Description
In this section you are supposed to research the chosen quality attribute and its
implications on software architecture. Moreover you need to investigate the effects of
applying design patterns in terms of the chosen quality attribute.
Description
In this section, you are required to provide a sample application design using UML
class diagram and implement it using Java programming language. Then you will
need to refine the UML design using two appropriate design patterns and implement
the refined design again for comparison. The selection of the design patterns should
be made by considering the the chosen quality attribute.
Design and Implementation using Simpler Solution (10%) Use UML for Design
and Java for implementation.
Design and Implementation using First Design Pattern based Solution (10%) -
Use UML for Design and Java for implementation.
Design and Implementation using Second Design Pattern based Solution (10%) -
Use UML for Design and Java for implementation.
Description
In this section, you are required to present detailed results based on the evaluation of
design pattern based solutions and their equivalent simpler solutions (i.e., solutions
without using design patterns) so as to quantify which of them is more suitable
towards improving the selected quality attribute.
To further elaborate this context, you can assume that there are two different design
solutions, S1 and S2 exists for a single problem in designing a software product.
Obviously before applying a solution, a software engineer needs to know that
applying S1 would be more appropriate than applying S2, or vice versa, in terms of
the chosen quality attribute. A good software engineer should measure both S1 and S2
beforehand (in terms of the selected quality attribute) by using specific metrics made
for this very purpose. The resulted quantified values would assist him/her to select the
better design inclined towards improving the chosen quality attribute and contributing
to improve the overall software quality.
You are also required to provide the empirical evidence to support the claims of
improved quality factor when applying design patterns. Use an experimental-based
evaluation technique. The measurements and evaluation processes should be clearly
stated and formulated into a guideline.
Analysis of the Results (15%) - This is where you compare and contrast the
results of the design pattern based solutions with their equivalent simpler
solutions.
Discussion (10%) Discuss the results and impact of using the design
patterns on the selected quality attributes.