Diane Strode Agile Methods An Unexpected Journey

advertisement
Agile methods: An unexpected
journey
Diane Strode PhD
Faculty of Business and Information Technology
Whitireia Polytechnic
Victoria Business School
Victoria University of Wellington
Overview
• Motivation
• Pre-history, agile methods in 2000, adaptation,
optimal environments, adoption, governance...agile
software development today
• References and resources
2
Motivation...teaching
• Project management to future PMs
– A project manager coordinates and controls software
projects
– Gantt charts, PERT charts
• Analysis and design to future IT BAs
– Analyse, then design, then code, then test, AND document
• Programming to future developers
– Testing – separation of concerns
– Meeting specifications
So what’s new in this
area – Ahhh...agile
methods
3
Primary sources
• Doctor of Philosophy (Information Systems) 2012
– A theory of coordination in agile software development
projects
• Master of Information Sciences (Information
Systems) 2005
– The agile methods: An analytical comparison of five agile
methods and an investigation of their target environment
• 15 individual software development projects
4
Agile pre-history
• 17 practitioners decided to meet at Snowbird in USA,
2001
– Based on their experiences, they rejected waterfall processes
and traditional project management practices 
“heavyweight methodologies”
– All working on individual “lightweight” methodologies based
on their experience in development teams
• Discussed and agreed on a manifesto
5
http://agilemanifesto.org
6
7
Focus on
business value of
software
No detailed upfront
requirement specification
Frequent demos
and feedback /
Frequent releases
to production
Very close customer
contact
8
Focus on
business value of
software
No detailed upfront
requirement specification
Support the team
Trust the team
Co-location
Frequent demos
and feedback /
Frequent releases
to production
Very close customer
contact
No last minute rush /
burnout
9
Focus on
business value of
software
No detailed upfront
requirement specification
Support the team
Trust the team
Co-locate
Completed
functionality
No last minute rush /
burnout
Frequent demos
and feedback /
Frequent releases
to production
Very close customer
contact
Design and quality
No gold plating
Self-organising
Continuous process
improvement 10
Acronym
DSDM
2
Agile Method
Dynamic Systems Development
method
Crystal methods
Crystal
Cockburn (1998)
Cockburn (2002)
3
Extreme Programming
XP
Beck (1999), Beck (2000) 1st Edition
Beck and Andres (2005) 2nd Edition
4
Adaptive Software Development
ASD
Highsmith (2000)
5
Scrum
Scrum
6
Feature Driven Development
FDD
Beedle, Devos, Sharon, Schwaber, &
Sutherland (1999)
Schwaber & Beedle (2002)
Palmer & Felsing (2002)
7
Lean Development
LD
Charette (2002)
Poppendiek & Poppendiek (2003)
8
EVO
EVO
Gilb (2005)
9
AgileUP
AUP
Ambler (2008)
First published on-line 2005
1
Source
DSDM (Dynamic Systems Development
Method, Version 2, 1995), Stapleton (1997)
11
Purpose
• Scrum –for project management of iterative projects
• XP –software development practices for high-change
environments
• DSDM - a framework for iterative projects
• Crystal methods - for designing a methodology
12
Agile Software Development
XP
...
Lean
DSDM
Agile
Methods
FDD
Crystal
Scrum
ASD
13
Scrum
One-month “Sprints”
or repeated cycles of
activity
14
XP – Extreme Programming
Iterations of 1-4
weeks
15
Agile practices
16
Agile software development
• Each agile method consists of a set of practices
• Initially the belief was that a method should be
adopted in its entirety
• In projects, practices are “cherry picked” or
tailored
• So if you use any method, any combination of
methods, or one or more agile practices, you
can say you are doing…
Agile software development
17
Agile method combinations
• XP + Scrum
• XP provides software development techniques
+ Scrum provides management practices
18
Commonalities – 5 agile methods
•
•
•
•
•
•
•
•
All published between 1995 – 2002 in USA and UK
Developed by practitioners (not academics)
Project manager and developer perspective
Incremental development
Iterative development - 1 month iterations optimal
Suitable for projects undergoing constant change
Active user involvement
Feedback (from testing, from users) and learning
19
Commonalities – 5 agile methods cont’d.
•
•
•
•
•
Teamwork and empowered teams
Communication between all stakeholders is critical
Small teams of 3-10 programmers is optimal
Frequent meetings, daily is optimal
Working software is the main product of
development
• Modelling techniques are not mandated
• Minimise documentation
20
When should you use an agile method?
• Research study...
Nine projects, different types of organisation,
different types of product, questionnaire
Calculated agile method usage
Looked at correlation between agile method usage
and factors in the development environment
21
When should you use an agile method?
• Began with a definition of success
• Success is when a project is using all of the practices
from their selected method
– e.g. if using XP then you are using all XP practices 100% of
the time
22
Research design
• First, developed a list of factors that various authors believe
are necessary for successful agile software development - 31
• Then, isolated all practices from five agile methods (XP,
Scrum, ASD, Crystal, DSDM) – 45
• Studied correlation between environmental factors and
adoption of practices
23
Research design
• Questionnaire
– Included questions to assess use of 31 environment factors
– Included a randomised list of 45 practices from five agile methods
– Completed by nine experienced project leaders
• Interview
– Each project leader was interviewed to ensure consistency of
understanding about the various practices
24
The projects
Project
Method
Org type
Org size
Type of system
Alpha
XP
P
100-150
Control system
Beta
XP
SOE
150-200
Information presentation
Delta
XP/ Scrum
G
13000-14000
Web development
Zeta
DSDM
P
300
DSS/MIS
Theta
RUP/XP
P
1400-1500
MIS
Iota
RUP
G
600
Transaction processing
Rho
Ad hoc
G
4500-5000
MIS
Tau
Ad hoc
P
5-10
Shrink wrapped software
Chi
Ad hoc
G
300-400
MIS
Key
G – Government department or fully government funded organisation
SOE – State Owned Enterprise
P – Privately owned company
DSS – Decision Support System
MIS – Management Information System
25
Organisational factors investigated
• Organisation factors
– social interaction is trustful, collaborative, competent…
• Domain factors
– Internet application domains, gaming, inventory …
• Technological factors
– automated testing, object-oriented technology…
• Project factors
– time pressure, requirements stability…
• People factors
– CRACK customers, experienced developers…
Collaborative, Representative,
Authorised, Committed,
Knowledgeable
26
Agile method usage
Project 
Alpha
Beta
Delta
Delta
Theta
Zeta
Iota
Tau
Chi
Rho
Development
method
used
XP
XP
XP
Scrum
XP
Scrum
XP
RUP
DSDM
RUP
Ad
hoc
Ad
hoc
Ad
hoc
Compared with
XP
XP
XP
Scrum
XP
DSDM
XP
XP
XP
XP
96%
56%
67%
67%
63%
94%
40%
54%
30%
18%
Agile method
usage
Result: Certain organisational factors correlate with higher usage of agile practices
Key
Blue area shows non-agile projects
All non-agile projects were assessed against XP
27
Agile method usage
Project 
Alpha
Beta
Delta
Delta
Theta
Zeta
Iota
Tau
Chi
Rho
Development
method
used
XP
XP
XP
Scrum
XP
Scrum
XP
RUP
DSDM
RUP
Ad
hoc
Ad
hoc
Ad
hoc
Compared with
XP
XP
XP
Scrum
XP
DSDM
XP
XP
XP
XP
96%
56%
67%
67%
63%
94%
40%
54%
30%
18%
Agile method
usage
Result: An agile project can tailor their agile method so much that it is the same as using
ad hoc development (no method)
Key
Blue area shows non-agile projects
All non-agile projects were assessed against XP
28
Typical result
The team members are actively involved in
decision making (Q34)
120.00
Agile usage %
100.00
80.00
60.00
40.00
20.00
0.00
0
1
2
3
4
5
6
Extent
Scatter plot of organisation enables empowerment of people Q34.
Spearman’s Rho, 2 tailed, 0.05 significance level
29
Target environment for agile methods
• Organisation
– Values feedback and learning. Social interaction in the organisation is
trustful, collaborative, and competent
– Values teamwork, is flexible and participative, and encourages social
interaction. The project manager acts as a facilitator
– Enables empowerment of people
– Is results oriented
– Is based on loyalty and mutual trust and commitment
– The management style is that of leadership and collaboration
– Leadership in the organisation is entrepreneurial, innovative, and risk
taking
• Project
– Projects undergoing constant change
30
• Is this generalisable, or cause and effect?
- No • Sample too small, as usual, further studies needed!
Keep in mind that you might have fewer problems
using an agile method if these factors are present in
your organisation or project
31
Implications
• Many practices work well together, so…
• If you change the method too much you loose some
advantages, however…
• If you don’t change the method you may need to
change your organisation; this can be difficult,
painful, and sometimes impossible.
32
Agile software development impact...
• Organisation
– Structure – peoples’ roles – manager, project manager, business analyst,
developer, tester....
– Culture – command & control  self-organisation
– Human resource practice – rewards, individual  team, skill sets
– Customer involvement
– Contract negotiation
• Software project
–
–
–
–
System quality - negotiable
Learn as you go/ incremental delivery
Software for communication (but it’s still star of the show)
Co-located & cross-functional teams (can understand and do each others work)
• Technical practices
– Test driven development , Continuous integration, Refactoring
33
IT governance and agile projects
• Are compatible, but not seamlessly compatible
• Depends on the organisation’s ability to be flexible in their
implementation of governance processes...
“Agile thought leaders have not provided much clear or detailed guidance
about scaling Agile practices to the enterprise level, where many governance
issues are ready to pounce. To make Agile work within enterprise
governance, managing the people issues first is critical. Next, organizations
must apply a common-sense approach to processes, enabling transitioning
teams to manage demand and deliver efficiently without adding layers of
bureaucracy. In addition, organizations should use tools to provide the
transparency necessary to ensure that demand is prioritized and selected
based on the value the finished product will deliver to the organization.”
Forrester Research July 2012
34
Technical
requirements
Conflict in the need to
meet governance
requirements with the
agile team’s focus on only
delivering business value
to their client
Functional
requirements
Governance
requirements
Stories (work tasks) for
processing by the agile team
35
Agile today
• Coaches and coaching
– Internal and external (consultants)
• Certification
–
–
–
–
–
Certified IC Agile Professional (Alistair Cockburn)
Certified ScrumMaster and Scrum practitioner certifications
DSDM foundation/practitioner
PMIs Agile Certified Practitioner certification
Agile Project Management Certification (integrates with PRINCE2!) –
APMG examination institute
• Agile encroachment
– IIBA - Agile extension integrated into the BABOK
– Agile and PMBOK – remain incompatible on many fronts
– Agile and SWEBOK – remain incompatible on many fronts
36
http://www.eweek.com/developer/agile-developers-needed-demand-outpaces-supplystudy/
Development
positions
37
Adoption rates
• Wide variation in reported adoption rates world wide
– 14% (Dyba & Dingsoyr, 2008) – an academic report
– 35% (West & Grant, 2010) – a Forrester research report
– 69% (Ambler, 2009) – an agile guru’s report
• Indisputable - agile software development - has
grown in popularity in the last 12 years
• Advocated as one of the top ten “best practices” of
IT project management (Nelson, 2007)
38
Further information…
• APN
– Agile Professionals Network
– Not-for-profit
– Monthly meetings in Wellington with seminars from
industry on success and issues with agile software
development
– http://www.agileprofessionals.net/
39
Resources
• Doctor of Philosophy (Information Systems) 2012
– A theory of coordination in agile software development projects
• Master of Information Sciences (Information Systems) 2005
– The agile methods: An analytical comparison of five agile methods
and an investigation of their target environment
• Please contact me if you would like copies of any of the resources
mentioned in this seminar
• diane.strode@alumni.unimelb.edu.au
• My research site
• https://sites.google.com/site/dianestrodepublic/
40
Agile methods: An
unexpected journey
Download