Copyright (c) 1994-2001 Cem Kaner. All Rights Reserved. 1 Black Box Software Testing (Professional Seminar) Cem Kaner, J.D., Ph.D. Professor of Computer.

Slides:



Advertisements
Similar presentations
Project management.
Advertisements

Black Box Software Testing Copyright © Cem Kaner & James Bach 1 Black Box Software Testing Spring 2005 Part 4 -- QUALITY COST ANALYSIS by Cem Kaner,
The System and Software Development Process Instructor: Dr. Hany H. Ammar Dept. of Computer Science and Electrical Engineering, WVU.
The CRM Textbook: customer relationship training Terry James © 2006 Chapter 11: Management.
[Title of meeting] [Name of sponsor] [Date] For guidance on working with PowerPoint and reformatting slides, click on Help, then Microsoft PowerPoint Help,
Chapter 10 Schedule Your Schedule. Copyright 2004 by Pearson Education, Inc. Identifying And Scheduling Tasks The schedule from the Software Development.
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.
Degree and Graduation Seminar Scope Management
Applied Software Project Management 1 Introduction Dr. Mengxia Zhu Computer Science Department Southern Illinois University Carbondale.
Pertemuan Matakuliah: A0214/Audit Sistem Informasi Tahun: 2007.
Software Engineering Principles Chapter 3 From Software Engineering by I. Sommerville, Slide 1 project managementorganizing planning scheduling Learning.
Chapter : Software Process
ET Workshop v Opening©2002 Amland Consulting0-1 Exploratory Testing v Workshop in Risk-Based Agile Testing Parts of this class have been.
Copyright (c) Cem Kaner. All Rights Reserved. 1 Black Box Software Testing (Academic Course – Fall 2001) Cem Kaner, J.D., Ph.D. Professor of.
University of Palestine software engineering department Testing of Software Systems Fundamentals of testing instructor: Tasneem Darwish.
Copyright (c) Cem Kaner. All Rights Reserved. 1 Black Box Software Testing (Professional Seminar) Cem Kaner, J.D., Ph.D. Professor of Computer.
Copyright (c) Cem Kaner Black Box Software Testing (Academic Course - Fall 2001) Cem Kaner, J.D., Ph.D. Florida Institute of Technology Section:
CS 360 Lecture 3.  The software process is a structured set of activities required to develop a software system.  Fundamental Assumption:  Good software.
Copyright (c) Cem Kaner. All Rights Reserved. 1 Black Box Software Testing (Professional Seminar) Cem Kaner, J.D., Ph.D. Professor of Computer.
1. 2 IMPORTANCE OF MANAGEMENT Some organizations have begun to ask their contractors to provide only project managers who have been certified as professionals.
Copyright (c) Cem Kaner. All Rights Reserved. 1 Black Box Software Testing (Professional Seminar) Cem Kaner, J.D., Ph.D. Professor of Computer.
Copyright (c) Cem Kaner Black Box Software Testing (Academic Course - Fall 2001) Cem Kaner, J.D., Ph.D. Florida Institute of Technology Section:
Copyright (c) Cem Kaner Black Box Software Testing (Academic Course - Fall 2001) Cem Kaner, J.D., Ph.D. Florida Institute of Technology Section:
Copyright (c) Cem Kaner. All Rights Reserved. 1 Black Box Software Testing (Professional Seminar) Cem Kaner, J.D., Ph.D. Professor of Computer.
COMP 208/214/215/216 Lecture 3 Planning. Planning is the key to a successful project It is doubly important when multiple people are involved Plans are.
1 Chapter 5 Project management. 2 Project management : Is Organizing, planning and scheduling software projects.
Problem Solving Session 1 Introduction. In this session we will be Reviewing the topics that will be covered in this module Discussing expectations Filling.
Project monitoring and Control
Black Box Software Testing Copyright © Cem Kaner & James Bach 1 Black Box Software Testing Fall 2005 Overview—Part 2 (Mission of Testing) Cem Kaner,
Copyright (c) Cem Kaner. All Rights Reserved. 1 Black Box Software Testing (Professional Seminar) Cem Kaner, J.D., Ph.D. Professor of Computer.
Copyright (c) Cem Kaner. All Rights Reserved. 1 Black Box Software Testing (Professional Seminar) Cem Kaner, J.D., Ph.D. Professor of Computer.
Chapter 3 Project Management Chapter 3 Project Management Organising, planning and scheduling software projects.
1 These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by.
IT 499 Bachelor Capstone Week 4. Adgenda Administrative Review UNIT Four UNIT Five Project UNIT Six Preview Project Status Summary.
Copyright (c) Cem Kaner Black Box Software Testing (Academic Course -Fall 2001) Cem Kaner, J.D., Ph.D. Florida Institute of Technology Section:
The System and Software Development Process Instructor: Dr. Hany H. Ammar Dept. of Computer Science and Electrical Engineering, WVU.
The Long Tail Why the future of business is selling less of more ▫ISBN = ▫Chris Anderson Low Distribution and Inventory costs allow companies.
Copyright (c) Cem Kaner Black Box Software Testing (Academic Course - Fall 2001) Cem Kaner, J.D., Ph.D. Florida Institute of Technology Section:
Session # Rational User Conference 2002 Author Note: To edit Session # go to: View/Master/Title Master ©1998, 1999, 2000, 2001, 2002 Rational Software.
Copyright (c) Cem Kaner Black Box Software Testing (Academic Course - Fall 2001) Cem Kaner, J.D., Ph.D. Florida Institute of Technology Section:
1 Project management. 2 Topics covered Management activities Project planning Project scheduling Risk management.
Software Maintenance Speaker: Jerry Gao Ph.D. San Jose State University URL: Sept., 2001.
Copyright (c) Cem Kaner. All Rights Reserved. 1 Black Box Software Testing (Professional Seminar) Cem Kaner, J.D., Ph.D. Professor of Computer.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
Copyright (c) Cem Kaner. All Rights Reserved. 1 Black Box Software Testing (Professional Seminar) Cem Kaner, J.D., Ph.D. Professor of Computer.
Copyright (c) Cem Kaner. All Rights Reserved. 1 Black Box Software Testing (Professional Seminar) Cem Kaner, J.D., Ph.D. Professor of Computer.
Copyright (c) Cem Kaner Black Box Software Testing (Academic Course - Fall 2001) Cem Kaner, J.D., Ph.D. Florida Institute of Technology Section:
Degree and Graduation Seminar Integration Management
Unit – I Presentation. Unit – 1 (Introduction to Software Project management) Definition:-  Software project management is the art and science of planning.
Copyright (c) Cem Kaner. All Rights Reserved. 1 Black Box Software Testing (Professional Seminar) Cem Kaner, J.D., Ph.D. Professor of Computer.
Software Development Process CS 360 Lecture 3. Software Process The software process is a structured set of activities required to develop a software.
Copyright (c) Cem Kaner. All Rights Reserved. 1 Black Box Software Testing (Professional Seminar) Cem Kaner, J.D., Ph.D. Professor of Computer.
Copyright (c) Cem Kaner. All Rights Reserved. 1 Black Box Software Testing (Professional Seminar) Cem Kaner, J.D., Ph.D. Professor of Computer.
Copyright (c) Cem Kaner. All Rights Reserved. 1 Black Box Software Testing (Professional Seminar) Cem Kaner, J.D., Ph.D. Professor of Computer.
Black Box Software Testing (Professional Seminar)
Black Box Software Testing 2004 Academic Edition
Black Box Software Testing (Academic Course - Fall 2001)
Black Box Software Testing (Academic Course - Fall 2001)
Software Project Management
Introducing ISTQB Agile Foundation Extending the ISTQB Program’s Support Further Presented by Rex Black, CTAL Copyright © 2014 ASTQB 1.
How to keep your Enterprise GIS Project on Track
Project Management Process Groups
Black Box Software Testing (Academic Course - Fall 2001)
Black Box Software Testing (Academic Course - Fall 2001)
Black Box Software Testing (Academic Course - Fall 2001)
Black Box Software Testing (Academic Course - Fall 2001)
Black Box Software Testing (Professional Seminar)
Black Box Software Testing (Professional Seminar)
Black Box Software Testing (Professional Seminar)
Black Box Software Testing (Professional Seminar)
Presentation transcript:

Copyright (c) Cem Kaner. All Rights Reserved. 1 Black Box Software Testing (Professional Seminar) Cem Kaner, J.D., Ph.D. Professor of Computer Sciences Florida Institute of Technology Section:33 Project Planning Summer, 2002 Contact Information: (testing website) (legal website) I grant permission to make digital or hard copies of this work for personal or classroom use, with or without fee, provided that (a) copies are not made or distributed for profit or commercial advantage, (b) copies bear this notice and full citation on the first page, and if you distribute the work in portions, the notice and citation must appear on the first page of each portion, (c) each page bear the notice "Copyright (c) Cem Kaner" or if you changed the page, "Adapted from Notes Provided by Cem Kaner". Abstracting with credit is permitted. The proper citation for this work is Cem Kaner, A Course in Black Box Software Testing (Professional Version), Summer-2002, To copy otherwise, to republish or post on servers, or to distribute to lists requires prior specific permission and a fee. Request permission to republish from

Copyright (c) Cem Kaner. All Rights Reserved. 2 Planning and Negotiating the Testing Project The notes here focus on your process of negotiating resources and quality level. Please see Testing Computer Software, Chapter 13 for a detailed discussion of planning and testing tasks across the time line of the project.

Copyright (c) Cem Kaner. All Rights Reserved. 3 Planning the Testing Project Things you can do very early in the project: Analyze any requirements documents for testability, ambiguity. Facilitate inspection and walkthrough meetings. Prepare a preliminary list of hardware configurations and start arranging for loaners. Ask for testing support code, such as debug monitors, memory meters, support for testpoints. Ask for a clear error handling message structure. Discuss the possibility of code coverage measurement (which will require programmer support).

Copyright (c) Cem Kaner. All Rights Reserved. 4 Planning the Testing Project Things you can do very early in the project: Prepare for test automation. This involves reaching agreements in principle on breadth of automation and automation support staffing level. Order automation support equipment. Order external test suites. Learn about the product’s market and competition. Evaluate coding tools that facilitate automation (e.g. test 3rd party custom controls against MS-Test)

Copyright (c) Cem Kaner. All Rights Reserved. 5 Planning the Testing Project: First Principles You can’t nail everything down. You will face difficult prioritization choices, and many constraints will be out of your direct control. You can influence several constraints by opening up your judgments to other stakeholders in the company. This is more than getting a sign-off. Reality is far more important than your ability to cast blame. Your task is to manage project-level risks. This includes risks to the project’s cost, schedule, and interpersonal dynamics, as well as to the product’s feature set and reliability.

Copyright (c) Cem Kaner. All Rights Reserved. 6 Planning the Testing Project: Deciding Your Depth of Testing You have three key objectives: 1Achieve a uniform and well-understood minimum level of testing. 2Be explicit about the level of testing for each area: » mainstream » guerrilla » formally planned » structured regression 3Reach corporate agreement on the level of testing for each area. Just like bug deferrals, depth-of-testing restrictions must rest on sound business decisions.This should not be your decision to make.

Copyright (c) Cem Kaner. All Rights Reserved. 7 Planning the Testing Project: Identify the Tasks Develop a project task list with your staff. Remember, you are looking for realism in estimates of complexity, difficulty, and time. Make the listing and estimation process public, and allow public comment. Identify all potential sources of information. List all main functional areas, and all other cross-functional approaches that you will take in testing the program. List every task that appears to need more than 1/2 day. (Probably you will do this by a group brainstorming session on flipcharts, listing sources on one chart. Gather the sources. List areas and approaches on a few charts. Make one chart for each area of work, and list tasks for each chart. Tentatively assign times to each task, possibly by a museum tour.)

Copyright (c) Cem Kaner. All Rights Reserved. 8 Planning the Testing Project: Estimate the Time 1Assign time estimates to each task. Invite programmers, marketers, and project managers to walk through the charts and provide their own estimates. Explore the bases of differences. You might have underestimated a task’s complexity. Or you might be seeing a priority disagreement. Or wishful thinking. 2Make your best-estimate task list. Provide the time needed to achieve formal, planned testing for each area. Include estimates for structured regression for key areas. This number is probably absurdly huge. 3Add to the list your suggestions for time-cuts to guerrila-level and mainstream-level testing for selected areas. 4Circulate your lists to all stakeholders, call one or more planning meetings, and reach agreements on the level of testing for each area. Keep cutting tasks and/or adding staff until you reach an achievable result.

Copyright (c) Cem Kaner. All Rights Reserved. 9 Planning the Testing Project: Estimate the Time Don’t forget: Budget for meetings and administrative overhead (10-30%). Budget for bug regression (5-15%). Budget for down time. Budget for holidays and vacations. Never develop a budget that relies on overtime. Leave the overtime free for discretionary additional work by the individual tester. Don’t let yourself be bullied or embarrassed, and don’t bully or embarrass your staff, into making underestimates. To achieve a result, insist on cutting tasks, adding staff, or finding realistic ways to improve productivity.

Copyright (c) Cem Kaner. All Rights Reserved. 10 Planning the Testing Project: Identify Dependencies & Milestones You can’t start reviewing the manual until you receive it, right? List these dependencies and point out, in every project meeting, what is due to you that is not yet delivered and holding you up. Try to reach verifiable, realistic definitions for each milestone. For example, if “gamma” is 6 weeks before release, the product can’t have more than 6 weeks of schedule risk at gamma. Negotiate a definition.

Copyright (c) Cem Kaner. All Rights Reserved. 11 Planning the Testing Project: Monitor Progress Put the tasks and agreed-to durations on a timeline and review progress of all staff every week. When prerequisite materials aren’t provided, find other tasks to do instead. When you can’t meet the schedule, due to absent materials, publish new estimates. When design changes invalidate your estimates, publish new estimates. If you’re falling consistently behind (e.g. due to underestimated overhead), publish the problem and ask for fewer tasks, more staff, or some other realistic solution. If one of your staff has trouble with an area, recognize it and deal with it.

Copyright (c) Cem Kaner. All Rights Reserved. 12 Planning the Testing Project: Control Late-Stage Issues Watch out for late changes. Encourage people to be cautious about late bug fixes, and super-cautious about late design changes. Provide interim and final deferred-bug reviews. Take a final inventory of your testing coverage. Carry out final integrity tests. You may have to assess and reporting the reliability of the tested product. Plan for post-release processes. Develop a release kit for product support. Don’t forget the party.

Copyright (c) Cem Kaner. All Rights Reserved. 13 Notes ___________________________________________________________ ___________________________________________________________ ___________________________________________________________ ___________________________________________________________

Copyright (c) Cem Kaner. All Rights Reserved. 14 Project Planning Testing Impossible Software Under Impossible Deadlines Presented at Software Testing Analysis East, 1999

Copyright (c) Cem Kaner. All Rights Reserved. 15 Introduction I didn’t come up with the idea for this talk--the STAR folk suggested it as something that I might be able to provide a few insights into. After all, this is a chronic complaint among testers.... Well, here goes. How should you deal with a situation in which the software comes to you undocumented on a tight deadline? I think that the answer depends on the causes of the situation that you’re in. Your best solution might be technical or political or resume-ical. It depends on how you and the company got into this mess. If it is a mess.

Copyright (c) Cem Kaner. All Rights Reserved. 16 What Caused This Situation? So, let’s start with some questions about causation: Why is the software undocumented? Why do you have so little time? What are the quality issues for this customer?

Copyright (c) Cem Kaner. All Rights Reserved. 17 Why Do You Have So Little Time? A Few Possibilities Time-to-release drives competition Cash flow drives release date Key fiscal milestone drives release date Executive belief that you’ll never be satisfied, so your schedule input is irrelevant Executive belief that testing group is out of control and needs to be controlled by tight budgets Executive belief that you have the wrong priorities (e.g. paperwork rather than bugs) Executive belief that testing is irrelevant Structural lack of concern about the end customer, or Maybe you have an appropriate amount of time.

Copyright (c) Cem Kaner. All Rights Reserved. 18 Quality Issues For This Customer? In-house, “In-house” outsourced External, custom External, large package, packaged External, mass-market, packaged What is quality in this market? What are their costs of failure? » User groups, Software stores, Sales calls, Support calls Over the long term, a good understanding of quality in the market, and as it affects your company’s costs, will buy you credibility and authority.

Copyright (c) Cem Kaner. All Rights Reserved. 19 Political Approaches: Buying Time Many of the ideas in this section will help you if you’re dealing with a single project that is out of control. If your problem is structural (reflects policy or standard practice of the company), then some of these ideas will be counter-productive.

Copyright (c) Cem Kaner. All Rights Reserved. 20 Buying Time: Delaying a Premature Release -2 Take the high road “I want to see knives in the chests, not in the backs.” » Trip Hawkins, founding President, Electronic Arts Communicate honestly. Avoid springing surprises on people. Never sabotage the project. Don’t become The Adversary: If you are nasty and personal, you will become a tool, to be used by someone else. And you will be disposable.

Copyright (c) Cem Kaner. All Rights Reserved. 21 Buying Time: Delaying a Premature Release -3 Search for show-stoppers. If you can, dedicate a specialist within your group to this task. Circulate deferred bug lists broadly. Consider writing mid-project and late-in-project assessments of: » extent of testing (by area) » extent of defects (by area, with predictions about level of bugs left) » deferred bugs » likely out of box experience or reviewers’ experience

Copyright (c) Cem Kaner. All Rights Reserved. 22 Buying Time: Delaying a Premature Release -4 Do regular, effective status reporting. List: your group’s issues (deliverables due to you, things slowing or blocking your progress, etc., areas in which you are behind or ahead of plan) project issues bug statistics Find allies (think in terms of quality-related costs)

Copyright (c) Cem Kaner. All Rights Reserved. 23 Signing Off on the Release? Don’t sign off. Don’t accept the authority to sign off. Don’t pretend to be “QA” when you (obviously) are not. Position yourself as a technical information provider. » Publish pre-release reports that provide data on the stability of the product and the extent of completed testing » Publish a report that lays out the likely issues that will be raised by magazine reviewers (or other third parities) when they see the product » Let the people who want to ship prematurely own their responsibility. Your responsibility is to provide them with the information they need to make that decision.

Copyright (c) Cem Kaner. All Rights Reserved. 24 Technical Approaches Find reference docs (you can get lots of data, even if you can’t get specs.) See the notes on this in the section on Spec-Driven testing Re-use materials across projects. Plan for exploratory testing. Do cost-effective automation. Use tools to find bugs faster » web page syntax checkers, spiders, etc. Facilitate inspections » (Get those bugs out before they reach you.) Cover the obvious legal issues.

Copyright (c) Cem Kaner. All Rights Reserved. 25 Reusable Test Matrix

Copyright (c) Cem Kaner. All Rights Reserved. 26 Group Management Approaches Can you add head count? Will they let you? Can you absorb them? » Do a work flow analysis to figure out what parts of each task could be split off and delegated to a newcomer. Stay organized Use functional outlines Or use a detailed project plan Create and publish explicit coverage reports Get critical processes under control Example: release management

Copyright (c) Cem Kaner. All Rights Reserved. 27 Notes ___________________________________________________________ ___________________________________________________________ ___________________________________________________________ ___________________________________________________________