The i-Technology Media!
Register | Log in
   
 
.NET  ·  AJAX  ·  CLOUD  ·  ECLIPSE  ·  FLEX  ·  OPEN WEB  ·  iPHONE  ·  JAVA  ·  LINUX  ·  OPEN SOURCE  ·  ORACLE  ·  PBDJ  ·  SEARCH  ·  SILVERLIGHT  ·  SOA  ·  VIRTUALIZATION  ·  WEB 2.0  ·  WIRELESS  ·  XML
Comments
Drool, Britannia? Is the UK Failing the Cloud?
By Roger Strukhoff
Richard Davies wrote: The UK has a good crop of technology pioneers in cloud computing - for example ElasticHosts, FlexiScale, Flexiant, OnApp - and also some strong government initiatives such as G-Cloud. We will have to see whether this kind of technical leadership converts into swift mass-market adoption or not.
Jan. 8, 2012 11:38 AM EST
read more & respond »
Cloud Expo on Google News
Did you read today's front page stories & breaking news?

Cloud Expo & Virtualization 2011 West
Keynotes
Oracle
Opening Keynote | An Enterprise Cloud for Business-Critical Applications
Abiquo
Day 2 Keynote | The Enterprise Cloud Tightrope - Balancing for Success
Akamai
Day 3 Keynote | The DNA of an Enterprise Cloud
DIAMOND SPONSOR:
Oracle
Many Clouds, Many Choices'Cloud
PLATINUM PLUS SPONSORS:
Abiquo
Enterprise Cloud Best Practices - Town Hall - Join the discussion…
PLATINUM SPONSORS:
Intel
Progressing Toward the Federated, Automated and Client-Aware Cloud
New Relic
How to build an app with Twitter-like throughput
Rackspace
Computing in the Cloud Era
GOLD SPONSORS:
Gale Technologies
Practical Cloud Migration
IBM
Re-think IT. Re-inventing Business.
Intel/McAfee
Identity Driven Security in the Cloud
PerspecSys
Hackers Hackers Everywhere, Is My Public Cloud That Safe?
Red Hat
Unlock the Value of the Cloud
SHI
Mission Critical Applications and the Cloud - Myth or Reality?
SoftLayer
Not Your Grandpa's Cloud
Terremark
Integrating Enterprise Clouds
VMware
Upgrade to a vCloud
POWER PANELS:
Cloud Expo Silicon Valley: CTO Power Panel
Cloud Expo Silicon Valley: CEO Power Panel
Cloud Expo Silicon Valley: Cloud SuperStars Panel
Cloud Expo Silicon Valley: CloudNOW Panel
Click For 2010 West
Event Webcasts
Cloud Expo & Virtualization 2011 East
DIAMOND SPONSOR:
Dell
Dell & VMware Deliver the Enterprise Hybrid Cloud
PLATINUM PLUS SPONSORS:
Abiquo
Are Financial Services Organizations Risking Security by Avoiding Cloud Computing?
Oracle
From Consolidation to Enterprise Private PaaS
PLATINUM SPONSORS:
Intel
Driving the Transformation to Next Generation Cloud Data Centers
Rackspace
The Inevitability of an Open Cloud
GOLD SPONSORS:
CA Technologies
Follow YOUR path to Cloud Computing
Interxion
Who Keeps the Cloud in the Air?
Microsoft
Patterns for Cloud Computing
PerspecSys
War in the Clouds: Are you ready?
ServiceMesh
The Big Win: Stop Playing Small-Ball with Your Cloud Strategy
Terremark
Evaluating Enterprise Clouds
Xiotech
Cloud Storage: Myths and Realities
POWER PANELS:
Cloud Expo New York: CTO Power Panel
Cloud Expo New York: CEO Power Panel
Cloud Expo New York: CMO Power Panel
Cloud Expo New York: Wrap-Up Power Panel
Click For 2010 West
Event Webcasts
Live Google News by SYS-CON!
Top Three Links You Must Click On


Development
Establishing an Infrastructure for Productive Development
Countermeasures to development waste

By: Sergei Sokolov
Sep. 23, 2007 12:30 PM
  • 1
  • 2
  • next ›
  • last »

Software development is an inherently creative process. Many developers compare it to art, and - like artists - take great pride in their work. However, creative processes are typically not efficient. The software development process is no exception, as the quote below clearly indicates.

Given that software development is a business, many software development managers and team leads want to make it more productive and predictable. Yet, they worry that such efforts will frustrate developers and impact the creativity that is vital for successful software projects.

Fortunately, efficiency and creativity can peacefully co-exist in the software development process. When the more mundane aspects of development are automated, developers can focus on the creative tasks they enjoy most…and still deliver better software in less time. This article explains how five industry-standard practices reduce the amount of avoidable waste in the software development process, enabling developers to satisfy business goals without compromising their craft.

Fewer Bugs or Shorter Schedules?
Surprisingly, the fastest schedule is actually one with a very high defect removal rate. Consider Figure 1, which is taken from Capers Jones' Applied Software Measurement: Assuring Productivity and Quality, 2nd edition (McGraw-Hill, 1996).

This graph, which is based on industry statistics, shows the relationship between total development time and the percentage of defects removed before a software release. As you can see, the development time steadily declines until the 95% defect removal rate is reached then it spikes as the percentage of defects removed approaches 100%.

These findings show that - contrary to popular belief - delivering better-quality software doesn't necessarily take more time than lower-quality software (i.e., software with more defects). Rather, the optimum schedule is attained with a pre-release defect removal rate of 95%, which is quite high in terms of software quality. This development point results in both the shortest schedule and a very low percentage of defects. Removing more defects will likely improve perceived quality, but dramatically increase development time.

Two key points to take away from these findings are:

  • Defect removal doesn't occur "naturally." It requires the engineering team to proactively adopt appropriate practices and tools.
  • Most organizations are admittedly in the sub-optimal area of this graph. This means they can not only im-prove the quality of delivered code, but also produce the code at a lower cost.


Examples of Waste
The first step in moving towards this optimal development zone is identifying the kind of waste that can and should be avoided. Granted, there's some unavoidable waste inherent in the software development process. For instance, examples of such waste include basic R&D that doesn't get productized, prototyping, and so forth.

The scope of avoidable waste, however, is quite substantial. It can include:

  • A day spent fixing a build break that occurred because someone checked in code without locally compiling it. This happens more often than most managers think.
  • Two weeks spent debugging a missing curly brace. This seems incredible, but can actually occur when the team is looking at functional manifestations of this error and trying to debug the error from that end.
  • Figuring out what the heck this variable g stands for. This is a result of poor naming conventions.
  • Nominal case design and development. This is typically a result of ignoring corner case conditions.

Notice the common thread here: a lot of waste stems from late detection of defects that could have been found much earlier or prevented altogether. This applies to all types of defects - including missing requirements, lack of error checking for unexpected user actions, or structural code problems.

Motivators for Waste Reduction
One benefit of reducing waste is that it allows your team to reach a development point that results in reduced development time and a very low percentage of remaining defects. Thinking back to the "development time versus percentage of defects removed" graph in the earlier section, the organizations that are in the optimal area of their development cycles are those that dramatically reduce their waste by targeting defect removal earlier in the process. Thus, they achieve both higher quality software and lower development costs.

The other tangible benefit of reducing waste is that it improves the professional life of developers. Their job satisfaction typically goes up when they're relieved from having to spend excessive time fixing bugs (unproductive work), and can instead focus on the creative tasks they enjoy the most.

Five Countermeasures to Development Waste
Five cornerstones that have been proven to reduce development waste are:

  • Robust development infrastructure
  • Consistent coding - personal and team practices
  • Consistent peer code review
  • Early testing
  • Automated regression testing

Finally - and most important - reducing waste in a systematic manner also requires a reporting system that enables teams to track qualitative progress towards their goals for all five of the above countermeasures.

The strategies above are explained in the following sections.

1. Robust Development Infrastructure
A robust infrastructure automates repetitive tasks, organizes project activities, tracks project status, and seamlessly collects project data to provide measures necessary for decision making. Most of all, this infrastructure sustains and facilitates the improvement of human-defined processes. 

Figure 2 illustrates the foundation of a robust development infrastructure.

This foundation comprises the following components:

  • Source control system: The source control system provides a central place where the team members can store and access the entire source code base. It gives each developer the freedom and safety to write, modify, and re-factor code on his or her workstation. Having a source code repository is also a prerequisite for regularly scheduled automated builds. All of the files needed for the build should be in the source control system, including build files, scripts, etc. not just the source that is being built.
  • Nightly build system: The automated build system builds an application on a regular basis by automatically executing the required build steps at the scheduled time without any human intervention. Without an automated nightly build, development quickly gets out of control and waste increases. Ideally, builds run nightly. This way, any problems are detected the next day (as opposed to a week or more later). However, the key is running them on any type of regular and frequent basis that suits your needs. Unless regular builds are run in an automated fashion, the probability of producing working software on time drops dramatically.
  • Requirements management system (and/or bug tracking system): This is a repository for storing and tracking defects and issues, as well as the developers' ideas for improving the application. Defects are stored so they can be tracked, analyzed, and ultimately prevented from recurring. The system can also be used for storing feature requests and tracking feature and requirement changes. The end result is a central repository of information related to your software.
  • Regression testing system: A regression system is any tool or combination of tools that can automatically run the core of the existing tests on the entire code base on a regular basis. For example, the regression system may be a script that runs one or more testing or defect prevention technologies in batch mode. Its purpose is to identify when code modifications cause unexpected faults, especially those faults that occur because a developer didn't fully understand the internal code dependencies when modifying or extending code that previously functioned correctly.
  • Other tools: This can include tools for static analysis, code review automation, performance profilers, memory analyzers, coverage analyzers, etc. - whatever automation the team finds reasonable (or can afford) to leverage for productivity.
  • Reporting system: This system should be able to gather data from all these components (source control, nightly build, tests, etc.) and present them in a visual way to enable status and trend analysis.

  • 1
  • 2
  • next ›
  • last »
Published Sep. 23, 2007— Reads 12,168
Copyright © 2007 SYS-CON Media, Inc. — All Rights Reserved.
Syndicated stories and blog feeds, all rights reserved by the author.
About Sergei Sokolov
Sergei Sokolov is a senior member of the Professional Services team at Parasoft, a provider of software development tools that help control and optimize the software development process.

Add Your Feedback

In order to post a comment you need to be registered and logged in.

Register | Sign-in

Reader Feedback: Page 1 of 1

Subscribe to the World's Most Powerful Newsletters
Subscribe to Our Rss Feeds & Get Your SYS-CON News Live!
Click to Add our RSS Feeds to the Service of Your Choice:
Google Reader or Homepage Add to My Yahoo! Subscribe with Bloglines Subscribe in NewsGator Online
myFeedster Add to My AOL Subscribe in Rojo Add 'Hugg' to Newsburst from CNET News.com Kinja Digest View Additional SYS-CON Feeds
Publish Your Article! Please send it to editorial(at)sys-con.com!

Advertise on this site! Contact advertising(at)sys-con.com! 201 802-3021

SYS-CON Featured Whitepapers

ADS BY GOOGLE

Breaking Java News
Market Data Industry Veteran Hubert Holmes Joins Xignite
Next-generation Fuze Meeting Brings Cloud-based Telepresence to iPads
CVEP Adds Local-Publicly Traded Company to List of SBDC Clients
Castlight Health Strengthens Management Team to Capitalize on Growing Demand for Health Care Transparency Solutions
Independent Research Proves ZeroWater Filtration Products Outperform Brita and PUR in Removing Pharmaceuticals from Tap Water
CLS Investments and Meeder Financial Available to Serve as Managed Account Providers on Retirement Products
SurDoc Introduces Secure Document Signing Capability Within the Cloud
Law Firm SmithAmundsen Engages SWC for Managed & Virtual CIO Services
Zenph Sound Innovations Reaches Technology Milestone
Matt Harris to Join Bain Capital Ventures as Managing Director

ADVERTISE   |   MAGAZINE SUBSCRIPTIONS   |   FREE BREAKING-NEWSLETTERS!   |   SYS-CON.TV   |   BLOG-N-PLAY!   |   WEBCAST   |   EDUCATION   |   RESEARCH

.NET Developer's Journal - .NETDJ   |   ColdFusion Developer's Journal - CFDJ   |   Eclipse Developer's Journal - EDJ   |   Enterprise Open Source Magazine - EOS
Open Web Developer's Journal - OPENWEB   |   iPhone Developer's Journal - iPHONE   |   Virtualization - Virtualization   |   Java Developer's Journal - JDJ   |   Linux.SYS-CON.com
PowerBuilder Developer's Journal - PBDJ   |   SEO / SEM Journal - SJ   |   SOAWorld Magazine - SOAWM   |   IT Solutions Guide - ITSG   |   Symbian Developer's Journal - SDJ
WebLogic Developer's Journal - WLDJ   |   WebSphere Journal - WJ   |   Wireless Business & Technology - WBT   |   XML-Journal - XMLJ   |   Internet Video - iTV
Flex Developer's Journal - Flex   |   AJAXWorld Magazine - AWM   |   Silverlight Developer's Journal - SLDJ   |   PHP.SYS-CON.com   |   Web 2.0 Journal - WEB2
Apache   |   CMS   |   CRM   |   HP   |   Oracle Journal   |   Perl   |   Python   |   Red Hat   |   Ruby on Rails   |   SAP   |   SaaS

SYS-CON MEDIA:   ABOUT US   |   CONTACT US   |   COMPANY NEWS   |   CAREERS   |   SITE MAP
SYS-CON EVENTS:   |  AJAXWorld Conference & Expo  |  iPhone Developer Summit  |  Cloud Computing Conference & Expo  |  SOA World Conference & Expo  |  Virtualization Conference & Expo
INTERNATIONAL SITES:   India  |  U.K.  |  Canada  |  Germany  |  France  |  Australia  |  Italy  |  Spain  |  Netherlands  |  Brazil  |  Belgium
 Terms of Use & Our Privacy Statement     About Newsfeeds / Video Feeds
Copyright ©1994-2008 SYS-CON Publications, Inc. All Rights Reserved. All marks are trademarks of SYS-CON Media.
Reproduction in whole or in part in any form or medium without express written permission of SYS-CON Publications, Inc. is prohibited.
 
close this window