agile development at w3i
Post on 14-May-2015
563 Views
Preview:
TRANSCRIPT
Agile Development Methodology
Jeff BollingerVP of Information Systemsjeff.bollinger@w3i.com @Jbollingerwww.jeffbollinger.net
St. Cloud State UniversityIS 350 10.13.2010
@JBollinger
Agenda
• Software Development Methodologies• Waterfall• Agile• Scrum @ W3i
@JBollinger
What’s a Development Methodology?
• A process or methodical approach to developing software.
• A repeatable process used to:– Handle Requirements– Improve Quality– Manages Risk
@JBollinger
Examples of Methodologies
• Waterfall• Agile
– Scrum W3i’s Flavor– XP
• Kanban
@JBollinger
Waterfall
Requirements
Design
Implementation
Testing
Deployment
Maintenance
@JBollinger
Waterfall Works Well When…
• Requirements are stable• Technology is well known
and mature• Everything happens as
one would expect• We are not taking on
anything new or unknown• We have done this many
times before
@JBollinger
Waterfall
Requirements
Design
Implementation
Testing
Deployment
Maintenance
Change
Takes too long
Gets skipped
The Real World
@JBollinger
What is Agile?
• Agile software development refers to a group of software development methodologies based on iterative development, where requirements and solutions evolve through collaboration between self-organizing cross-functional teams.
@JBollinger
The Agile Manifesto
We are uncovering better ways of developing software by doing it and helping others do it. Through this work we have come to value:
• Individuals and interactions over processes and tools • Working software over comprehensive documentation• Customer collaboration over contract negotiation • Responding to change over following a plan
That is, while there is value in the items on the right, we value the items on the left more.
http://agilemanifesto.org/
@JBollinger
Agile Principles
Our highest priority is to satisfy the customer through early and continuous delivery of valuable software.
Welcome changing requirements, even late in development. Agile processes harness change for the customer's competitive advantage.
Deliver working software frequently, from a couple of weeks to a couple of months, with a preference to the shorter timescale.
Business people and developers must work together daily throughout the project.
@JBollinger
Agile Principles
• Build projects around motivated individuals. Give them the environment and support they need, and trust them to get the job done.
• The most efficient and effective method of conveying information to and within a development team is face-to-face conversation.
• Working software is the primary measure of progress.
• Agile processes promote sustainable development. The sponsors, developers, and users should be able to maintain a constant pace indefinitely.
@JBollinger
Agile Principles
• Simplicity--the art of maximizing the amount of work not done is essential.
• Continuous attention to technical excellence and good design enhances agility.
• The best architectures, requirements, and designs emerge from self-organizing teams.
• At regular intervals, the team reflects on how to become more effective, then tunes and adjusts its behavior accordingly.
@JBollinger
Why Agile?
@JBollinger
The Agile Paradigm Shift
PLANDriven
Fixed
Estimated
VisionVALUEDriven
Waterfall Agile
Requirements
Features
Resources Time
Resources Time
@JBollinger
What is Scrum?
• Scrum is popular flavor of agile• Used @ W3i for past 5 years
@JBollinger
Scrum Illustration
@JBollinger
Scrum
User Story
Epics
Planning Meeting
Review MeetingStory Points
TasksBacklog
Velocity
Burndown Chart
Retrospective
Estimating
@JBollinger
User Stories
• A software requirement formulated as one or two sentences in the everyday business language of the user
• Format: As a (role) I want (something) so that (benefit)
• Example: – As a customer service representative, I want to
search for my customers by their first and last name, so that I can spend less time browsing lists.
@JBollinger
Estimating
• A consensus-based estimation method• Estimate effort or relative size of
development tasks • Estimate in Story Points• Story points possibilities are
0,1,2,3,5,8,13
@JBollinger
Velocity
• Number of story points completed in one sprint (iteration)
• Calculated by taking the last three sprint’s rolling average
@JBollinger
Planning Meeting
• Approximately one day• Includes Development Team and Business Owners• Pull prioritized stories from the backlog and
technically plan them– Call in business owners to clarify requirements– Database design – ERD– API Specifications– Break stories down into several tasks
• Commitment is made to Business Owners to deliver stories by end of the sprint
@JBollinger
Daily Scrum
• Stand-up meeting• Not longer than 15 minutes• Each developer answers 3 questions:
– What did you work on yesterday?– What are you going to work on today?– What are your roadblocks, if any?
@JBollinger
Burndown
• Illustrates the progress of the current sprint.
@JBollinger
Sprint Reviews
• Occurs at the end of every sprint • Business owners and Development Team
are present• Demonstration of working software is
given by the development team
@JBollinger
Retrospectives
• Learning• Continuous Improvement• Meeting with product management, team
members, managers• Discussion on successes and areas for
improvement in the current sprint
@JBollinger
Questions?Jeff BollingerVP of Information Systemsjeff.bollinger@w3i.com
top related