AGILE GREECE 28th Athens Agile/Scrum...

27
1 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development and how Agile Practices deal with them" AGILE GREECE

Transcript of AGILE GREECE 28th Athens Agile/Scrum...

Page 1: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

1

28th Athens Agile/Scrum Meetup

2016-06-14

"AntiPatterns in Software Development and how Agile Practices deal with them"

AGILE GREECE

Page 2: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

2

Overview

● AntiPatterns● Agile and AntiPatterns

– Case Studies

– LIVE Workshop with further Case Studies

● Conclusion

Page 3: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

3

AntiPatterns

● “Something that looks like a good idea, but which backfires badly when applied”

[Jim Coplien]

Page 4: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

4

Categories

● Business Operations– Organizational

– Project Management

– Human Resources

– etc.

● SW Engineering– SW Design

● OO Design

– Programming

– Methodological

– SW Testing

– etc.

Page 5: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

5

Agile

● Can it alleviate AntiPatterns?

A

Page 6: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

6

Seagull Manager

“Seagull managers fly in, make a lot of noise, dump on everyone, then fly out.”

[Ken Blanchard]

Page 7: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

7

Agile and 'Seagull Manager'

Teams are served by the Scrum Master

AAA

Page 8: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

8

Smoke and Mirrors

“Functionality that does not yet exist, but appears as though it does”

Random()

Page 9: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

9

Agile and 'Smoke and Mirrors'

● Agile focuses on Working Software● “Working Software over comprehensive

documentation”● “Working Software is the primary measure of

progress”● “The purpose of each Sprint is to deliver

Increments of potentially releasable functionality”

AAA

Page 10: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

10

God Object

● “In OOP, a God Object is an object that knows too much or does too much”

Page 11: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

11

Agile and 'God Object'

● Quality is NOT an after-thought● Code Quality practices

– Code Reviews

– Pair Programming

– Code Analysis Tools● Since the very baby steps of project

A

Page 12: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

12

Let's Discuss!

Page 13: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

13

(1) Law of Triviality

● Aka. “Bicycle Shed”● “Members of an organization give

disproportionate weight to trivial issues”● 'Organizational' type

Page 14: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

14

(2) Micromanagement

● “A management style whereby a manager excessively observes or controls the work of subordinates or employees”

● 'Organizational' type

Page 15: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

15

(3) Stovepipe

● Aka. “Silos”● “A stovepipe organization has a structure which

largely restricts the flow of information within the organization to up-down through lines of control, inhibiting or preventing cross-organizational communication”

● 'Organizational' type

Page 16: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

16

(4) Premature Optimization

● “Sacrifice of maintainability, in favor of performance optimization, during early stages of design and development”

● 'SW Engineering Methodology' type

Page 17: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

17

(5) Overengineering

● “Spending, and effectively wasting, resources making a project more robust and complex than is needed”

● 'Project Management' type

Page 18: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

18

(6) Ninety-Ninety Rule

● “Tendency to underestimate the amount of time to complete a project when it is 'nearly done'”

● 'Project Management' type

Page 19: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

19

(7) Analysis Paralysis

● “A project stalled in the analysis phase, unable to achieve support for any of the potential plans of approach”

– Generally, “The state of over-analyzing a situation so that a decision or action is never taken”

● 'Organizational' type

Page 20: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

20

(8) Mushroom Management

● “The running of a company where the communication channels between the managers and the employees do not work properly. The personnel are not familiar with the ideas or the general state of the company, and are given work without knowing the purpose of this work.”

● 'Organizational' type

Page 21: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

21

(9) Design by Committee

● “A project that has many designers involved but no unifying plan or vision”

● 'Organizational' type

Page 22: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

22

References – Sources

● Agile Manifesto● Cunningham & Cunningham, Inc.: AntiPatterns● Wikipedia: AntiPatterns [2016-06-06]● Dr. Martin Fowler 's blog:

– Article about AntiPatterns

● ScrumAlliance ● Milindageorge blog:

– Article about Scrum teams

Page 23: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

23

References – Pictures (I)

● Slide “AntiPatterns”– Picture of book 'AntiPatterns':

Amazon -> AntiPatterns

– Picture of book 'AntiPatterns in Project Management':

Amazon -> AntiPatterns in Project Management

● Slides about “Seagull Manager”– Picture of 'Seagull': Mirror.co.uk

– Picture of 'The Boss': Dilbert

– Picture of 'Scrum Master': ScrumAlliance -> Scrum Master

Page 24: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

24

References – Pictures (II)

● Slides about “Smoke and Mirrors”– Picture of 'Smoke and Mirrors': timeglassjournal

– Picture elements of 'calculate button' and 'gears': clker.com

– Picture of 'Product Owner': milindageorge blog -> scrum team roles

● Slides about “God Object”– Picture of 'Statue': Easter Islands

Page 25: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

25

Learn More

● W.J. Brown, R.C. Malveau, H.W. "Skip" McCormick, T.J. Mowbray: "AntiPatterns: Refactoring Software, Architectures, and Projects in Crisis"

● W.J. Brown, H.W. "Skip" McCormick, T.J. Mowbray: "AntiPatterns in Project Management"

Page 26: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

26

Contact Info, etc.

● If you feel like, you can find me at the Agile Meetup:

pek● Or, perhaps write to me at:

pkaklam [at] gmail [dot] com

● And since you have read that long, here is a tip. Start your trip in AntiPatterns with the third and first items of the “References – Sources” slides.

Page 27: AGILE GREECE 28th Athens Agile/Scrum Meetupfiles.meetup.com/9788192/AthensAgileMeetup28_AntiPatterns.pdf · 28th Athens Agile/Scrum Meetup 2016-06-14 "AntiPatterns in Software Development

27

THANK YOU