M Global Software Group 1 Motorola Internal Use Only Better Software Quality at a Lower Cost: Testing to Eliminate Software Black Holes Isaac (Haim) Levendel,

Slides:



Advertisements
Similar presentations
QuEdge Testing Process Delivering Global Solutions.
Advertisements

Lecture 8: Testing, Verification and Validation
1 Integration Testing CS 4311 I. Burnstein. Practical Software Testing, Springer-Verlag, 2003.
Automated Software Testing: Test Execution and Review Amritha Muralidharan (axm16u)
T. E. Potok - University of Tennessee Software Engineering Dr. Thomas E. Potok Adjunct Professor UT Research Staff Member ORNL.
ITIL: Service Transition
Copyright © 2003 Software Quality Research Laboratory Software Production Essentials Seeing Past the Buzz Words.
Documentation Testing
Unit 231 Software Engineering Introduction to SWE What is SDLC Phases of SDLC.
SE 555 Software Requirements & Specification Beyond Requirements Based on Weigers Chapter17.
Illinois Institute of Technology
(c) 2007 Mauro Pezzè & Michal Young Ch 1, slide 1 Software Test and Analysis in a Nutshell.
CSE Senior Design II Test Planning Mike O’Dell Based on an earlier presentation by Mike O’Dell, UTA.
Software Testing and QA Theory and Practice (Chapter 16: Test Team Organization) © Naik & Tripathy 1 Software Testing and Quality Assurance Theory and.
12 Steps to Useful Software Metrics
BY RAJESWARI S SOFTWARE TESTING. INTRODUCTION Software testing is the process of testing the software product. Effective software testing will contribute.
What is Business Analysis Planning & Monitoring?
Effective Methods for Software and Systems Integration
ECE 355: Software Engineering
Software Testing. Recap Software testing – Why do we do testing? – When it is done? – Who does it? Software testing process / phases in software testing.
Introduction to RUP Spring Sharif Univ. of Tech.2 Outlines What is RUP? RUP Phases –Inception –Elaboration –Construction –Transition.
Dr Andy Brooks1 FOR0383 Software Quality Assurance Lecture 1 Introduction Forkröfur/prerequisite: FOR0283 Programming II Website:
University of Palestine software engineering department Testing of Software Systems Fundamentals of testing instructor: Tasneem Darwish.
1 Software Testing and Quality Assurance Theory and Practice Chapter 16 Test Team Organization.
CompSci 230 Software Design and Construction
CPIS 357 Software Quality & Testing
CS 360 Lecture 3.  The software process is a structured set of activities required to develop a software system.  Fundamental Assumption:  Good software.
Chapter 3: Software Maintenance Process Omar Meqdadi SE 3860 Lecture 3 Department of Computer Science and Software Engineering University of Wisconsin-Platteville.
ELN5622 Embedded Systems Class 10 Spring, 2003 Aaron Itskovich
SOFTWARE TESTING Scope of Testing  The dynamic Indian IT industry has always lured the brightest minds with challenging career.
CPSC 2150 August 21, Chapter 1 Object Oriented Software Development This is an introductory course In this chapter we will look at 3 topics Challenges.
Object-Oriented Software Engineering Practical Software Development using UML and Java Chapter 1: Software and Software Engineering.
Software Measurement & Metrics
Testing Workflow In the Unified Process and Agile/Scrum processes.
1 Chapter 22 Developer Testing. 2 introduction Testing is the most popular quality-improvement activity Testing is the most popular quality-improvement.
Chapter 13: Regression Testing Omar Meqdadi SE 3860 Lecture 13 Department of Computer Science and Software Engineering University of Wisconsin-Platteville.
Software Product Line Material based on slides and chapter by Linda M. Northrop, SEI.
CSCI 521 Final Exam Review. Why Establish a Standard Process? It is nearly impossible to have a high quality product without a high quality process. Standard.
Software Maintenance Speaker: Jerry Gao Ph.D. San Jose State University URL: Sept., 2001.
MNP1163 (Software Construction).  SDLC and Construction Models  Construction Planning  Construction Measurement.
CSE 303 – Software Design and Architecture
Dr. DEVENDRA TAYAL– THE SCOPE OF SOFTWARE ENGINEERING.
Chapter 8 Testing. Principles of Object-Oriented Testing Å Object-oriented systems are built out of two or more interrelated objects Å Determining the.
Rational Unified Process (RUP)
Advanced Software Engineering Lecture 4: Process & Project Metrics.
Thomas L. Gilchrist Testing Basics Set 3: Testing Strategies By Tom Gilchrist Jan 2009.
Software Quality Assurance and Testing Fazal Rehman Shamil.
1 SYS366 Week 1 - Lecture 1 Introduction to Systems.
Software Development Process CS 360 Lecture 3. Software Process The software process is a structured set of activities required to develop a software.
C++ for Engineers and Scientists, Second Edition 1 Problem Solution and Software Development Software development procedure: method for solving problems.
Chapter 8: Maintenance and Software Evolution Ronald J. Leach Copyright Ronald J. Leach, 1997, 2009, 2014,
© Chinese University, CSE Dept. Software Engineering / Software Engineering Topic 1: Software Engineering: A Preview Your Name: ____________________.
Testing Integral part of the software development process.
Information Systems Development
ITIL: Service Transition
Progile Automated Verification Engineer • PAVE •
Software Engineering (CSI 321)
Integration Testing.
Manfred Huber Based on an earlier presentation by Mike O’Dell, UTA
E2E Testing in Agile – A Necessary Evil
Applied Software Implementation & Testing
Some Important Techniques For Regression Testing That You Must Know.
Information Systems Development
Software engineering -1
Chapter 11: Integration- and System Testing
Software Development Chapter 1.
Chapter 11: Integration and System Testing
Requirements Engineering
CS410 – Software Engineering Lecture #11: Testing II
Presented by KARRI GOVINDA RAO ,
Presentation transcript:

M Global Software Group 1 Motorola Internal Use Only Better Software Quality at a Lower Cost: Testing to Eliminate Software Black Holes Isaac (Haim) Levendel, Director Systems Engineering Technology Center, Global Software Group

M 2 Motorola Internal Use Only Central theme Process to accelerate software quality improvement by maximizing the impact of software testing, given: –a limited testing budget –limited time We generally cannot afford full testing coverage How do we manage risk?

M Global Software Group 3 Motorola Internal Use Only Traditional theory of software reliability: bugs are homogeneously distributed

M Global Software Group 4 Motorola Internal Use Only Implications of the traditional theory of software reliability 1.Development data can be used to predict field readiness that’s good! But is the prediction correct? 2.Full coverage testing is necessary to improve the software that’s bad!

M Global Software Group 5 Motorola Internal Use Only Humans deal with complexity in an iterative way We use successive approximation methods The lack of complete understanding of the correct design space is the root cause of most software errors –These errors happen at all phases of the software manufacturing process At every point in time, a SW black hole is –An incomplete/incorrect area of the software

M Global Software Group 6 Motorola Internal Use Only Levendel’s Axiom “Bugs Abhor Loneliness” (They create software black holes)

M Global Software Group 7 Motorola Internal Use Only Implications of the black hole theory of software reliability 1.Development data can be used to predict field readiness that’s good! But is the prediction correct? 2.Full coverage testing is necessary to improve the software that’s bad!

M Global Software Group 8 Motorola Internal Use Only Disintegration of software black holes (4) Software black hole (1) (2) (3) (5) Acceptable?

M Global Software Group 9 Motorola Internal Use Only At the end of the process: the SW product variance has been reduced

M Global Software Group 10 Motorola Internal Use Only The software crafting phases Requirements Design Coding Unit Design Integration “Make believe” Requirements Design Coding Unit Design Integration Reality

M Global Software Group 11 Motorola Internal Use Only Requirements Design Software black holes are left behind anywhere in the crafting process Coding Unit Design Integration Each phase leaves SW black holes

M Global Software Group 12 Motorola Internal Use Only The black hole theory of software Supporting data and experience

M Global Software Group 13 Motorola Internal Use Only Software modules affected by changes for new features (Subsystem #1)

M Global Software Group 14 Motorola Internal Use Only Software modules affected by changes for new features (Subsystem #2)

M Global Software Group 15 Motorola Internal Use Only Number of new and modified lines of source code for each internal release (total of 34 internal releases)

M Global Software Group 16 Motorola Internal Use Only Number of software modules changed per fix for each internal release (total of 34 internal releases)

M Global Software Group 17 Motorola Internal Use Only Number of lines of software changed per fix for each internal release (total of 34 internal releases)

M Global Software Group 18 Motorola Internal Use Only Software field products will always have bugs Cost Per Bug Fix Reproducibility (1/MTBF) Time

M Global Software Group 19 Motorola Internal Use Only Identifying black holes

M Global Software Group 20 Motorola Internal Use Only Role of testing: help to identify black hole (4) Software black hole (1) (2) (3) (5) Acceptable?

M Global Software Group 21 Motorola Internal Use Only Advancing the release time by repairing a software black hole in one step B’ A = A black hole is found B = Field delivery Number of Tests t (or time elapsed) Cumulative No. of Failures ,000 2,000 3,000 4,000 5,000 O Climb to a “better” curve = The black hole is fixed O’ A’

M Global Software Group 22 Motorola Internal Use Only Testing to improve product quality Home on SW Black Hole Explore SW Black Hole Repair SW Black Hole (redesign SW module) Stop More SW black holes? Yes No Find bug Fix bug Execute test Retest fix Stop More Tests? Yes No

M Global Software Group 23 Motorola Internal Use Only How do we position the initial testing on software black holes? Desirable initial tests Not worth testing

M Global Software Group 24 Motorola Internal Use Only Information sources for guiding the testing toward potential software black holes Proc. Phase Info Info type Past releases Planning of current release Design/coding of current release Testing of current release Field data  Laboratory problems  SW change information  SW planning problems  TIME

M Global Software Group 25 Motorola Internal Use Only Correlation between trouble reports and fixes helps identify problem-prone software modules Trouble report 1 SW Module 1 Fix 1b Fix 1a SW Module 2 SW Module 3 SW Module 4 Trouble report 2 Fix 2a

M Global Software Group 26 Motorola Internal Use Only Code changes and new code may affect problem-prone software modules Code change request 1 SW Module 1 Change 1 SW Module 2 SW Module 3 SW Module 4 Code change request 2 Change 2

M Global Software Group 27 Motorola Internal Use Only White box testing leads to higher fail rate Trouble report 1 SW Module 1 Fix 1b Fix 1a SW Module 2 SW Module 3 SW Module 4 Trouble report 2 Fix 2a Test x fails Test y passes Test z fails

M Global Software Group 28 Motorola Internal Use Only Test program alerts Test programs cannot be fully designed one year ahead of time!!! –because one does not know in advance all the places where the functionality is going to break They must be adaptive!!! –Need to combine upfront planning with adaptive execution This includes regression tests

M Global Software Group 29 Motorola Internal Use Only Practical Testing Question Black Box Testing or White Box Testing?

M Global Software Group 30 Motorola Internal Use Only Practical Testing Question Black Box Testing or White Box Testing? Both!! Why? Black box testing reflects requirements White box testing reflects software black holes

M Global Software Group 31 Motorola Internal Use Only Who would want to test like that?

M Global Software Group 32 Motorola Internal Use Only 4 weeks of testing data

M Global Software Group 33 Motorola Internal Use Only Test program architecture & Test program metrics

M Global Software Group 34 Motorola Internal Use Only Managing complexity Complexity can be managed by decomposing large systems into a tree-like hierarchy of functions The depth and levels of the decomposition are arbitrary Functional Area Functional Package Functional Subset Functional Functional Functional Component Component Component

M Global Software Group 35 Motorola Internal Use Only How a test suite traverses functional components Test 1 Test 2 Component 1 Component 2 Component 3 Component 4 Component 5 Component 6

M Global Software Group 36 Motorola Internal Use Only Two key issues with components 1.The SW architecture is a good starting point for a decomposition into functional components 2.It is essential to characterize the mapping between test suites and functional components

M Global Software Group 37 Motorola Internal Use Only Implementing test programs: the combinatorial explosion problem Functional Area Functional Package Functional Subset Functional Component Functional Package Functional Subset Functional Component Functional Component Underlying Functional structure Unmanageable size of test program + Feature interactions

M Global Software Group 38 Motorola Internal Use Only Filtering test program scope to reduce cost Functional Area Functional Package Functional Subset Functional Component Functional Package Functional Subset Functional Component Functional Component Customer rollout plan Suspected vulnerabilities Underlying Functional structure Manageable Test program

M Global Software Group 39 Motorola Internal Use Only Collect failures on tests ( ) and components ( ) Test 1 Test 2 Component 1 Component 2 Component 3 Component 4 Component 5 Component 6

M Global Software Group 40 Motorola Internal Use Only Fail rates for typical project’s components Likely software black holes

M Global Software Group 41 Motorola Internal Use Only Create time and space repetitions FS 2 FS 3 FS n FS 1 FS 2 FS 3 FS n FS 1 FS 2 FS 3 FS n FS 1 FS 2 FS 3 FS n FS 1 Evaluation Evaluation Period 1 Period 2 Period 3 Period 4   Comparisons Time repetition Space repetition

M Global Software Group 42 Motorola Internal Use Only A reporting mechanism to motivate repairs of software black holes It is more economical to climb the quality curve in steps The reporting should motivate these step functions The solution: –Drive the testing to identify software black holes –Orient the test reporting to point at software black holes & recommend solutions

M Global Software Group 43 Motorola Internal Use Only Log the learning 1.The exercise of human judgment is indispensable 2.Data per se has NO meaning

M Global Software Group 44 Motorola Internal Use Only The key common sense question about testing in general Common Sense is not so common - Voltaire ( ) How does one measure testing productivity? –In number of tests executed per $? or –In number of test failed per $?

M Global Software Group 45 Motorola Internal Use Only The key common sense question about testing in general Common Sense is not so common - Voltaire ( ) How does one measure testing productivity? –In number of tests executed per $? or –In number of test failed per $ !

M Global Software Group 46 Motorola Internal Use Only (Dire) Conclusion If one accepts the software black hole hypothesis, then: the current reliability and availability technologies need to be rethought