Development. Lecture 3



Similar documents
How To Plan A Project

Moonzoo Kim CS Division of EECS Dept. KAIST

CS435: Introduction to Software Engineering! " Software Engineering: A Practitioner s Approach, 7/e " by Roger S. Pressman

Agile Project Management By Mark C. Layton

Software processes that are:

Agile Development Overview

Ingegneria del Software Corso di Laurea in Informatica per il Management. Agile software development

Agile Development with C#

Software Processes. Agile Methods

Agile Project Management with Scrum

Agile Overview. 30,000 perspective. Juha Salenius CSPO CSM PMI-ACP PMP SCGMIS Workshop January 23 rd, 2013

Agile Projects 7. Agile Project Management 21

Introduction to Agile Software Development. EECS 690 Agile Software Development

AGILE SOFTWARE DEVELOPMENT: INTRODUCTION, CURRENT STATUS & FUTURE Pekka Abrahamsson Jyväskylä

Manifesto for Agile Software Development

Agile Software Development. Mohsen Afsharchi

26 May 2010 CQAA Lunch & Learn Paul I. Pazderski (CSM/CSP, OD-CM, CSQA) spcinc13@yahoo.com Cell: AGILE THROUGH SCRUM

Agile Project Management: Adapting project behaviors to the software development environment

LEAN AGILE POCKET GUIDE

ITSM Agile Intro Feb 5, 2015

Introduction to Agile Software Development

Agile Software Development

How to manage agile development? Rose Pruyne Jack Reed

Mitigating Risk with Agile Development. Rich Mironov CMO, Enthiosys

Role of Agile Methodology in Software Development

Topics covered. Agile methods Plan-driven and agile development Extreme programming Agile project management Scaling agile methods

History of Agile Methods

Comparative Study of Agile Methods and Their Comparison with Heavyweight Methods in Indian Organizations

PMBOK? You Can Have Both! June 10, Presented by:

COMP 354 Introduction to Software Engineering

CSSE 372 Software Project Management: Managing Agile Projects

This handbook is meant to be a quick-starter guide to Agile Project Management. It is meant for the following people:

Issues in Internet Design and Development

Agile QA s Revolutionary Impact on Project Management

Processes in Software Development. Presented by Lars Yde, M.Sc., at Selected Topics in Software Development, DIKU spring semester 2008

Agile-Waterfall Hybrid Jessica LaGoy, MS, PMP

Agile Project Management

USCIS/SPAS: Product Backlog Items and User Stories 4/16/2015. Dr. Patrick McConnell

The Basics of Scrum An introduction to the framework

Creating a High Maturity Agile Implementation

Digital Transformation of the Enterprise for SMAC: Can Scrum help?

CSSE 372 Software Project Management: More Agile Project Management

Agile Beyond The Team 1

Agile Fundamentals, ROI and Engineering Best Practices. Rich Mironov Principal, Mironov Consulting

Agile Requirements Generation Model: A Soft-structured Approach to Agile Requirements Engineering. Shvetha Soundararajan

Neglecting Agile Principles and Practices: A Case Study

Agile and Secure: Can We Be Both?

AGILE - QUICK GUIDE AGILE - PRIMER

Agile Project Management

Software Development with Agile Methods

How To Understand The Limitations Of An Agile Software Development

werteorientierte Unternehmenskultur

Introduction to Agile and Scrum

Software Requirements and Specification

Governments information technology

Agile Extension to the BABOK Guide

What does it mean to be Agile. Marek Majchrzak, Andrzej Bednarz Wrocław,

Agile and PRINCE2 And how they integrate. enterprise.bcs.org

Agile Software Development in the Large

Waterfall to Agile. DFI Case Study By Nick Van, PMP

Agile Scrum Training. Nice to meet you. Erik Philippus. Erik Philippus (1951)

Aristotle in an Agile World. By Ben Allen

SCEA 2010 EST06. Estimating Issues Associated with Agile. Bob Hunt. Galorath Incorporated

A Software Project Management Innovation (SPM) Methodology: A Novel Method for Agile Software Development

Agile with XP and Scrum

AGILE METHODOLOGY IN SOFTWARE DEVELOPMENT

AGILE vs. WATERFALL METHODOLOGIES

Jukka Mannila KEY PERFORFORMANCE INDICATORS IN AGILE SOFTWARE DEVELOPMENT

What Does Large Mean? Copyright 2003 by N. Josuttis and J. Eckstein 3. Why is Large an Issue?

Lean vs. Agile similarities and differences Created by Stephen Barkar -

Software Development Methodologies

The Agile Manifesto is based on 12 principles:

Bottlenecks in Agile Software Development Identified Using Theory of Constraints (TOC) Principles

PROCESS OF MOVING FROM WATERFALL TO AGILE PROJECT MANAGEMENT MODEL

Agile Methodologies and Its Processes

Agile Processes and Distributed Projects: Dream or Nightmare?

Project Management in Software: Origin of Agile

The traditional project management uses conventional methods in software project management process.

Introduction to Software Engineering: Overview and Methodologies

Comparing Scrum And CMMI

Agile on huge banking mainframe legacy systems. Is it possible?

Agile Software Development

Adopting Agile Project Management - Corporate Culture Must Match (Apr 15)

Agile Notetaker & Scrum Reference. Designed by Axosoft, the creators of OnTime the #1 selling scrum software.

Introduction to Agile Software Development Process. Software Development Life Cycles

10/4/2013. Sharif University of Technology. Session # 3. Contents. Systems Analysis and Design

Agile methods. Objectives

Agile Systems Engineering: What is it and What Have We Learned?

The Agility of Agile Methodology for Teaching and Learning Activities

Course Title: Planning and Managing Agile Projects

Advanced Software Engineering. Software Development Processes

When is Agile the Best Project Management Method? Lana Tylka

SECC Agile Foundation Certificate Examination Handbook

Agile Software Development

Agile Practitioner: PMI-ACP and ScrumMaster Aligned

Information Management for National Guard Agribusiness Development Teams: An Agile Development Case Study

Transcription:

Software Process in Modern Software Development Lecture 3

Software Engineering i Practice Software engineering practice is a broad array of principles, concepts, methods, and tools that must be considered d as software is planned and developed. Principles the elemental ideas that guide software engineers in the work that they do, providing a foundation from which software engineering g models, methods, and tools can be applied and evaluated. SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 2

Principles that Guide Process - I Pi Principle i #1. Be agile. Whether the process model you choose is prescriptive or agile, the basic tenets of agile development should govern your approach. Principle #2. Focus on quality at every step. The exit condition for every process activity, action, and task should focus on the quality of the work product that has been produced. Principle #3. Be ready to adapt. Process is not a religious experience and dogma has no place in it. When necessary, adapt your approach to constraints t imposed by the problem, the people, and the project itself. Principle #4. Build an effective team. Software engineering g process and practice are important, but the bottom line is people. Build a self-organizing team that has mutual trust and respect. SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 3

Principles that Guide Process - II Pi Principle i #5. Establish mechanisms for communication and coordination. Projects fail because important information falls into the cracks and/or stakeholders fail to coordinate their efforts to create a successful end product. Principle #6. Manage change. The approach may be either formal or informal, but mechanisms must be established to manage the way changes are requested, assessed, approved and implemented. Pi Principle i #7. Assess risk. Lots of things can go wrong as software is being developed. It s essential that you establish contingency plans. Principle #8. Create work products that provide value for others. Create only those work products that provide value for other process activities, actions or tasks. SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 4

Introduction to Agile Agile vs. Waterfall: A Tale of Two Teams SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 5

The Manifesto for Agile Software Development 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. SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 Kent Beck et al 6

What is Agility? Effective (rapid and adaptive) response to change Effective communication among all stakeholders Drawing the customer onto the team Organizing g a team so that it is in control of the work performed Yielding Rapid, incremental delivery of software SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 7

Agility and the Cost of Change SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 8

An Agile Process Is driven by customer descriptions of what is required (scenarios) Recognizes that plans are short-lived Develops software iteratively ti with a heavy emphasis on construction activities Delivers multiple software increments Adapts as changes occur SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 9

Agility Principles - I 1. Our highest priority is to satisfy the customer through early and continuous delivery of valuable software. 2. Welcome changing requirements, even late in development. Agile processes harness change for the customer's competitive advantage. 3. Deliver working software frequently, from a couple of weeks to a couple of months, with a preference to the shorter timescale. 4. Business people and developers must work together daily throughout the project. 5. Build projects around motivated t individuals. id Give them the environment and support they need, and trust them to get the job done. 6. The most efficient and effective method of conveying information to and within a development team is face to face conversation. SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 10

Agility Principles - II 7. Working software is the primary measure of progress. 8. Agile processes promote sustainable development. The sponsors, developers, and users should be able to maintain a constant pace indefinitely. 9. Continuous attention to technical excellence and good design enhances agility. 10. Simplicity the art of maximizing the amount of work not done is essential. 11. The best architectures, t requirements, and designs emerge from self organizing teams. 12. At regular intervals, the team reflects on how to become more effective, then tunes and adjusts its behavior accordingly. SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 11

Extreme Programming (XP) The most widely used agile process, originally proposed by Kent Beck XP Planning Begins with the creation of user stories Agile team assesses each story and assigns a cost Stories are grouped to for a deliverable increment A commitment is made on delivery date After the first increment project velocity is used to help define subsequent delivery dates for other increments SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 12

Extreme Programming (XP) user st ories values accept ance t est crit eria it erat ion plan simple design CRC cards spike solut ions prot ot ypes refact oring pair programming Release software increment project velocity computed unit t est cont inuous int egrat ion accept ance t est ing SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 13

Extreme Programming (XP) Source: http://www.extremeprogramming.org/ SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 14

Scrum Oi Originally i proposed dby Schwaber and dbeedle Scrum distinguishing features Development work is partitioned into packets Testing and documentation are on-going as the product is constructed Work occurs in sprints and is derived from a backlog of existing requirements Meetings are very short and sometimes conducted without chairs demos are delivered to the customer with the time-box allocated SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 15

Scrum SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 16

Scrum Process Flow Source: http://solutions.daffodilsw.com/scrum-development.html SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 17

Agile Modeling Originally proposed by Scott Ambler Suggests a set of agile modeling principles Model with a purpose Use multiple models Travel light Content is more important than representation Know the models and the tools you use to create them Adapt locally SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 18

Agile Unified Process (AUP) Adopts a serial in the large and iterative in the small philosophy p for building computer- based systems. UP phased activities inception, elaboration, construction, and transition. Iterates to achieve agility and to deliver meaningful software increments as rapidly as possible. SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 19

And many more Dynamic Systems Development Method (www.dsdm.org) Crystal/ASD Feature Driven Development Win-Win Spiral XBreed Lean Development SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 20

Principles that Guide Practice Principle #1. Divide and conquer. Stated in a more technical manner, analysis and design should always emphasize separation of concerns (SoC). Principle #2. Understand the use of abstraction. At it core, an abstraction is a simplification of some complex element of a system used to communication meaning in a single phrase. Principle #3. Strive for consistency. A familiar context makes software easier to use. Principle #4. Focus on the transfer of information. Pay special attention to the analysis, design, construction, and testing of interfaces. SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 21

Principles that Guide Practice Pi Principle i #5. Build software that t exhibits effective modularity. Separation of concerns (Principle #1) establishes a philosophy for software. Modularity provides a mechanism for realizing the philosophy. Principle #6. Look for patterns. Brad Appleton [App00] suggests that: The goal of patterns within the software community is to create a body of literature to help software developers resolve recurring problems encountered throughout all of software development. Principle #7. When possible, represent the problem and its solution from a number of different perspectives. Principle #8. Remember that someone will maintain the software. SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 22

Communication Principles Pi Principle i #1. Listen. Try to focus on the speaker s words, rather than formulating your response to those words. Principle # 2. Prepare before you communicate. Spend the time to understand the problem before you meet with others. Principle # 3. Someone should facilitate the activity. Every communication meeting should have a leader (a facilitator) to keep the conversation moving in a productive direction; (2) to mediate any conflict that does occur, and (3) to ensure than other principles are followed. Principle #4. Face-to-face communication is best. But it usually works better when some other representation of the relevant information is present. SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 23

Communication Principles Pi Principle i #5. Take notes and document decisions. i Someone participating i in the communication should serve as a recorder and write down all important points and decisions. Principle # 6. Strive for collaboration. Collaboration and consensus occur when the collective knowledge of members of the team is combined Principle # 7. Stay focused, modularize your discussion. The more people involved in any communication, the more likely l that t discussion i will bounce from one topic to the next. Principle # 8. If something is unclear, draw a picture. Principle # 9. (a) Once you agree to something, move on; (b) If you can t agree to something, move on; (c) If a feature or function is unclear and cannot be clarified at the moment, move on. Principle # 10. Negotiation is not a contest or a game. It works best when both parties win. SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 24

Planning Principles Pi Principle i #1. Understand d the scope of the project. It s impossible ibl to use a roadmap if you don t know where you re going. Scope provides the software team with a destination. Pi Principle i #2. Involve the customer in the planning activity. it The customer defines priorities and establishes project constraints. Principle #3. Recognize that planning is iterative. A project plan is never engraved in stone. As work begins, it very likely l that t things will change. Principle #4. Estimate based on what you know. The intent of estimation is to provide an indication of effort, cost, and task duration, based on the team s current understanding of the work to be done. Principle #5. Consider risk as you define the plan. If you have identified d risks that t have high h impact and high h probability, bilit contingency planning is necessary. SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 25

Planning Principles Principle #6. Be realistic. People don t work 100 percent of every day. Principle #7. Adjust granularity as you define the plan. Granularity refers to the level of detail that is introduced as a project plan is developed. Principle #8. Define how you intend to ensure quality. The plan should identify how the software team intends to ensure quality. Principle #9. Describe how you intend to accommodate change. Even the best planning can be obviated by uncontrolled change. Principle #10. Track the plan frequently and make adjustments as required. Software projects fall behind schedule one day at a time. SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 26

Modeling Principles In software engineering work, two classes of models can be created: Requirements models (also called analysis models) represent the customer requirements by depicting the software in three different domains: the information domain, the functional domain, and the behavioral domain. Design models represent characteristics of the software that help practitioners to construct it effectively: the architecture, the user interface, and component-level detail. SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 27

Construction Principles The construction activity encompasses a set of coding and testing tasks that lead to operational software that is ready for delivery to the customer or end-user. Coding principles and concepts are closely aligned programming style, programming languages, and programming methods. Testing principles and concepts lead to the design of tests that systematically uncover different classes of errors and to do so with a minimum amount of time and effort. SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 28

Preparation Principles Before you write one line of code, be sure you: Understand of the problem you re trying to solve. Understand d basic design principles i and concepts. Pick a programming language that meets the needs of the software to be built and the environment in which it will operate. Select a programming environment that provides tools that will make your work easier. Create a set of unit tests t that t will be applied once the component you code is completed. SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 29

Summary Be agile to accommodate the needs of modern business. Every software engineering project is different. A generic principles apply to the process as a whole regardless of the project or the product. SCCS365 Information Systems Analysis and Design - ICT@MU 2009/2 30