MODULE - 3
IMPLEMENTATION AND TESTING
        OBJECT-ORIENTED DESIGN
               USING UML
• Object-oriented design processes involve designing object classes and the
  relationships between these classes.
• To develop a system design from concept to detailed, object-oriented
  design, you need to:
   1.   Understand and define the context and the external interactions with the
        system.
   2.   Design the system architecture.
   3.   Identify the principal objects in the system.
   4.   Develop design models.
   5.   Specify interfaces
System Context and Interactions:
• The first stage in any software design process is to develop an
  understanding of the relationships between the software that is being
  designed and its external environment. This is essential for deciding
  how to provide the required system functionality and how to
  structure the system to communicate with its environment.
• Setting the system boundaries helps you decide what features are
  implemented in the system being designed and what features are in
  other associated systems.
• System context models and interaction models present complementary
  views of the relationships between a system and its environment:
   1. System context model  a structural model that demonstrates the other systems in
      the environment of the system being developed.
   2. Interaction model  a dynamic model that shows how the system interacts with
      its environment as it is used.
• The context model of a system may be represented using associations.
• Associations simply show that there are some relationships between the
  entities involved in the association.
• When you model the interactions of a system with its environment, you
  should use an abstract approach that does not include too much detail.
  One way to do this is to use a use case model.
• Fig: System context for the   • Fig: Weather station use cases
  weather station
Architectural Design:
• Once the interactions between the software system and the system’s
  environment have been defined, you use this information as a basis
  for designing the system architecture.
• Identify the major components that make up the system and their
   interactions.
• Then design the system organization using an architectural pattern
  such as a layered or client–server model.
• The weather station is composed of independent subsystems that
  communicate by broadcasting messages on a common infrastructure,
  shown as Communication link in the figure.
• Each subsystem listens for messages on that infrastructure and picks up the
  messages that are intended for them. This “listener model” is a commonly
  used architectural style for distributed systems.
• The key benefit of this architecture is that it is easy to support
  different configurations of subsystems because the sender of a
  message does not need to address the message to a particular
  subsystem.
                   Architecture of data collection system
• The Transmitter and Receiver objects
  are concerned with managing
  communications
• The WeatherData object encapsulates
  the information that is collected from
  the instruments and transmitted to the
  weather information system.
• This arrangement follows          the
  producer–consumer pattern
Object Class Identification:
 • The use case description helps to identify objects and operations in the
   system.
 • Various ways of identifying object classes in object-oriented systems are:
    1. Use a grammatical analysis of a natural language description of the system to be
       constructed. Objects and attributes are nouns; operations or services are verbs.
    2. Use tangible entities (things) in the application domain such as aircraft, roles such
       as manager, events such as request, interactions such as meetings, locations such as
       offices, organizational units such as companies, and so on.
    3. Use a scenario-based analysis where various scenarios of system use are identified
       and analyzed in turn.
Weather station objects
Design Models:
• Design or system models show the objects or object classes in a system.
• They also show the associations and relationships between these
 entities.
• These models are the bridge between the system requirements and the
 implementation of a system.
• They have to be abstract.
• They also have to include enough detail for programmers to make
 implementation decisions.
• The level of detail that you need in a design model depends on the design
  process used.
• 2 kinds of design model:
   1. Structural models  describe the static structure of the system
      using object classes and their relationships.
   2. Dynamic models  describe the dynamic structure of the system
      and show the expected runtime interactions between the system
      objects.
Three UML model types:
  1. Subsystem models, which show logical groupings of objects into coherent
     subsystems. These are represented using a form of class diagram with
     each subsystem shown as a package with enclosed objects. Subsystem
     models are structural models.
  2. Sequence models, which show the sequence of object interactions. These
     are represented using a UML sequence or a collaboration diagram.
     Sequence models are dynamic models.
  3. State machine models, which show how objects change their state in
     response to events. These are represented in the UML using state
     diagrams. State machine models are dynamic models.
• A subsystem model is a useful static model that shows how a
  design is organized into logically related groups of objects.
• Sequence models are dynamic models that describe, for each
  mode of interaction, the sequence of object interactions that
  take place.
• Sequence diagrams are used to model the combined behavior of
  a group of objects, but you may also want to summarize the
  behavior of an object or a subsystem in response to messages
  and events.
• State diagrams are useful high-level models of a system or an
  object’s operation.
Sequence diagram describing data collection
1. The SatComms object receives a request from the weather information system
to collect a weather report from a weather station. It acknowledges receipt of
this request. The stick arrowhead on the sent message indicates that the external
system does not wait for a reply but can carry on with other processing.
2. SatComms sends a message to WeatherStation, via a satellite link, to create a
summary of the collected weather data. Again, the stick arrowhead indicates that
SatComms does not suspend itself waiting for a reply.
3. WeatherStation sends a message to a Commslink object to summarize the
weather data. In this case, the squared-off style of arrowhead indicates that the
instance of the WeatherStation object class waits for a reply.
 4. Commslink calls the summarize method in the object WeatherData and waits
for a reply
5. The weather data summary is computed and returned to WeatherStation via
the Commslink object.
6. WeatherStation then calls the SatComms object to transmit the summarized
data to the weather information system, through the satellite communications
Weather station state diagram
1. If the system state is Shutdown, then it can respond to a restart(), a reconfigure() or a
powerSave() message. The unlabeled arrow with the black blob indicates that the
Shutdown state is the initial state. A restart() message causes a transition to normal
operation. Both the powerSave() and reconfigure() messages cause a transition to a state in
which the system reconfigures itself. The state diagram shows that reconfiguration is
allowed only if the system has been shut down.
2. In the Running state, the system expects further messages. If a shutdown() message is
received, the object returns to the shutdown state.
3. If a reportWeather() message is received, the system moves to the Summarizing state.
When the summary is complete, the system moves to a Transmitting state where the
information is transmitted to the remote system. It then returns to the Running state.
4. If a signal from the clock is received, the system moves to the Collecting state, where it
collects data from the instruments. Each instrument is instructed in turn to collect its data
from the associated sensors.
5. If a remoteControl() message is received, the system moves to a controlled state in
which it responds to a different set of messages from the remote control room. These are
not shown on this diagram.
Interface Specification:
 • Interfaces need to specified so that objects and subsystems can be
   designed in parallel.
 • Interface design is concerned with specifying the detail of the interface to
   an object or to a group of objects. This means defining the signatures and
   semantics of the services that are provided by the object or by a group of
   objects.
 • Interfaces can be specified in the UML using the same notation as a
   class diagram.
 • You should not include details of the data representation in an interface
   design, as attributes are not defined in an interface specification.
 • You should include operations to access and update data.
Interface specification
 Weather station interfaces
                     DESIGN PATTERNS
• Pattern  a description of the problem and the essence of its
  solution, so that the solution may be reused in different settings.
  • not a detailed specification.
  • It is a description of accumulated wisdom and experience, a well-
    tried solution to a common problem.
• “Patterns and Pattern Languages are ways to describe best
  practices, good designs, and capture experience in a way that it is
  possible for others to reuse this experience” -- Hillside Group
  website.
Design Patterns
• The pattern is a description of the problem and the essence of its
  solution, so that the solution may be reused in different settings.
  The pattern is not a detailed specification.
• Patterns have made a huge impact on object-oriented software
  design
• They have become a vocabulary for talking about a design
• Patterns are a way of reusing the knowledge and experience of
  other designers. Design patterns are usually associated with object-
  oriented design.
• The general principle of encapsulating experience in a pattern is one
  that is equally applicable to any kind of software design.
Four essential elements of design patterns
 1. A name that is a meaningful reference to the pattern.
 2. A description of the problem area that explains when the pattern
 may be applied.
 3. A solution description of the parts of the design solution, their
 relationships and their responsibilities. It is a template for a design
 solution that can be instantiated in different ways. This is often
 expressed graphically and shows the relationships between the
 objects and object classes in the solution.
 4. A statement of the consequences—the results and trade-offs—of
 applying the pattern. This can help designers understand whether or
 not a pattern can be used in a particular situation.
• Graphical representations are
  normally used to illustrate the
  object classes in patterns and
  their relationships.
• These supplement the pattern
  description and add detail to the
  solution description.
                                      Fig: shows two different graphical presentations of the same
                                      dataset. (Multiple displays)
• Patterns support high-level, concept reuse.
• Using patterns means that you reuse the ideas but can adapt the
  implementation to suit the system you are developing.
• Using patterns in a design process often involves:
   1. developing a design,
   2. experiencing a problem, and then
   3. recognizing that a pattern can be used.
• Patterns need experience of software design to use them effectively.
 You have to recognize situations where a pattern can be applied.
• To use patterns in your design, you need to recognize that any design
  problem you are facing may have an associated pattern that can be
  applied.
• Ex: of such problems, documented in the Gang of Four’s original
  patterns book,
  include:
   1. Tell several objects that the state of some other object has changed (Observer
      pattern).
   2. Tidy up the interfaces to a number of related objects that have often been
      developed incrementally (Façade pattern).
   3. Provide a standard way of accessing the elements in a collection, irrespective
      of how that
      collection is implemented (Iterator pattern).
   4. Allow for the possibility of extending the functionality of an existing class at
      runtime (Decorator pattern).