You are on page 1of 53

REQUIREMENTS GATHERING USING OBJECT-

ORIENTED MODELS
SDLC

Mario Castillo
SDLC
Phases of SDLC
1. Requirement Phase
2. Analysis Phase
3. Design Phase
4. Development Phase
5. Testing Phase
6. Deployment Phase
Software Life Cycle

■ The "software lifecycle" refers to all stages of software development from planning to
disappearance. The objective of such a division is to allow the definition of
intermediate milestones allowing the validation of the software development, that is
to say the conformity of the software with the needs expressed, and the verification
of the development process. It means the adequacy of the methods used.
■ The origin of this division comes from the fact that the errors have a higher cost
because they are detected late in the process. The life cycle makes it possible to
detect the errors at the earliest and thus to control the quality of the software, the
delays of its realization and the associated costs.
Software Development Steps (IEEE 1074)
(IEEE 1074: Standard for Development a Software Project Life Cycle Process)
-IEEE: Institute of Electrical and Electronic Engineers-

Goals definition Needs analysis

Conception Coding

Validation Documentation

Production Maintenance
The 8 steps of software development
The software life cycle includes the following activities:
■ Goals definition, consisting of defining the purpose of the project and its inclusion in a global
strategy.

■ Analysis of needs, collection and formalization of the needs of the applicant (the client) and all
the constraints.

■ Conception/Design, This is the development of the specifications of the general architecture of


the software and precisely define each subset of the software.

■ Coding (Implementation or programming), or translation into a programming language of the


functionalities defined during design phases.
The 8 steps of software development

■ Validation, that is, verification of the software's compliance with the initial specifications.

■ Documentation, aimed at producing the information necessary for the use of the software and
for further development.

■ Production – End user

■ Maintenance, including all corrective (corrective maintenance) and scalable (evolutionary


maintenance) corrective actions on the software.
-The sequence and presence of each of these activities in the life cycle depends on the choice
of a life-cycle model between the client and the development team-
Models / processes of the development cycle

■ In order to be able to have a common methodology between the customer and the
development service company, life cycle models have been developed defining the
stages of the development as well as the documents to be produced allowing to
validate each one of the steps before proceeding to the next. At the end of each
phase, the reviews are organized.
The Waterfall Model Characteristics
Waterfall Model (linear)
■ The waterfall life-cycle model was developed in 1966, then formalized
around 1970. It defines sequential phases at the end of each of which
documents are produced to verify compliance before proceeding to the
next :
Specification
Validation
General Conception
Verification
Detailed Conception
Verification

Coding
Unit test
Integration
Integration test
Production
Relationship between each step and the next Validation
Outputs of a specific step are the entries for the next step
New ideas are incorporated at the stage level to form the new deliverables Maintenance
The Waterfall Model
The Waterfall Model – Changes
The Waterfall Model - Pros & Cons
The Waterfall Model
Impact on Testing
Spiral Model

■ The spiral model combines the idea of iterative development with the systematic,
controlled aspects of the waterfall model.
■ This Spiral model is a combination of iterative development process model and
sequential linear development model i.e. the waterfall model with a very high
emphasis on risk analysis.
Spiral Model - Design

■ Identification:
- This phase starts with gathering the business requirements in the baseline spiral.
- This phase also includes understanding the system requirements by continuous
communication between the customer and the system analyst.
■ Design:
- It starts with the conceptual design in the baseline spiral and involves architectural
design, logical design of modules, physical product design and the final design in the
subsequent spirals.
■ Construct or Build:
- The Construct phase refers to production of the actual software product at every spiral.
- In the baseline spiral, when the product is just thought of and the design is being
developed a POC (Proof of Concept) is developed in this phase to get customer feedback.
- Then in the subsequent spirals with higher clarity on requirements and design details a
working model of the software called build is produced with a version number. These
builds are sent to the customer for feedback.
■ Evaluation and Risk Analysis:
- Risk Analysis includes identifying, estimating and monitoring the technical feasibility
and management risks.
- After testing the build, at the end of first iteration, the customer evaluates the software
and provides feedback.
Spiral Model - Pros and Cons
■ PROS:
■ Changing requirements can be accommodated.
■ Allows extensive use of prototypes.
■ Users see the system early.
■ Development can be divided into smaller parts and the risky parts can be developed
earlier which helps in better risk management.
■ CONS:
■ Management is more complex.
■ End of the project may not be known early.
■ Not suitable for small or low risk projects and could be expensive for small projects.
■ Process is complex
■ Large number of intermediate stages requires excessive documentation.
V Model (linear)

■ May be considered as an extension of the waterfall model


■ The V-Model is an extension of the waterfall model and is based on
the association of a testing phase for each corresponding
development stage.
■ This means that for every single phase in the development cycle,
there is a directly associated testing phase.
■ Under the V-Model, the corresponding testing phase of the
development phase is planned in parallel.
Validation Phases
■ Unit Testing
- Unit testing is the testing at code level and helps eliminate bugs at an early stage,
though all defects cannot be uncovered by unit testing.
■ Integration Testing
- Integration tests are performed to test the coexistence and communication of the
internal modules within the system.
■ System Testing
- System tests check the entire system functionality and the communication of the
system under development with external systems. Acceptance Testing
■ Acceptance testing
- Acceptance tests uncover the compatibility issues with the other systems available in
the user environment.
V-Model - Pros and Cons
■ PROS:
■ Works well for smaller projects where requirements are very well understood.
■ Simple and easy to understand and use.
■ Easy to manage due to the rigidity of the model. Each phase has specific deliverables
and a review process.
■ CONS:
■ High risk and uncertainty.
■ Not a good model for complex and object-oriented projects.
■ Not suitable for the projects where requirements are at a moderate to high risk of
changing.
Agile Model

■ Agile SDLC model is a combination of iterative and incremental process models with
focus on process adaptability and customer satisfaction by rapid delivery of working
software product.
■ Iterative approach is taken and working software build is delivered after each
iteration. Each build is incremental in terms of features; the final build holds all the
features required by the customer.
Agile Model - Pros and Cons
■ PROS:
■ Is a very realistic approach to software development.
■ Promotes teamwork and cross training.
■ Resource requirements are minimum.
■ Delivers early partial working solutions.
■ Minimal rules, documentation easily employed.
■ Little or no planning required.
■ Easy to manage.
■ Gives flexibility to developers.
■ CONS:
■ More risk of sustainability, maintainability and extensibility.
■ Depends heavily on customer interaction, so if customer is not clear, team can be
driven in the wrong direction.
■ There is a very high individual dependency, since there is minimum documentation
generated.
■ Transfer of technology to new team members may be quite challenging due to lack of
documentation.
Prototype
■ Software prototyping is becoming very popular as a software development model, as
it enables to understand customer requirements at an early stage of development.
■ It helps get valuable feedback from the customer and helps software designers and
developers understand about what exactly is expected from the product under
development.
■ Prototype is a working model of software with some limited functionality. The
prototype does not always hold the exact logic used in the actual software
application and is an extra effort to be considered under effort estimation.
■ Prototyping is used to allow the users evaluate developer proposals and try them out
before implementation.
Other SDLC Models:
Iterative Model
■ Iterative process starts with a simple implementation of a subset of the software
requirements and iteratively enhances the evolving versions until the full system is
implemented.
■ At each iteration, design modifications are made and new functional capabilities are
added. The basic idea behind this method is to develop a system through repeated
cycles (iterative) and in smaller portions at a time (incremental).
■ During software development, more than one iteration of the software development
cycle may be in progress at the same time.
■ The key to a successful use of an iterative software development lifecycle is rigorous
validation of requirements, and verification & testing of each version of the software
against those requirements within each cycle of the model.
■ PROS:
■ Results are obtained early and periodically.
■ Progress can be measured.
■ Risks are identified and resolved during iteration
■ With every increment, operational product is delivered.
■ Risk analysis is better.
■ It supports changing requirements.
■ During the life cycle, software is produced early which facilitates customer evaluation
and feedback.
■ CONS:
■ More resources may be required.
■ More management attention is required.
■ System architecture or design issues may arise because not all requirements are
gathered in the beginning of the entire life cycle.
■ Defining increments may require definition of the complete system.
■ Not suitable for smaller projects.
■ Management complexity is more.
■ End of project may not be known which is a risk.
■ Highly skilled resources are required for risk analysis.
Big Bang Model
■ The Big Bang model is an SDLC model where we do not follow any specific process.
■ The development just starts with the required money and efforts as the input, and
the output is the software developed which may or may not be as per customer
requirement.
■ This Big Bang Model does not follow a process/procedure and there is a very little
planning required. Even the customer is not sure about what exactly he wants and
the requirements are implemented on the fly without much analysis.
■ This model is ideal for small projects with one or two developers working together
and is also useful for academic or practice projects.
■ It is an ideal model for the product where requirements are not well understood and
the final release date is not given.
Big Bang Model - Pros and Cons
■ PROS:
■ This is a very simple model
■ Little or no planning required
■ Easy to manage
■ Very few resources required
■ Gives flexibility to developers
■ CONS:
■ Very High risk and uncertainty.
■ Not a good model for complex and object-oriented projects.
■ Poor model for long and ongoing projects.
■ Can turn out to be very expensive if requirements are misunderstood.
RAD Model (Rapid Application Development)

■ The RAD (Rapid Application Development) model is based on


prototyping and iterative development with no specific planning
involved.
■ The process of writing the software itself involves the planning required
for developing the product.
■ Rapid application development is a software development methodology
that uses minimal planning in favor of rapid prototyping.
■ In the RAD model, the functional modules are developed in parallel as
prototypes and are integrated to make the complete product for faster
product delivery.
■ RAD model distributes the analysis, design, build and test phases into a
series of short, iterative development cycles.
RAD Model Design
■ Business Modeling
- A complete business analysis is performed to find the vital information for business,
how it can be obtained, how and when is the information processed and what are the
factors driving successful flow of information.
■ Data Modeling
- The information gathered in the Business Modeling phase is reviewed and analyzed to
form sets of data objects vital for the business.
■ Process Modeling
- The process model for any changes or enhancements to the data object sets is defined
in this phase. Process descriptions for adding, deleting, or modifying a data object are
given.
■ Application Generation
- The actual system is built and coding is done by using automation tools to convert
process and data models into actual prototypes.
■ Testing and Turnover
- The overall testing time is reduced in the RAD model as the prototypes are
independently tested during every iteration. However, the data flow and the interfaces
between all the components need to be tested with complete test coverage. Since most
of the programming components have already been tested, it reduces the risk of any
major issues.
■ RAD MODEL PROS:
■ Changing requirements can be accommodated.
■ Progress can be measured.
■ Productivity with fewer people in a short time.
■ Reduced development time.
■ Encourages customer feedback.
■ CONS:
■ Dependency on technically strong team members for identifying business
requirements.
■ Requires highly skilled developers/designers.
■ Inapplicable to cheaper projects as cost of modeling and automated code generation
is very high.
■ Management complexity is more.
■ Requires user involvement throughout the life cycle.
Next class March 01st 2020

■ Review (1:00 pm to 2:00 pm)


■ Mid-Term exam (2:00 pm to 4:30 pm)
■ Topics: Requirements Gathering Techniques, Tester Career, Quality Assurance,
Software Quality Assurance & Software Development Life Cycle.
Assignment # 3_Part 1

■ 1. What is the best model? Why? (Choose only one model per scenario)
■ You have three scenarios, choose the appropriate SDLC model to make the new
software for those scenarios and say in a paragraph why it is the best model for you.
■ Use an Office Word document.
- SCENARIO # 1
■ A client is going to build smart homes and needs software for that. He wants a house
that is managed with the voice of its owner.
■ The doors of the house have no locks or keys, the owner opens them giving a vocal
order.
■ The owner turns on or off the appliances and the lights with his voice.
- SCENARIO # 2
■ You had been mandated by a client to develop a web to record his personal travels,
like a Travel Log Book.
■ The client expects to be able to insert the depart city and the arrive city.
■ The date of departure and arrival.
■ Once a country is visited I system should provide a world map with the visited
countries tagged.
■ SCENARIO # 3
■ It is necessary to create a bank security application for the Bank of Montreal
■ Manage bank accounts through facial recognition.
■ The system must recognize the customer of the bank easily and without mistakes
(for example: that the client is alive, that it is not a customer's picture, that the
customer's face is complete).
Source:

■ https://www.synopsys.com/blogs/software-security/secure-sdlc/
■ https://www.tutorialspoint.com/sdlc/index.htm

You might also like