jon grommes

31
Jon Grommes Feature Driven Development

Upload: ipo

Post on 21-Jan-2016

52 views

Category:

Documents


0 download

DESCRIPTION

Jon Grommes. Feature Driven Development. Overview. What is Feature Driven Development History of FDD Defining a Feature FDD Roles FDD Reporting FDD Process FDD Quality. What is Feature Driven Development(FDD). - PowerPoint PPT Presentation

TRANSCRIPT

Page 1: Jon Grommes

Jon Grommes

Feature Driven Development

Page 2: Jon Grommes

Overview

• What is Feature Driven Development• History of FDD• Defining a Feature• FDD Roles• FDD Reporting• FDD Process• FDD Quality

Page 3: Jon Grommes

What is Feature Driven Development(FDD)• Feature Driven Development is a iterative and incremental

software development process

• FDD is a software process that was created to deliver frequent, working deployable code repeatedly to the customer.

• FDD is considered a straight forward approach to developing software systems that is broken down into five processes.

• FDD builds the correct system

Page 4: Jon Grommes

The FDD Process

1. Develop an Overall Model2. Build a Feature List3. Plan by Feature4. Design by Feature5. Build by Feature

Page 5: Jon Grommes

What is Feature Driven Development

Iterative development process

(modified for FDD)

Page 6: Jon Grommes

History of FDD

• First created by Jeff De Luca for a 50 person 15 month project

• Luca used the process again, with 250 people 18 month project.

• FDD is heavily influenced by Peter Coad and his idea of using a feature list to manage requirements 

• Documented in 1999, by when Luca and Coad and Eric Lefebvre wrote a book which was entitled “Java Modeling in Color with UML.”

Page 7: Jon Grommes

Defining a Feature

• A feature is a “customer-valued function that can be implemented in two weeks or less,” according to COA99.(Coad and colleagues) 

• Features are suppose to be small enough so that the customer can describe them exactly.

• Should be small enough to implement in one to three days. But if the feature is estimated to take more than ten days to implement then it should be broken down into smaller features.

Page 8: Jon Grommes

Naming a Feature

• COA99 created a template for defining a feature

• <action> the <result> <by | for | of | to> a(n) <object>

• Examples• Calculate the total of a Sale• Add a student to the class list

Page 9: Jon Grommes

Grouping Features

• A feature set is a grouping of business related features.

• <action><-ing> a(n) <object>• Example :Making a product Sale• A major feature set is groups of feature

sets• <object> management• Example: Product Sales Management

Page 10: Jon Grommes

FDD Roles

• Project Manager○ Responsible for progress reports, budget management, and maintains resources

• Chief Architect○ Responsible for the creation of the overall design of the system

•  Chief Programmers○ Responsible for managing programming teams, helping with design of the   system

Page 11: Jon Grommes

FDD Roles

• Development Managers○ Responsible for day-to-day activities

• Class Owners○ Responsible for creating and testing classes

• Domain Experts○ Usually the customer, help the class owners build the correct system

Page 12: Jon Grommes

Class Owners

• Class give to individual developers or two people

• Class owner responsible that happen in their class

Opposite• Collective Ownership

• Any developer can change any line of code

Page 13: Jon Grommes

Class Owner Advantages• Sole person is responsible for the class• Expert on every class• Can make changes faster on a class• Owner has something to take pride in• Bring consistency to a class

Disadvantages• Possible long waits times to edit other

classes• Risk of Lack of knowledge about the class

Page 14: Jon Grommes

FDD Reporting Parking Lot Report 

Page 15: Jon Grommes

FDD Reporting

Parking Lot Report

Page 16: Jon Grommes

• Milestone chart

Domain Walkthrough

Design Design Inspection

Code Code Inspection

Promote to Build

1% 40% 3% 45% 10% 1%

Page 17: Jon Grommes

The FDD Process

1. Develop an Overall Model2. Build a Feature List3. Plan by Feature4. Design by Feature5. Build by Feature

Page 18: Jon Grommes

The FDD Process

• Upfront Design Activities• Develop an Overall Model• Build a Features List• Plan by Feature

• Create systems by Features• Design by Feature• Build by Feature

Page 19: Jon Grommes

The FDD Process

 

Page 20: Jon Grommes

1. Develop an Overall Model

• Create overall object model•Domain walk through•Manage scope•Form Modeling Team•Informal Feature List

•Model•Only major class and important functions•State relationships between major classes

•Sequence Diagram•Displaying complex functional requirements

•Review

•Notes

Page 21: Jon Grommes

2. Build a Feature List

•Features List•Feature List Team•Prioritize the Features

•For features: <action> the <result> <by | for | of | to> a(n) <object>•For features sets: <object> management•For major feature sets: <action><-ing> a(n) <object>.

•Review

Page 22: Jon Grommes

3. Plan by Feature

• Create Project Milestones•Form the Planning team•Setting Initial Dates

•Assigning Class Owners

•Review

Page 23: Jon Grommes

4. Design by Feature

• Feature Teams•Class Owners•Domain Walkthrough(optional)•Study Notes(optional)

•Develop sequence diagrams

•Refine Object Model

•Review

Page 24: Jon Grommes

5. Build by Feature

• Implement Classes and Methods

•Code Inspection

•Promote to Build

Page 25: Jon Grommes

FDD Process

 

Page 26: Jon Grommes

FDD Process

 

Page 27: Jon Grommes

FDD Quality

• Inspections• Design• Code

• Benefits• Knowledge transfer• Standards Conformance

• Unit Tests

Page 28: Jon Grommes

Summary

• Feature Driven Development is a iterative and incremental software development process

• FDD is a software process that was created to deliver frequent, working deployable code repeatedly to the customer.

• Overall FDD has a lot of good aspects to it that will allow it to be used a lot in the futrue.

Page 29: Jon Grommes

References

[1]        Stephen Palmer, John Felsing. (2002). A Practical Guide to Feature Driven Development. Upper Saddle River: Prentice Hall. [2]        Pressman, R. (2005). Software Engineering A Practitioner's Approach. Crawfordsville: McGraw-Hill. [3]        Unkown. (2007, 6 17). Feature Driven Development. Retrieved 3 25, 2011, from SCMWise: http://www.scmwise.com/feature-driven-development.html [4]        Palmer, S. (2009, 11 20). An Introduction to Feature-Driven Development. Retrieved 3 25, 2011, from AgileZone: http://agile.dzone.com/articles/introduction-feature-driven [5]        Bauer, M. (2004, 5 27). FDD and Project Managment. Retrieved 3 27, 2011, from martinbauer: http://www.martinbauer.com/Articles/FDD-and-Project-Management [6]        Cause, G. (n.d.). Delivering Real Business Value using FDD. Retrieved 3 26, 2011, from methodsandtools: http://www.methodsandtools.com/archive/archive.php?id=19p3

http://www.featuredrivendevelopment.com/files/fddoverview.pdf

Page 30: Jon Grommes

Questions?