OF SDLC :-
SDLC :- SOFTWARE DEVELOPMENT LIFE
• Definition :-A software development process, also known as a
software development life-cycle, is a structure imposed on the
development of a software product. Similar terms include
software life cycle and software process. It is often considered
a subset of systems development life cycle.
• It is a framework defining tasks performed at each step in the
software development process. SDLC is a structure followed by
a development team within the software organization. It
consists of a detailed plan describing how to develop, maintain
and replace specific software. The life cycle defines a
methodology for improving the quality of software and the
overall development process.
This term is also known as the software development process.
“Life-Cycle” Models (1)
Waterfall Model with “back flow”
“V” model: Integrating testing
• V model means verification and validation model.
• The V-model represents a software development process (also
applicable to hardware development) which may be considered
an extension of the waterfall model.
• Each phase has to be completed before the next phase begins.
• Instead of moving down in a linear way, the process steps are
bent upwards after the coding phase, to form the typical V
• Testing is emphasized in this model more than in the waterfall
• It is a structured approach to testing.
• Brings high quality into the development of our products.
• The V-Model demonstrates the relationships between each phase of
the development life cycle and its associated phase of testing. The
horizontal and vertical axes represents time or project completeness
(left-to-right) and level of abstraction (coarsest-grain abstraction
Each phase has corresponding test or validation counterpart
Steps in the V-Shaped
Quality is guaranteed at each project stage.
• In this phase, the first step in the verification process,
the requirements of the system are collected by analysing the needs
of the user.
• This phase is concerned with establishing what the ideal system has
to perform. However it does not determine how the software will be
designed or built.
• Usually, the users are interviewed and a document called the user
requirements document is generated.
• The user requirements document will typically describe the system’s
functional, interface, performance, data, security, etc. requirements
as expected by the user.
• It is used by business analysts to communicate their understanding
of the system to the users.
• The users carefully review this document as this document would
serve as the guideline for the system designers in the system design
phase. The user acceptance tests are designed in this phase.
• There are different methods for gathering requirements of both soft
and hard methodologies including; interviews, questionnaires,
document analysis, observation, throw-away prototypes, use cases
and static and dynamic views with users.
• Systems design is the phase where system engineers analyse
and understand the business of the proposed system by
studying the user requirements document.
• They figure out possibilities and techniques by which the user
requirements can be implemented. If any of the requirements
are not feasible, the user is informed of the issue. A resolution
is found and the user requirement document is edited
2. System design
• The software specification document which serves as a
blueprint for the development phase is generated. This
document contains the general system organization, menu
structures, data structures etc.
• It may also hold example business scenarios, sample windows,
reports for the better understanding.
• Other technical documentation like entity diagrams, data
dictionary will also be produced in this phase. The documents
for system testing are prepared in this phase.
• The phase of the design of computer architecture and software
architecture can also be referred to as high-level design. The
baseline in selecting the architecture is that it should realize all
which typically consists of the list of modules, brief
functionality of each module,
their interface relationships, dependencies, database tables,
architecture diagrams, technology details etc. The integration
testing design is carried out in the particular phase.
• The module design phase can also be referred to as low-level design. The
designed system is broken up into smaller units or modules and each of
them is explained so that the programmer can start coding directly. The low
level design document or program specifications will contain a detailed
functional logic of the module, in pseudo code:
• database tables, with all elements, including their type and size
• all interface details with complete API references
• all dependency issues
• error message listings
• complete input and outputs for a module.
• The unit test design is developed in this stage.
The most ‘micro’ scale of Testing
A unit = smallest testable software component
Objects and methods
Procedures / functions
Performed by Programmer
A tester can help.
Requires detailed knowledge of the internal
program design and code.
The units are tested in isolation.
Ensures the component is working according to the
detailed design/build specifications of the module.
Not to be confused with debugging.
Also known as component, module, or program
Testing of more than one (tested) unit together to
determine if they function correctly.
Focus on interfaces
Communication between units
It is done using the integration test design prepared
during the architecture design phase.
Helps assembling incrementally a whole system,
ensuring the correct ‘flow’ of data from the first
through the final component.
Done by developers/designers and testers in
Also called Interface Testing or Assembly Testing.
Testing the system as a whole - Black-box type
testing that is based on overall requirements
specifications; covers all combined parts of a system.
Ensures that system meets all functional and
Verifying that specifications are met
Validating that the system can be used for the
The system test design is derived from the system
design documents and is used in this phase.
It can involve a number of specialized types of
tests to check performance, stress, documentation
etc. Sometimes testing is automated using testing
Done by Independent testing group
To determine whether a system satisfies its
acceptance criteria and business requirements or
Similar to System testing in that the whole system
is checked, but the important difference is the
change in focus.
Done by real business users.
It enables the customer to determine whether to
accept the system or not.
Also called as Beta Testing, Application Testing or
End User Testing.
Should be performed in real operating
Customer should be able to perform any test
• Faults are prevented and it stops fault multiplication.
• Avoids the downward flow of defect.
• Lower defect Resolution cost due to earlier detection.
• Improved quality and reliability.
• Reduction in the amount of Re-work.
• Improved Risk Management
• Validation and Verification at each level of stage
• Allows testers to be active in the project early in the
project’s lifecycle. They develop critical knowledge
about the system.
Benefits of V-Model