Agile Model and Methodologies

Download as docx, pdf, or txt
Download as docx, pdf, or txt
You are on page 1of 9
At a glance
Powered by AI
The key takeaways from the document are that agile focuses on iterative development, emphasizes collaboration with customers, and values working software over documentation. It also discusses various agile methodologies like scrum, kanban, FDD and lean software development.

The four core values of agile are: individual and team interactions over processes and tools, working software over comprehensive documentation, customer collaboration over contract negotiation, and responding to change over following a plan.

Some agile methodologies discussed are scrum, DSDM, FDD, lean software development and kanban. Each methodology has its own specific practices and phases of work.

Agile Model and Methodologies: Guide for Developers and Testers

To understand the concept of agile testing, first let's understand-

What is Agile?
AGILE is a methodology that promotes continuous iteration of development and testing throughout the software development life cycle
of the project. Both development and testing activities are concurrent unlike the Waterfall model

I hope we got an idea of Agile!!! Now, we can step on to Agile Testing.

The agile software development emphasizes on four core values.

1. Individual and team interactions over processes and tools

2. Working software over comprehensive documentation

3. Customer collaboration over contract negotiation

4. Responding to change over following a plan

Agile versus Waterfall Method


Agile and Waterfall model are two different methods for software development process. Though they are different in their approach, both
methods are useful at times, depending on the requirement and the type of the project.

Agile Model Waterfall Model

Agile method proposes Development of the


incremental and iterative approach to software flows sequentially
software design from start point to end point.
The agile process is broken into The design process is not
individual models that designers work broken into an individual
on models
The customer has early and The customer can only
frequent opportunities to look at the see the product at the end of the
product and make decision and project
changes to the project
Agile model is considered Waterfall model are more
unstructured compared to the secure because they are so plan
waterfall model oriented
Small projects can be All sorts of project can be
implemented very quickly. For large estimated and completed.
projects, it is difficult to estimate the
development time.
Error can be fixed in the middle Only at the end, the
of the project. whole product is tested. If the
requirement error is found or
any changes have to be made,
the project has to start from the
beginning
Development process is The development process
iterative, and the project is executed in is phased, and the phase is
short (2-4) weeks iterations. Planning much bigger than iteration.
is very less. Every phase ends with the
detailed description of the next
phase.
Documentation attends less Documentation is a top
priority than software development priority and can even use for
training staff and upgrade the
software with another team
Every iteration has its own Only after the
testing phase. It allows implementing development phase, the testing
regression testing every time new phase is executed because
functions or logic are released. separate parts are not fully
functional.
In agile testing when an iteration All features developed are
end, shippable features of the product delivered at once after the long
is delivered to the customer. New implementation phase.
features are usable right after
shipment. It is useful when you have
good contact with customers.
Testers and developers work Testers work separately
together from developers
At the end of every sprint, user User acceptance
acceptance is performed is performed at the end of the
project.
It requires close communication Developer does not
with developers and together analyse involve in requirement and
requirements and planning planning process. Usually, time
delays between tests and
coding
Methodologies of Agile Testing

There are various methods present in agile testing, and those are listed below:

Scrum
SCRUM is an agile development method which concentrates specifically on how to manage tasks within a team based development
environment. Basically, Scrum is derived from activity that occurs during a rugby match. Scrum believes in empowering the development
team and advocates working in small teams (say- 7 to 9 members). It consists of three roles, and their responsibilities are explained as
follows:
Scrum Master
o Master is responsible for setting up the team, sprint meeting and removes obstacles to progress
Product owner
o The Product Owner creates product backlog, prioritizes the backlog and is responsible for the delivery of the
functionality at each iteration
Scrum Team
o Team manages its own work and organizes the work to complete the sprint or cycle

Product Backlog
This is a repository where requirements are tracked with details on the no of requirements to be completed for each release. It should be
maintained and prioritized by product owner, and it should be distributed to the scrum team. Team can also request for a new
requirement addition or modification or deletion

Scrum Practices
Practices are described in detailed:

Process flow of Scrum:


Process flow of scrum testing is as follows:

Each iteration of a scrum is known as Sprint


Product backlog is a list where all details are entered to get end product
During each Sprint, top items of Product backlog are selected and turned into Sprint backlog
Team works on the defined sprint backlog
Team checks for the daily work
At the end of the sprint, team delivers product functionality

eXtreme Programming (XP)


Extreme Programming technique is very helpful when there is constantly changing demands or requirements from the customers or when
they are not sure about the functionality of the system. It advocates frequent "releases" of the product in short development cycles, which
inherently improves the productivity of the system and also introduces a checkpoint where any customer requirements can be easily
implemented. The XP develops software keeping customer in the target.
Business requirements are gathered in terms of stories. All those stories are stored in a place called the parking lot.

In this type of methodology, releases are based on the shorter cycles called Iterations with span of 14 days time period. Each iteration
includes phases like coding, unit testing and system testing where at each phase some minor or major functionality will be built in the
application.

Phases of eXtreme programming:


There are 6 phases available in Agile XP method, and those are explained as follows:

Planning
Identification of stakeholders and sponsors
Infrastructure Requirements
Security related information and gathering
Service Level Agreements and its conditions

Analysis
Capturing of Stories in Parking lot
Prioritize stories in Parking lot
Scrubbing of stories for estimation
Define Iteration SPAN(Time)
Resource planning for both Development and QA teams

Design
Break down of tasks
Test Scenario preparation for each task
Regression Automation Framework

Execution
Coding
Unit Testing
Execution of Manual test scenarios
Defect Report generation
Conversion of Manual to Automation regression test cases
Mid Iteration review
End of Iteration review

Wrapping
Small Releases
Regression Testing
Demos and reviews
Develop new stories based on the need
Process Improvements based on end of iteration review comments

Closure
Pilot Launch
Training
Production Launch
SLA Guarantee assurance
Review SOA strategy
Production Support
There are two storyboards available to track the work on a daily basis, and those are listed below for reference.

Story Cardboard
o This is a traditional way of collecting all the stories in a board in the form of stick notes to track daily XP activities. As
this manual activity involves more effort and time, it is better to switch to an online form.

Online Storyboard
o Online tool Storyboard can be used to store the stories. Several teams can use it for different purposes.

Crystal Methodologies
Crystal Methodology is based on three concepts

1. Chartering: Various activities involved in this phase are creating a development team, performing a preliminary feasibility
analysis, developing an initial plan and fine-tuning the development methodology

2. Cyclic delivery: The main development phase consists of two or more delivery cycles, during which the

1. Team updates and refines the release plan

2. Implements a subset of the requirements through one or more program test integrate iterations

3. Integrated product is delivered to real users

4. Review of the project plan and adopted development methodology

3. Wrap Up: The activities performed in this phase are deployment into the user environment, post- deployment reviews and
reflections are performed.

Dynamic Software Development Method (DSDM)


DSDM is a Rapid Application Development (RAD) approach to software development and provides an agile project delivery framework. The
important aspect of DSDM is that the users are required to be involved actively, and the teams are given the power to make decisions.
Frequent delivery of product becomes the active focus with DSDM. The techniques used in DSDM are

1. Time Boxing

2. MoSCoW Rules
3. Prototyping

The DSDM project consists of 7 phases

1. Pre-project

2. Feasibility Study

3. Business Study

4. Functional Model Iteration

5. Design and build Iteration

6. Implementation

7. Post-project

Feature Driven Development (FDD)


This method is focused around "designing & building" features. Unlike other agile methods, FDD describes very specific and short phases
of work that has to be accomplished separately per feature. It includes domain walkthrough, design inspection, promote to build, code
inspection and design. FDD develops product keeping following things in the target

1. Domain object Modeling

2. Development by feature

3. Component/ Class Ownership

4. Feature Teams

5. Inspections

6. Configuration Management

7. Regular Builds

8. Visibility of progress and results

Lean Software Development


Lean software development method is based on the principle "Just in time production". It aims at increasing speed of software
development and decreasing cost. Lean development can be summarized in seven steps.

1. Eliminating Waste

2. Amplifying learning

3. Defer commitment (deciding as late as possible)

4. Early delivery

5. Empowering the team


6. Building Integrity

7. Optimize the whole

Kanban
Kanban originally emerged from Japanese word that means, a card containing all the information needed> to be done on the product at
each stage along its path to completion. This framework or method is quite adopted in software testing method especially in agile testing.

Difference between Scrum and Kanban

Scrum Kanban

In scrum technique, test must No particular item size is


be broken down so that they can be prescribed
completed within one sprint
Prescribes a prioritized product Prioritization is optional
backlog
Scrum team commits to a Commitment is optional
particular amount of work for the
iteration
Burndown chart is prescribed No particular item size is
prescribed
Between each sprint, a scrum A Kanban board is
board is reset persistent. It limits the number
of items in workflow state
It cannot add items to ongoing It can add items whenever
iteration capacity is available
WIP limited indirectly WIP limited directly
Timeboxed iterations Timeboxed iterations
prescribed optional

Agile metrics:
Metrics that can be collected for effective usage of Agile is:

Drag Factor
o Effort in hours which do not contribute to sprint goal
o Drag factor can be improved by reducing number of shared resources, reducing the amount of non-contributing
work
o New estimates can be increased by percentage of drag factor -New estimate = (Old estimate+drag factor)
Velocity
o Amount of backlog converted to shippable functionality of sprint
No of Unit Tests added
Time taken to complete daily build
Bugs detected in an iteration or in previous iterations
Production defect leakage

You might also like