Professional Documents
Culture Documents
Objectives
.To explain why change is inevitable if software systems are to remain useful
Topics covered
.Agile methods
.Extreme programming
.Software prototyping
.Software maintenance
.Evolution processes
.This requires software and rapid development and delivery is not often the most
critical requirement for software systems.
Requirements
.User engagement with the system. Users have to be involved in the development
which means the system is more likely to meet their requirements and the users
are more committed to the system.
.Management problems
•Progress can be hard to judge and problems hard to find because there is no
documentation to demonstrate what has been done.
.Contractual problems
.Validation problems
.Maintenance problems
Prototyping
.For some large systems, incremental iterative development and delivery may be
impractical; this is especially true when multiple teams are working on different
sites.
Conflicting objectives
Agile methods
.Dissatisfaction with the overheads involved in design methods led to the creation
of agile methods. These methods:
•Are intended to deliver working software quickly and evolve this quickly to meet
changing requirements.
.It can be difficult to keep the interest of customers who are involved in the process.
Extreme programming
•All tests must be run for every build and the build is only accepted if tests run
successfully.
.People not process through pair programming, collective ownership and a process
that avoids long working hours.
Requirements scenarios
.These are written on cards and the development team break them down into
implementation tasks. These tasks are the basis of schedule and cost estimates.
.The customer chooses the stories for inclusion in the next release based on their
priorities and the schedule estimates.
XP and change
.XP, however, maintains that this is not worthwhile as changes cannot be reliably
anticipated.
Testing in XP
.Test-first development.
.Automated test harnesses are used to run all component tests each time that a
new release is built.
Test-first development
.Tests are written as programs rather than data so that they can be executed
automatically. The test includes a check that it has executed correctly.
.All previous and new tests are automatically run when new functionality is added.
Thus checking that the new functionality has not introduced errors.
Pair programming
.This helps develop common ownership of code and spreads knowledge across the
team.
.It serves as an informal review process as each line of code is looked at by more
than 1 person.
.It encourages refactoring as the whole team can benefit from this.
.Agile methods have received a lot of attention but other approaches to rapid
application development have been used for many years.
.Interface generator
.Report generators
Interface generation
.Many applications are based around complex forms and developing these forms
manually is a time-consuming activity.
Visual programming
.Scripting languages such as Visual Basic support visual programming where the
prototype is developed by creating a user interface from standard items and
associating components with these items
COTS reuse
.An effective approach to rapid development is to configure and link existing off the
shelf systems.
Compound documents
.This is a document with active elements (such as a spreadsheet) that allow user
computations.
.Each active element has an associated application which is invoked when that
element is selected.
Application linking
Software prototyping
Benefits of prototyping
.Improved maintainability.
Throw-away prototypes
.Prototypes should be discarded after development as they are not a good basis for
a production system:
•The prototype probably will not meet normal organisational quality standards.
Software evolution
Software change
Importance of evolution
.Organisations have huge investments in their software systems - they are critical
business assets.
.To maintain the value of these assets to the business, they must be changed and
updated.
.After major empirical studies, Lehman and Belady proposed that there were a
number of ‘laws’ which applied to all systems as they evolved.
.There are sensible observations rather than laws. They are applicable to large
systems developed by large organisations. Perhaps less applicable in other cases.
•Confirmed in more recent work by Lehman on the FEAST project (see further
reading on book website).
•Small organisations;
Software maintenance
Maintenance is inevitable
.The system requirements are likely to change while the system is being developed
because the environment is changing. Therefore a delivered system won't meet its
requirements!
.Systems are tightly coupled with their environment. When a system is installed in
an environment it changes that environment and therefore changes the system
requirements.
Types of maintenance
Maintenance costs
.Usually greater than development costs (2* to 100* depending on the application).
.Ageing software can have high support costs (e.g. old languages, compilers etc.).
.Team stability
•Maintenance costs are reduced if the same staff are involved with them for some
time.
.Contractual responsibility
.Staff skills
•Maintenance staff are often inexperienced and have limited domain knowledge.
•As programs age, their structure is degraded and they become harder to
understand and change.
Maintenance prediction
.Maintenance prediction is concerned with assessing which parts of the system may
cause problems and have high maintenance costs
•Maintenance costs depend on the number of changes and costs of change depend
on maintainability.
Change prediction
Complexity metrics
.Studies have shown that most maintenance effort is spent on a relatively small
number of system components.
.Complexity depends on
Process metrics
.If any or all of these is increasing, this may indicate a decline in maintainability.
Evolution processes
.Proposals for change are the driver for system evolution. Change identification and
evolution continue throughout the system lifetime.
.Urgent changes may have to be implemented without going through all stages of
the software engineering process
•If there are business changes that require a very rapid response (e.g. the release
of a competing product).
System re-engineering
.Applicable where some but not all sub-systems of a larger system require frequent
maintenance.
.Re-engineering involves adding effort to make them easier to maintain. The system
may be restructured and re-documented.
Advantages of reengineering
.Reduced risk
.Reduced cost
•The cost of re-engineering is often significantly less than the costs of developing
new software.
.Reverse engineering
.Program modularisation
.Data reengineering
•This can be a problem with old systems based on technology that is no longer
widely used.
.Organisations that rely on legacy systems must choose a strategy for evolving
these systems
•Scrap the system completely and modify business processes so that it is no longer
required;
.The strategy chosen should depend on the system quality and its business value.
•System end-users;
•Business customers;
•Line managers;
•IT managers;
•Senior managers.
•How well does the business process support the current goals of the business?
.Environment assessment
.Application assessment
•Do different parts of the organisation use different processes for the same
function?
•What are the relationships with other business processes and are these necessary?
.Example - a travel ordering system may have a low business value because of the
widespread use of web-based ordering.
System measurement
.You may collect quantitative data to make an assessment of the quality of the
application system
Key points
.Agile methods are iterative development methods that aim to reduce development
overhead and so produce software faster.
.When implementing a throw-away prototype, start with the requirements you least
understand; in incremental development, start with the best-understood
requirements.
.Three types of maintenance are bug fixing, modifying software for a new
environment and implementing new requirements.
.The business value of a legacy system and its quality should determine the
evolution strategy that is used.