NCCU CS碩專班 軟體工程專題 Lecture 10 May 10, 2012 © 2004 EVOLUTION.

Slides:



Advertisements
Similar presentations
Configuration management
Advertisements

Configuration management
Computer Engineering 203 R Smith Project Tracking 12/ Project Tracking Why do we want to track a project? What is the projects MOV? – Why is tracking.
1 In-Process Metrics for Software Testing Kan Ch 10 Steve Chenoweth, RHIT Left – In materials testing, the goal always is to break it! That’s how you know.
Software Delivery. Software Delivery Management  Managing Requirements and Changes  Managing Resources  Managing Configuration  Managing Defects 
Defect Tracking CSC444F'07 Lecture 8.
Computer Engineering 203 R Smith Requirements Management 6/ Requirements IEEE Standard Glossary A condition or capability needed by a user to solve.
SE 555 Software Requirements & Specification Requirements Management.
Database Design Concepts Info 1408 Lecture 2 An Introduction to Data Storage.
Database Design Concepts Info 1408 Lecture 2 An Introduction to Data Storage.
SE 501 Software Development Processes
Applied Software Project Management Andrew Stellman & Jennifer Greene Applied Software Project Management greene.com 1 Applied Software.
Module CC3002 Post Implementation Issues Lecture for Week 6 AY 2013 Spring.
© 2012 IBM Corporation Rational Insight | Back to Basis Series Work on a Defect from QA Liu Xue Ning.
Tracking The Problem  By Aaron Jackson. What’s a Problem?  A suspicious or unwanted behavior in a program  Not all problems are errors as some perceived.
Error reports as a source for SPI Tor Stålhane Jingyue Li, Jan M.N. Kristiansen IDI / NTNU.
Configuration Management (CM)
Using error reports in SPI Tor Stålhane IDI / NTNU.
LOGO Team Assignment 1 Software Architectures. LOGO K15T2- Group21 Contents Introduce to Sale system 1 Architecture Drivers 2 Minimal Acceptable Delivery.
Managing Change 1. Why Do Requirements Change?  External Factors – those change agents over which the project team has little or no control.  Internal.
Configuration Management and Change Control Change is inevitable! So it has to be planned for and managed.
CSC444F'06Lecture 101 Feature Tracking. CSC444F'06Lecture 102 Feature Tracking Keeping track of all the features that have been requested. Keeping track.
CSC444F'07Lecture 41 CSC444 Software Engineering Top 10 Practices.
Testing under the Agile Method CSCI 521 Software Project Management based on the book Testing Extreme Programming by Lisa Crispin and Tip House.
© 2012 IBM Corporation Rational Insight | Back to Basis Series Working on Enhancement/Defect Nick Hu Shuai 2012/05/17.
Applied Software Project Management SOFTWARE TESTING Applied Software Project Management 1.
Introduction to CAST Technical Support
Peter Varhol Solutions Evangelist
Configuration Management
Metrics That Matter Real Measures to Improve Software Development
Applied Software Testing
Software Configuration Management
Software Project Configuration Management
Essentials of UrbanCode Deploy v6.1 QQ147
Causal Analysis & Resolution (CAR) Support Category
Tracking and Squashing Bugs
Quality Assurance Week 5 Winter quarter 02/04/02 SOS
Approaches to ---Testing Software
Chapter 11: Software Configuration Management
Agile Scrum Management
SEVERITY & PRIORITY RELATIONSHIP
Chapter 18 Maintaining Information Systems
Software testing
Quality Assurance: Early Work Items
Configuration Management
Etrics XP Metrics.
12 Steps to Useful Software Metrics
Defect Tracking CSC444F'05 Lecture 9.
Taking an Iteration Down to Code
Applied Software Implementation & Testing
Operational and Postimplementation
QuickBooks Pro Errors And Their Solutions QuickBooks Pro is an excellent accounting software for those who use Windows computers to manage and run their.
Why Technology Startups Should Not Ignore Software Testing.
Teaching slides Chapter 1.
Introduction to CAST Technical Support
© University of Liverpool
Testing and Test-Driven Development CSC 4700 Software Engineering
CS240: Advanced Programming Concepts
Chapter 11: Software Configuration Management
Orange ASP Training Module
Notice! This file is a ‘disabled’ file. It is not complete. Slides have been left out and other info is lacking. I have posted this file for general information.
CS5123 Software Validation and Quality Assurance
Project Name - Testing Iteration 1 UAT Kick-off
Product released! Software Released! Now what?.
Feature Tracking CSC444F'07 Lecture 9.
Test Cases, Test Suites and Test Case management systems
Better Bug Workflow System
Proposal on TSC policy for ONAP release Maintenance
Chapter 12: Software Support and Maintenance
Introduction to Software Testing
Presentation transcript:

NCCU CS碩專班 軟體工程專題 Lecture 10 May 10, 2012 © 2004 EVOLUTION

Defect Tracking Slides by Prof. David A. Penny CSC444F'07 Lecture 8

Defect Tracking Keeping track of all the defects that have been discovered Keeping track of all the steps required to validate, correct, and take preventative action for a defect Necessary because to not lose any reported defects to co-ordinate defect resolution to ensure coders don’t work on non-defects Features masquerading as defects Wasting time fixing something that isn’t broken Wasting time chasing down a badly reported defect to control defect correction activity ensure the right defects are being worked on In practice: A database of defect records A workflow driven by the state and owner fields. CSC444F'07 Lecture 8

Aside on “Bugs” Why not call defects “bugs”? First used because a moth flew into a vacuum-tube computer and ate away at the wires. “bugs” are things that happen to you, outside of your control A “defect” is something that is caused by a coder making a correctable mistake. Gets you into the right mindset CSC444F'07 Lecture 8

Defect Information Where Found Who Found It Description of the Defect product, release, version, hardware, os, drivers, general area Who Found It customer, internal, when Description of the Defect summary, description, how to reproduce, associated data links to related defects or features Triage severity, likelihood → priority Audit Trail all changes to the defect data, by whom, when State state, owner CSC444F'07 Lecture 8

Priority Matrix Likelihood Severity Low Medium High Severity Crash, bad data 2 1 Work around 5 3 Cosmetic 4 Submitter of defect chooses severity and likelihood May later correct if determined to be an exaggeration or in error System assigns a priority according to the priority matrix Humans may change the priority using their judgment No need to stick to “the matrix”, which is after all too simple to account for every contingency CSC444F'07 Lecture 8

Defect Workflow issue customer QA WIP Valid Fixed Closed New Disputed CSC444F'07 Lecture 8

Coder Assignment Matrix Defect is auto-assigned to a coder based upon The product in which it was found The functional area of the defect Catch-all category (misc.) goes to a team lead charged with defect assignment and overview for assignment elsewhere. Keeps track of the defect load by priority on all coders Balanced the load Chips in where needed Developers may move the defect to the appropriate coder without management permission. May also move to team lead for re-assignment Natural corollary to auto-assignment. CSC444F'07 Lecture 8

Management Controls One of main purposes is to provide defect visibility to enable management to ensure defects are appropriately prioritized. Management must: overview all active defect records ensure priorities are good if languishing too long in a given state, act ensure coders are working on defects of appropriate priority at any given time System Support Most systems can be configured to send e-mail and/or re-assign to manager when certain conditional action thresholds are reached E.g., prio 1 defect with state unchanged for 24 hrs. Post daily reports of overdue defects CSC444F'07 Lecture 8

Metrics Another purpose for defect tracking is to enable gathering of good, clean defect arrival/departure data. Gives insight into productivity of coders fixing defects testers finding defects Clean data is essential e.g., if no way to validate defects lots of arrivals may be due to bad code or to bad defect triage may expend a lot of effort on coding initiatives and numbers will go the wrong way! Must quickly get defects out of New and Fixed. Arrivals: defects per day entering into Valid Departures: defects per day going from Fixed to Closed Total: sum of defects in states Valid, WIP, and Fixed. CSC444F'07 Lecture 8

Metrics arrivals departures HURRY! HURRY! HURRY! WIP Valid Fixed Closed New Disputed CSC444F'07 Lecture 8

Metrics Example -20 20 40 60 80 100 1 3 5 7 9 11 13 15 17 19 21 23 25 days defects total arrivals departures net CSC444F'07 Lecture 8

Towards GA These metrics should be tracked: by product by priority Company should establish shipping thresholds e.g., no known priority 1 or 2 defects arrival rate for priority 1-3 < 1 defect per day Watch trends, compare to last release. If bad: “bug Olympics” “bug blitz weekends” slip date clean up the architecture CSC444F'07 Lecture 8

Relationship to SCCS Two reasons for changes to source: fix a defect add a feature Can tie SCCS and defect/feature tracking systems to control this Whenever a coder checks in a change Prompted for: defect or feature # check to ensure assigned to them persistently stored This allows management to see what was changed why it was changed by whom how much of a change Is this really control? yes: audit trail CSC444F'07 Lecture 8

Depot Change Report David Kathleen Douglas Brian D100203 23 F100350 Date Range: Last 24 hours David Kathleen Douglas Brian D100203 23 F100350 108 34 D155401 56 D100343 10 D100453 1 F100782 508 Totals: 24 598 CSC444F'07 Lecture 8

Defect Attribution Beginning to understand what are the systemic root causes of defects. Include as data in the defect tracking system that must be there before defect is closed Should record time taken to deal with it, or at least a “difficulty” field (high, medium, low) Attribute to: where in the source code can identify modules whose re-design will add most bang-for-the-buck which developer introduced it organizationally tricky but very useful during what phase spec, design, code CSC444F'07 Lecture 8

Customer Issue Tracking Distinct from defect tracking Customers have many issues: how to use software installation issues perceived problems problems that have already been resolved in a previous patch known issues ship me a manual, please … Some of these issues will result in new defects Requirements of issue tracking systems will include: customer relationship management tie-in searchable knowledge bases customer tracking of issue progress CSC444F'07 Lecture 8

Shipping Known Defects 0-defects is not a sustainable software business how many defects are acceptable? how many are you shipping? Defect seeding inject defects, see how many are found, use the ratio hard to work this in practice Must measure customer satisfaction with perceived level of defects and correlate to known defects at ship. e.g., If we ship with 350 known defects and customers are down on the release then it’s too high If we ship with 50 and customers say “best release ever” super stable, then it’s good. Might want to use 50 as the shipping threshold, and then gradually lower that over time CSC444F'07 Lecture 8

Testing/Coding Effort Changes Can only compare across releases if have a consistent testing effort same number of testers, same productivity, same time, same general size of the release If increase size of testing team relative to coding team, ratio of known to unknown defects decreases Assume ratio is 50% ship with 50 known, actually shipping 100 defects Add testers, raising ratio to 75% ship with 75 known, actually shipping 100 defects good to know. If increasing testing effort without increasing coding efforts, will be hard-pressed to meet the old thresholds Add coders, lowering ratio to 25% ship with 25 known, actually shipping 100 defects Add coders and testers ratios stay the same but will reach the thresholds faster for the same sized effort CSC444F'07 Lecture 8

Release Notes When shipping point releases, good to say which defects are fixed hard to get this info! Start with sccs and defect tracking to see which defect corrections have been checked in since the last point release Must describe the defect in terms the users will understand e.g., load this data file it crashes good enough to find and fix the defect not good enough for release notes must track down the root cause, and extrapolate into what kind of situations will trigger the defect. If doing this, must make it a part of the defect correction process CSC444F'07 Lecture 8