You are on page 1of 30

The role of Process in

Integrated CASE Environment


Ali Haider
We will discuss
• Introduction to process integration
• Understanding the Nature of Process Integration
• Process integration and CASE Tools and Environments
• Examples of Process and CASE Tool Interactions
Introduction-1
• In recent years, however, the process aspect of integration has grown in importance in
the eyes of most members of the software community.
• The role of process, and hence of process integration, is now generally regarded as
critical.
• Such issues as determining the impact of process on the choice of tools to be
integrated, how those integrations should be implemented, and how a CASE
environment will be used in the overall life of an enterprise are now increasingly seen
as being of paramount importance.
• As an example, while one could assert that a particular analysis tool should be
integrated with a documentation tool, this is of little real value.
• A more meaningful assertion is that the analysis tool must make use of documentation
services to generate documentation in some standard life-cycle model form.
Introduction-2
• In our three-level model, process integration is orthogonal to mechanism-
level integration and service-level integration.
• In this view, we see that integration is not just an amalgamation of related
tools, but is the combination of several integrating mechanisms, used over
some set of services (as implemented by tools) to achieve some specific
process objective.
• Put another way, we view software processes as defining a design context,
i.e., a set of integration requirements.
• When implemented, they can be expressed as a coordinated set of
environment services, i.e., unified through a combination of control, data,
and presentation mechanisms.
Question?
• What do you mean by DoD-STD-2167 document sets?
• Why process aspect of integration is significant?
Understanding the Nature of Process
Integration
• Several viewpoints that highlight the different notions of process
integration.
• These views fall into the following categories: a "dimensional" view of
process integration; a "relationship" view of process integration;
process integration in the context of the user of the process; process
integration in the context of software process improvement; and our
own view, exemplified by the three-level model of integration.
Process Integration as a Dimension
• Together with his division of integration into three basic dimensions (i.e., data,
control, and presentation), Wasserman also proposed a tool-centric view of process
integration.
• In this perspective, process integration is the weaving together of tools into
coherent support for a software engineering process.
• This definition highlights the fact that collections of tools must be composed in a
coherent fashion to cooperate in supporting a process.
• Cagan goes somewhat further by considering several process dimensions: model
integration (specifically, CM models of product structure); life-cycle integration; and
task integration. Cagan refers to task integration as "process integration." However,
his use of the term specifically focuses on task specification and automation, and
not on broader software process issues such as lifecycle issues.
Process Integration as a Relationship
• A different view, proposed by Thomas and Nejmeh, concentrates on the many
different kinds of relationships among environment components.
• In particular, the major relationships of concern are between two tools,
between a tool and the platform on which it operates, and between a tool and
the process being enacted.
• This definition identifies three properties of a process that are of interest:
• the degree to which tools combine to support the performance of a single process step,
• the degree to which tools agree on the events needed to support a particular process
(where an event is a condition that arises during a process step that may result in the
execution of an associated action), and
• the degree to which relevant tools cooperate to enforce some constraint that arises as a
result of the process.
Process Integration in the Context of the
User-1
• These views, while expanding our understanding of process
integration, do not address one key issue, namely, that the goal of
process integration will vary depending on the user of the process.
• For instance, software developers may tend to prefer a process that
maximizes individual freedom (because software development is
often viewed as a creative activity); managers may instead prefer that
the process facilitate and enforce the tracking of project activities.
Process Integration in the Context of the
User-2
• Considering both the user and the scope of the process provides a useful per- spective in understanding how process
integration involves the relationships between different CASE tool functions. Building on the set of models developed by Perry
and Kaiser we can use a social metaphor to illustrate different communities of interest, and to highlight their differences:
• Individuals are primarily interested in support for their day-to-day tasks and the tools that support those tasks. There is seldom
need to be concerned with the details of tool interaction and communication; this can normally be hand- crafted on a pair-wise
basis as necessary.
• Families are small groups of developers who share a common philosophy and approach. Many agreements and conventions
among tools are so well internalized that they need not be explicitly defined and controlled. Inte- grated interaction is possible
with minimal explicit external control from the CASE environment.
• Cities are larger collections of families and individuals with more comple patterns of interaction. Enforced cooperation is
necessary to ensure that communication and sharing can take place. Agreements that exist informally within a family of tools
can no longer be assumed among families of tools. This leads to an architecture of loosely coupled collections of tightly
integrated tools.
• States are an extension of the city in which collections of cities must be managed. To manage a state there must be rules and
constraints that are consistent across a number of cities. While each city is necessarily unique, there are important points of
intersection which it makes sense to standardize to facilitate reuse, cooperation, and sharing among the cities. Commonality
across a number of CASE environments supporting multiple projects or multiple organizations is necessary to implement the
state model.
Process Integration and Software Process
Improvement
• A very different perspective on process integration is seen in the concept of "process
improvement," In fact, much of the current interest in process has derived from work done
over the past several years in this area.
• There are five levels defined in this model:
• Initial. The current predominant state in which an organization has in place few procedures for
control, monitoring, or assessment of the processes being carried out.
• Repeatable. The processes being enacted are sufficiently understood that they can be repeated
from one project to the next.
• Defined. Descriptions of an organization's processes exist. These can be used as the basis for
improved understanding of the tasks carried out.
• Managed. Comprehensive measurement and analysis of the processes are in place.
• Optimizing. Continual process improvement is now possible based on the statistics gained from
well-defined processes.
Question?
• What is the relationship among CMM and CASE tools?
Process Integration and the Three-Level
Model
• The understanding the relationships between services and the integration of tools that
provide those services must take place in the context of a set of process constraints.
• Conversely, understanding the process must somehow be related to the abstract services, and
thereby to the actual tools in the CASE environment, since these tools will shape and
constrain that process.
• Finally, both of these levels of integration must be implemented by some mechanisms, which
in turn will guide the manner of the overall integration of the environment.
• This view, while somewhat at variance with the other notions of process integration,
essentially builds on them.
• For instance, we share Thomas and Nejmeh’s notion that integration is a relationship,
although we see the relationship as broader and more complex.
• Similarly, we concur with the CMM view that process is pervasive, but we maintain that
services and tools have parity with process.
Process integration and CASE Tools and
Environments
• We now consider how process integration actually relates to CASE
tools and environments.
• To do so, we first distinguish between process automation and
process support.
• Next we examine the characteristics of process-centered tools and
environments. We then discuss the relationships between CASE tools,
process maturity, and process improvement.
Process Automation and Process Support
• Attempts to introduce process automation are motivated by the need to
improve the consistency, quality, and productivity of software development.
• Among the many ways in which tool support can assist in software
development are by:
• automating menial and/or repetitive tasks,
• enforcing consistency in support of process and methods,
• supporting analysis and understanding of programs and data,
• supporting the management of the software process, and
• maintaining a history of the software activity via versions and
configurations.
Characteristics of Process-Centered Tools and
Environments-1
• Any CASE tool or CASE environment can be considered "process-centered" in the
sense that the tool or environment's primary role is to support (some part of) some
process.
• Various CASE tools or environments show significant differences from each other in
two basic features:
• The extent to which the process being supported is explicitly defined.
• This feature affects the visibility and control available on that process.
• The ease with which the process being supported by the CASE tool or environment
can be changed.
• These changes may be minor (such as the tailoring of a small detail in part of the
process) or extensive (such as the replacement of one process with a different one).
Characteristics of Process-Centered Tools and
Environments-2
• Thus, the extent to which a CASE tool or CASE environment actually is process-
centered will largely be related to the way in which it offers support for both
these features.
• In examining a tool or an environment, therefore, one needs to question the ways
in which these features are offered.
• While an individual tool may offer some degree of process support, a number of
attempts have been made to produce extensive CASE environments with a strong
emphasis on explicit process support.
• These environments are sometimes called "process-centered CASE environments"
to distinguish them from environments composed of loosely connected tools with
little or no explicit definition or visibility of the processes being supported.
Relationships Between CASE Tools, Process
Maturity, and Process Automation-1
• The relationships between process improvement (as exemplified by the CMM),
• the use of CASE tools, and automated process support is an interesting one.
• We have already noted Humphrey's comments concerning CASE tools and process
improvement; he gave a clear warning that the use of CASE tools and environments is
likely to do more harm than good before a process framework is in place.
• Some organizations and individuals, adopting a rigid interpretation of Humphrey's
work, have suggested that CASE tool support is inappropriate before CMM Level
Three is attained.
• In contrast, many CASE tool vendors encourage the belief that the use of CASE tools
at every level is essential to manage process improvement in a cost-effective manner,
and that more technology is required on the road to process improvement.
Relationships Between CASE Tools, Process
Maturity, and Process Automation-2
• As an example, we consider the CMM at Level Two. The operational basis of the CMM
is a set of key process areas that identify the principal topics of interest at each
maturity level. In each of these key process areas, there is a set of key practices that
can be used as the basis for satisfying the goals defined for that process area.
• At Level Two, the key process areas are:
• Software configuration management.
• Software quality assurance.
• Software subcontract management.
• Software project tracking and oversight.
• Software project planning.
• Requirements management.
Examples of Process and CASE Tool
Interactions
• We now consider some idealized examples of how process and CASE
tools
• interact.
• These examples are intended to illustrate the complex issues that
affect how a defined process, the tools needed to implement it, and
the integrating mechanisms that underlie both of these are all
necessary factors in creating an integrated CASE environment.
• There are four examples: coordinating tools across different life-cycle
phases, coordinating tools within a single life-cycle step, overlapping
tool capabilities, and life-cycle documentation.
Coordinating Tools Across Different Life-
Cycle Phases-1
• One popular way to describe an overall software process is by way of a
lifecycle model.
• Descriptions of software life cycles abound, and alternative models differ
about whether the life cycle is iterative, whether several phases can be active
simultaneously, etc.
• However, all share some common concepts, notably, the idea of life-cycle
phases and the progression of a process through these phases.
• A large or extensive software life cycle is typically composed of many phases.
• Tools may or may not be common across these phases, but some of the
tools' data are almost certainly so.
Coordinating Tools Across Different Life-
Cycle Phases-2
• Such coordination affects CASE environment integration for a number of
reasons, including the following:
• One facet of CASE environment integration is the control of global changes to
data, i.e., controlling what changes can be made, why they should be made,
when the changes should be made and who should make the changes.
• Tools featuring private repositories need to work within a global change
control regime for effective global change control to be put into practice, yet
tools frequently provide their own services and mechanisms for controlling
change.
• Coordination of CASE tools in the life-cycle context can be simplified if the
problem is viewed in a kind of data-flow framework.
Coordinating Tools Across Different Life-
Cycle Phases-3
• In a strict waterfall life cycle, preconditions tend to be static, and traceability is relatively
straightforward.
• One implication of this is that traceability links can be made (relatively) immutable since
iteration does not exist.
• In a spiral life-cycle model, however, iteration exists.
• Preconditions are more flexible, and traceability links must be dynamically changeable.
• This fact places requirements on the choice of tools as well as on their mode of integration.
• The parallel development model, which offers the greatest developmental flexibility, also
places the greatest constraints on the tools and their integration.
• This life-cycle model implies that there are degrees of incompleteness in each phase (inherent
in the notion of activity), and also demands requirements such as the possible need to notify
tools and users where logically shared (orderived) information is under modification.
Coordinating Tools Within a Single Life-
Cycle Step
• By their nature, processes within life-cycle steps are likely to be more
interactive, more collaborative, and more complex in terms of number, kind,
and frequency of process-related events and data.
• Further, support for activities within life-cycle steps often falls into the realm
of individual CASE tools.
• Thus, many of the issues related to tool integration in this context are highly
dependent upon the idiosyncracies of individual tools.
• CASE tools are not developed by vendors without some preconceived notions
of software process.
• In most cases, there is no strict separation of CASE tool functions and process
constraints that can, and should, be separate from tool functions.
Overlapping Tool Capabilities
• The examples discussed above were based on a simple assumption, namely, that each life-cycle phase
is equated with a single tool.
• If we remove this simplistic assumption about tools and life-cycle phases, the issues become still more
complex.
• In Figure 23, several tools are depicted that could reasonably be available in a CASE environment.
• One important point to note is the overlap among various kinds of tools. In some cases the overlap is
intentional and benign. For example, a design tool such as Software through Pictures (StP) can be
thought to overlap coding tools to the extent to which StP can be used to generate module interface
specifications.
• In a case such as this, CASE tools might overlap but provide services that amplify the effect of the
tools.
• In other cases, the overlap can be useless (if not destructive).
• For example, it is not at all clear that there are any benefits to be gained from using two competing
design notations and tools simultaneously (e.g., AGE (Asa+Geode) and StP)
Life-Cycle Documentation
• For almost any process as a whole, an item of particular significance is the generation and
maintenance of documentation produced as a consequence of lifecycle requirements.
• As most developers of large-scale U.S. DoD software systems can testify, life-cycle
standards such as DoD-STD-2167 require the production and maintenance of various
kinds of documentation as a means of controlling and managing the software life cycle.
• Some kinds of documentation directly affect the kinds of CASE environment services used
and, perhaps, how the services are used.
• For example, the requirement to maintain unit development folders to document every
change to software configuration items will greatly affect the configuration management
tools used and their optimal integration with the rest of the CASE environment.
• Other kinds of documentation may also be required that reflect traceability across various
phases of the life cycle, e.g., tracing requirements to test cases.
Questions
• What is key problem of traceability?
• Why the SLCSE and AD/Cycle approach involve great expense and
effort?

You might also like