SCRUM
What is Scrum?
Scrum is an agile, iterative, incremental process for developing any product or managing
any work.
It produces a potentially shippable set of functionality at the end of every iteration.
Scrum is a team-based approach to iteratively, incrementally develop systems and
products when requirements are rapidly changing.
Scrum terminology
Scrum Master: The person(s) in charge of the tracking and the daily updates for the
scrum (Equivalent to a Project Manager) also referred as the Scrum Lord.
Back log: The task to be completed.
Sprint: A 4 to 6 week period in which a set of tasks are committed to and which are
finished.
Burn Down: Daily progress for a sprint over the sprint's length.
Scrum is ideally suited for projects with rapidly changing or highly emergent
requirements. The work to be done on a Scrum project is listed in the Product Backlog,
which is a list of all desired changes to the product. At the start of each sprint a Sprint
Planning Meeting is held during which the Product Owner prioritizes the Product
Backlog and the Scrum Team selects the tasks they can complete during the coming
Sprint. These tasks are then moved from the Product Backlog to the Sprint Backlog.
Each day during the sprint conducts a brief daily meeting called the Daily Scrum, which
helps the team stay on track.
At the end of each sprint the team demonstrates the completed functionality at a Sprint
Review Meeting.
Graphically, Scrum looks something like this:
Characteristics of Scrum
A product backlog of prioritized work to be done.
Completion of a fixed set of backlog items in a series of short iterations or sprints;
A brief daily meeting or scrum, at which progress is explained, upcoming work is
described and impediments are raised.
A brief sprint planning session in which the backlog items for the sprint will be
defined.
A brief sprint retrospective, at which all team members reflect about the past sprint.
Scrum enables the creation of self-organizing teams by encouraging co-location of all
team members, and verbal communication across all team members and disciplines that
are involved in the project.
Scrum adopts an empirical approach – accepting that the problem cannot be fully
understood or defined, focusing instead on maximizing the team's ability to deliver
quickly and respond to emerging requirements.
Product Backlog
It is the master list of all functionality desired in the product.
When a project is initiated there is no comprehensive effort to write down all
foreseeable tasks or requirements.
Typically, everything obvious is written down, which is almost always more than
enough for a first sprint.
The Product Backlog is then allowed to grow and change as more is learned about the
product and its customers.
Sprint Backlog
The sprint backlog is the list of tasks that the Scrum team is committing that they will
complete in the current sprint.
Items on the sprint backlog are drawn from the Product Backlog, by the team based on
the priorities set by the Product Owner and the team's perception of the time it will take
to complete the various features.
It is critical that the team selects the items and size of the sprint backlog. Because they
are the ones committing to completing the tasks they must be the ones to choose what
they are committing to.
The sprint backlog is very commonly maintained as an Excel. An example of the Sprint
Backlog in Excel looks like this:
During the Sprint the ScrumMaster maintains the sprint backlog by updating it to reflect
which tasks are completed and how long the team thinks it will take to complete those
that are not yet done. The estimated work remaining in the sprint is calculated daily and
graphed, resulting in a sprint burndown chart
The Daily Scrum
On each day of a sprint, the team holds daily meetings (“the daily scrum”). Meetings are
typically held in the same location and at the same time each day. Ideally the daily
scrums are held in the morning as they help set the context for the coming day's work.
The daily scrum is not used as a problem-solving or issue resolution meeting. Issues that
are raised are taken offline and usually dealt with by the relevant sub-group immediately
after the daily scrum. During the daily scrum each team member provides answers to the
following three questions:
1. What did you do yesterday?
2. What will you do today?
3. Are there any impediments in your way? / Do you have any problems preventing
you from accomplishing your goal?
The daily scrum is not a status update meeting in which a boss is collecting information
about who is behind schedule. Rather, it is a meeting in which team members make
commitments to each other. If a programmer stands up and says "Today I will finish the
data storage module" everyone knows that in tomorrow's meeting he will say whether or
not he did finish. This has the wonderful effect of helping a team realize the significance
of these commitments and that their commitments are to each other, not to some far-off
customer or salesman.
Any impediments that are raised become the ScrumMaster's responsibility to resolve as
quickly as possible. Typical impediments are:
• My ____ broke and I need a new one today.
• I need help debugging a problem with ______.
• I'm struggling to learn ______ and would like to pair with someone on it.
• The department VP has asked me to work on something else "for a day or two."
Sprint Planning Meeting
The Sprint Planning Meeting is attended by the Product Owner, Scrum Master, the entire
Scrum Team, and any interested and appropriate management or customer
representatives.
During the meeting the product owner describes the highest priority features to the team.
The team asks enough questions during this meeting so that they can go off after the
meeting and determine which tasks they will move from the product backlog to the sprint
backlog.
Collectively, the Scrum team and the product owner define a sprint goal, which is a short
description of what the sprint will attempt to achieve.
After the sprint planning meeting, the Scrum team meets separately to discuss what they
heard and decide how much they can commit to during the coming sprint.
In some cases there will be negotiation with the product owner but it will always be up to
the team to determine how much they can commit to completing.
Sprint Review Meeting
At the end of each sprint a sprint review meeting is held. During this meeting the Scrum
team shows what they accomplished during the sprint. Typically this takes the form of a
demo of the new features.
The sprint review meeting is intentionally kept very informal, typically with rules
forbidding the use of PowerPoint slides and allowing no more than two hours of
preparation time for the meeting. A sprint review meeting should not become a distraction
or significant detour for the team; rather, it should be a natural result of the sprint.
Participants in the sprint review typically include the Product Owner, the Scrum team, the
ScrumMaster, management, customers, and engineers from other projects.
Advantages:
Following are some practices for the Scrum:
Customers become a part of the development team
Frequent intermediate deliveries with working functionality. – Incremental development
and releases (may be internal only) – providing you an opportunity to validate and verify
at shorter intervals rather than only at the end; thereby, providing you time to fix, and
reducing the cost to fix.
Frequent risk and mitigation plans developed by the development team itself. – Risk
Mitigation, Monitoring and Management (risk analysis) at every stage and with genuinity
– Make it live, and continuous activity.
Daily status discussion with the team. – Standup meetings (accomplishments, to be
accomplished, issues / concerns / risks)
Transparency in planning and module development – Let everyone know who is
accountable for what and by when.
Frequent stakeholder meetings to monitor progress – Balanced (Delivery, Customer,
Employee, Process– Stakeholders' update – You have to have Advance Warning
Mechanism, i.e. visibility to potential slippage / deviation ahead of time.
To Do:
HISTORY:
Scrum is a rugby offensive term where a team pushes forward to score as a single unit.
http://www.mountaingoatsoftware.com/sprint_planning_meeting