Table of Contents
        
 
 1. Introduction. 
 
    Who Should Read This Book? 
     What Software Testing Is and Isn't. 
     What Is Different about Testing Object-Oriented Software? 
     Overview of Our Testing Approach. 
     Test Early. 
     Test Often. 
     Test Enough. 
     The Testing Perspective. 
     Organization of This Book. 
     Conventions Used in This Book. 
     A Continuing Example — Brickles. 
     Basic Brickles Components. 
     Brickles Physics. 
     Game Environment. 
   2. The Testing Perspective.      Testing Perspective. 
     Object-Oriented Concepts. 
     Object. 
     Message. 
     Interface. 
     Class. 
     Inheritance. 
     Polymorphism. 
     Development Products. 
     Analysis Models. 
     Design Models. 
     Source Code. 
     Summary. 
   3. Planning for Testing.      A Development Process Overview. 
     A Testing Process Overview. 
     Risk Analysis — A Tool for Testing. 
     Risks. 
     Risk Analysis. 
     A Testing Process. 
     Planning Issues. 
     Dimensions of Software Testing. 
     Who Performs Testing? 
     Which Pieces Are Tested? 
     When is Testing Performed? 
     How Is Testing Performed? 
     How Much Testing Is Adequate? 
     Roles in the Testing Process. 
     A Detailed Set of Test Activities. 
     Roles in the Testing Process. 
     Class Tester. 
     Integration Tester. 
     System Tester. 
     Test Manager. 
     A Detailed Set of Test Activities. 
     Planning Activities. 
     Scheduling Testing Activities. 
     Estimation. 
     A Process for Testing Brickles. 
     Document Templates. 
     Test Metrics. 
     Summary. 
   4. Testing Analysis and Design Models.      An Overview. 
     Place in the Development Process. 
     The Basics of Guided Inspection. 
     Evaluation Criteria. 
     Organization of the Guided Inspection Activity. 
     Basic Roles. 
     Individual Inspection. 
     Preparing for the Inspection. 
     Specifying the Inspection. 
     Realistic Models. 
     Selecting Test Cases for the Inspection. 
     Creating Test Cases . 
     Completing Checklists. 
     The Interactive Inspection Session. 
     Testing Specific Types of Models. 
     Requirements Model. 
     Analysis Models. 
     Design Models. 
     Testing Again. 
     Testing Models for Additional Qualities. 
     Summary. 
     Model Testing Checklist. 
     Addendum: A Process Definition for Guided Inspection. 
     Steps in the Process. 
     Detailed Step Descriptions. 
     Roles in the Process. 
   5. Class Testing Basics.      Class Testing. 
     Ways to Test a Class. 
     Dimensions of Class Testing. 
     Constructing Test Cases. 
     Adequacy of Test Suites for a Class. 
     Constructing a Test Driver. 
     Test Driver Requirements. 
     Tester Class Design. 
     Summary. 
   6. Testing Interactions.      Object Interactions. 
     Identifying Interactions. 
     Specifying Interactions. 
     Testing Object Interactions. 
     Testing Collection Classes. 
     Testing Collaborator Classes. 
     The Interaction between Testing and Design Approach. 
     Sampling Test Cases. 
     Orthogonal Array Testing. 
     Adequacy Criteria for OATS. 
     Another Example. 
     Another Application of OATS. 
     Testing Off-the-Shelf Components. 
     Case Study in Component Acceptance Testing. 
     Protocol Testing. 
     Test Patterns. 
     Listener Test Pattern. 
     Specific Example. 
     Testing Exceptions. 
     Testing Interactions at the System Level. 
     Summary. 
   7. Testing Class Hierarchies.      Inheritance in Object-Oriented Development. 
     Subclass Test Requirements. 
     Refinement Possibilities. 
     Hierarchical, Incremental Testing. 
     Organizing Testing Software. 
     Testing Abstract Classes. 
     Summary. 
   8. Testing Distributed Objects.      Basic Concepts. 
     Computational Models. 
     Concurrent. 
     Parallel. 
     Networked. 
     Distributed. 
     Basic Differences. 
     Non-Determinism. 
     Additional Infrastructure. 
     Partial Failures. 
     Time Outs. 
     Dynamic Nature of the Structure. 
     Threads. 
     Synchronization. 
     Path Testing in Distributed Systems. 
     Thread Models. 
     Life Cycle Testing. 
     Models of Distribution. 
     Basic Client/Server Model. 
     Standard Models of Distribution. 
     Comparisons and Implications. 
     A Generic Distributed Component Model. 
     Basic Architecture. 
     Local and Remote Interfaces. 
     Specifying Distributed Objects. 
     Interface Definition Language. 
     Traditional Pre/Post-Conditions and Invariants. 
     Temporal Logic. 
     Temporal Test Patterns. 
     Eventually(a). 
     Until(a,b). 
     Always. 
     A Test Environment. 
     Class Testing. 
     Interaction Testing. 
     Test Cases. 
     Model-specific tests. 
     Testing Every Assumption. 
     Infrastructure Tests. 
     Logic-Specific Test Cases. 
     The Ultimate Distributed System — The Internet. 
     Web Servers. 
     Life Cycle Testing of Internet Applications. 
     What Haven't We Said? 
     Summary. 
   9. Testing Systems.      Defining the System Test Plan. 
     Features Tested and Not Tested. 
     Test Suspension Criteria and Resumption Requirements. 
     Complementary Strategies for Selecting Test Cases. 
     Use Profile. 
     ODC. 
     Use Cases as Sources of Test Cases. 
     Constructing Use Profiles. 
     Using Scenarios to Construct Test Cases. 
     The Expected Results Section of a Test Case. 
     Brickles. 
     Testing Incremental Projects. 
     Legacy Projects. 
     Testing Multiple Representations. 
     What Needs to Be Tested. 
     Testing Against Functional Requirements. 
     Testing for Qualitative System Attributes. 
     Testing the System Deployment. 
     Testing After Deployment. 
     Testing Environment Interactions. 
     Test System Security. 
     Types of Testing. 
     Stress Testing. 
     Life Cycle Testing. 
     Performance Testing. 
     Testing Different Types of Systems. 
     Reactive Systems. 
     Embedded Systems. 
     Multi-Tiered Systems. 
     Distributed Systems. 
     Measuring Test Coverage. 
     What Is to Be Covered? 
     When Is Coverage Measured? 
     When Is Coverage Used? 
     ODC<ETH>Defect Impacts. 
     More Examples. 
     Summary. 
   10. Components, Frameworks, and Product Lines.      Component Models. 
     Enterprise JavaBeans Component Model. 
     Testing Components vs. Objects. 
     Component Test Processes. 
     Test Cases Based on Interfaces. 
     Case Study — A GameBoard Component. 
     Frameworks. 
     Basic Issues. 
     Framework Testing Processes. 
     Inspecting a Framework. 
     Structuring Test Cases to Support a Framework. 
     Product Lines. 
     Testing at the Organizational Management Level. 
     Testing at the Technical Management Level. 
     Testing at the Software Engineering Level. 
     Testing in a Product Line Project. 
     Future. 
     Summary. 
   11. Conclusion.      Suggestions. 
     Organization and Process. 
     Data. 
     Standards. 
     Software Infrastructure. 
     Techniques. 
     Risks. 
     Brickles. 
     Finally. 
   Bibliography.    Index. 0201325640T04062001 
            Preface
        Testing software is a very important and challenging activity.  This is a book for people who test software during its development. Our focus is on object-oriented and component-based software, but you can apply many of the techniques discussed in this book regardless of the development paradigm. We assume our reader is familiar with testing procedural software--that is, software written in the procedural paradigm using languages such as C, Ada, Fortran, or COBOL.  We also assume our reader is familiar and somewhat experienced in developing software using object-oriented and component-based technologies. Our focus is on describing what to test in object-oriented development efforts as well as on describing techniques for how to test object-oriented software, and how testing software built with these newer technologies differs from testing procedural software.
What is software testing? To us, testing is the evaluation of the work products created during a software development effort. This is more general than just checking part or all of a software system to see if it meets its specifications. Testing software is a difficult process, in general, and sufficient resources are seldom available for testing. From our standpoint, testing is done throughout a development effort and is not just an activity tacked on at the end of a development phase to see how well the developers did. We see testing as part of the process that puts quality into a software system. As a result, we address the testing of all development products (models) even before any code is written.
We do not necessarily believe that you will apply everything we describe in this book. There are seldom enough resources available to a development effort to do all the levels and kinds of testing we would like. We hope you will find a number of approaches and techniques that will prove useful to and affordable for your project.
In this book we describe a set of testing techniques. All of the techniques we describe have been applied in practice. Many of these techniques have been used in a wide variety of industries and on projects of vastly different sizes. In Chapter 3, we will consider the impact of some of these variables on the types of testing that are routinely performed.
To describe these techniques, we rely in many cases on one or more examples to illustrate their application. We hope from these examples and from our explanations that you can apply the same techniques to your project software in a straightforward manner.  The complete code for these examples, test code, and other resources can be obtained via a link off this Web site. 
In order to make this book as useful as possible, we will provide two major organizational threads. The physical layout of the book will follow the usual sequence of events as they happen on a project. Model testing will be addressed earlier than component or code testing, for example. We will also include a set of questions that a tester might ask when he or she is faced with specific testing tasks on a project. This testing FAQ will be tied into the main body of the text with citations.
We have included alternative techniques and ways of adapting techniques for varying the amount of testing. Testing life-critical or mission-critical software requires more effort than testing an arcade game. The summary sections of each chapter should make these choices clear.
This book is the result of many years of research, teaching, and consulting both in the university and in companies. We would like to thank the sponsors of our research, including COMSOFT, IBM, and AT&T for their support of our academic research. Thanks to the students who assisted in the research and those who sat through many hours of class and provided valuable feedback on early versions of the text. The consultants working for Korson-McGregor, formerly Software Architects, made many suggestions and worked with early versions of the techniques while still satisfying client needs. The employees of numerous consulting clients helped us perfect the techniques by providing real problems to be solved and valuable feedback. A special thanks to Melissa L. Russ (formerly Major) who helped teach several tutorials and made her usual insightful comments to improve the material.
Most of all, we wish to thank our families for enduring our mental and physical absences and for the necessary time to produce this work: Gayle and Mary Frances McGregor; Susan, Aaron, Perry, and Nolan Sykes.
JDM
DAS
   0201325640P04062001 
            
Index
        
  -  Abstract classes, 35-36
  
    -  testing of, 263-661
  
 
-  Abstraction, 39
  -  Acceptance-level component test process, 348
  -  Acceptance testing, 133, 323
  
    -  of components, 237-41
    -  on frameworks, 360
    -  of systems, 310
  
 
-  Accessor (inspector) operations, 24-25, 53
  
    -  baseline testing of, 193, 194
  
 
-  Action, 49
  -  Activity, 49
  -  Activity diagrams, 41
  
    -  in analysis models, 54-55
  
 
-  Actor profiles, 316-17
  -  Actual parameters of messages, 20
  -  Adequacy criteria for orthogonal array testing system, 234-35
  -  Adequacy of testing, idea of, 84-86
  -  "All events" level of coverage, 335
  -  Always temporal operator, 293
  -  Analysis
  
    -  in STEP technique, 72
    -  testing during, 5-6
  
 
-  Analysis models, 40-55
  
    -  activity diagrams in, 54-55
    -  application analysis, 41
    -  class diagrams in, 45-48, 49
    -  class specifications in, 49-51
    -  domain analysis, 40-41
    -  guided inspection of, 138-41
    -  level of detail in testing, 82
    -  purpose of, 42
    -  sequence diagrams in, 51-54, 55
    -  state diagrams in, 49, 50, 53
    -  use case diagrams in, 42-45
  
 
-  Analysis phase of development process, 66
  -  Ancestors, 32
  -  API testing, 304
  -  Application, system vs., 310
  -  Application analysis, 41, 66, 115
  
    -  testing activities, 88
  
 
-  Application-analysis models
  
    -  guided inspection of, 140-41
    -  mapping domain models onto, 140
  
 
-  Application implementation testing activities, 90
  -  Application-level use cases, 44
  -  Application life cycles, 331-32
  -  Arcade games, domain-level use cases for, 43-44
  -  Architects, role in testing class diagram, 149
  -  Architectural design, 115
  
    -  guided inspection of, 142-48
    
      -  evaluating performance and scalability, 147-48
      -  inspection criteria, 43
      -  roles in inspection, 142
      -  test case for, 142, 145, 146-47
      -  test execution, 146
      -  verification of results, 146
    
 
-  testing activities, 89
  
 
-  Architectural models, performance goals in, 120
  -  Architecture
  
    -  software, 142
    -  three-tiered, 146-47
  
 
-  Assertion checking in class under test (CUT), 194
  -  Asynchronous messages, 287, 302
  -  Attitudes toward testing, 2
  
  
  
	- 
		
- 
 
-  Base class (superclass), 32
  -  Baseline testing, 193-95
  -  BeanBox, 346
  -  Beans, 345-46
  -  Behavior
  
    -  constrained by substitution principle, 33
    -  of instances, 27
  
 
-  BetterState, 143
  -  Black box testing (functional testing), 84, 187
  -  Boundary conditions, 180
  -  Boundary values for states, 179
  -  Brickles, 10-14
  
    -  abstract classes in, 36
    -  activity diagram, 54
    -  all events coverage for, 335
    -  application analysis of, 41
    -  architectural model for, 145
    -  change case for, 152
    -  class diagram for, 45-47
    -  class risks in, 166
    -  class testing in, 169
    -  collaborating classes in, 219, 223
    -  collection classes in, 218, 219
    -  components of, 11
    -  design class diagram for, 56-57, 58
    -  detailed design model for, 148
    -  domain analysis of, 40
    -  exceptions in, 245
    -  frameworks in, 359
    -  game environment of, 14
    -  guided inspection of, 111-14
    -  incremental iterative development process, 68-69
    -  inheritance in, 34-35, 256-57
    -  Java implementation of, 270, 278, 303
    -  objects in, 18
    -  package diagram for, 47
    -  performance testing of, 333
    -  physics of, 11-13
    -  player actor in, 316, 317
    -  risk analysis of, 76
    -  sequence diagram for, 51, 52, 57-58, 60
    -  Sprite class in, 194
    -  state diagram for, 57, 59
    -  summary of testing, 371-73
    -  system test cases from, 320-22
    -  system test plan for, 312
    -  testing process for, 93-94
    -  test pattern for, 244-45
    -  use-case diagram for, 132, 133, 134-36
    -  use cases in, 42-44, 137
    -  use profiles in, 130
  
 
-  Buddy testing, 70, 80, 92, 151
  -  Business risks, 74
  
	- 
		
- 
 
-  C++
  
    - class of referents in, 38
    -  friends supports, 61
    -  inclusion polymorphism in, 34
    -  risks associated with, 75
    -  templates in, 38-39
    -  thread synchronization in, 275
    -  typing in, 61
  
 
-  Callbacks, distributed, 296-97
  -  Capability Maturity Model for Software (SW-CMM), 362
  -  Cell phone, state machine for, 337
  -  Change cases, 151-54
  -  Checklists
  
    -  completing, 128
    -  design phase, 129
    -  model-testing, 155-56
  
 
-  Class(es), 22-24
  
    -  abstract, 35-36, 263-66
    -  base, 32
    -  collaborator, 213, 218-20, 223
    -  collection, 218, 219, 222, 237
    -  container, 218
    -  derived, 32, 34
    -  implementation, 22, 30-31, 90
    -  nonprimitive, 215-16, 218
    -  objectives for, 99
    -  as objects, 22
    -  primitive, 215
    -  risk in, 166
    -  sets representing, 35
    -  specification, 22, 24-29
    
      -  in analysis models, 49-51
    
 
-  subsystems and, 31
    -  Tester. See Tester class
    -  Timer, 279-80
  
 
-  Class diagrams, 41
  
    -  in analysis models, 45-48, 49
    -  in design models, 56-57
    -  layering for, 122
    -  linking, 123, 124
  
 
-  Class family, 227
  -  Class hierarchies, 249-67
  
    -  abstract classes, 263-66
    -  organizing testing software, 262-63
    -  subclass test requirements, 250-62
    
      -  hierarchical incremental testing (HIT), 253-57
      -  implementation-based test cases, 261-62
      -  refinement possibilities, 251-52
      -  specification-based test cases, 257-61
      -  top-down, 250-51
    
 
 
-  Class invariants, 26-27, 289, 290
  -  Class libraries, 166
  
    -  container classes in, 218
  
 
-  Class tester, 86-87
  -  Class testing, 78, 163-211. See also Interactions; Parallel architecture for class testing (PACT)
  
    -  adequacy of, 168, 179-82
    
      -  code-based coverage, 181-82
      -  constraint-based coverage, 181
      -  state-based coverage, 179-81
    
 
-  buddy approach to, 92
    -  continuum for assignments of roles in, 80
    -  defined, 164
    -  dimensions of, 166-68
    -  of distributed objects, 272, 293-94
    -  execution-based, 263-65
    -  guided inspections, 266
    -  integration testing and, 164
    -  of objects with threads, 277-78
    -  parallel architecture for (PACT), 249, 262-63
    -  partial, 215
    -  regression, 167
    -  scheduling, 91
    -  test cases for, 168-79
    
      -  describing, 177
      -  identification of, 168
      -  from pre- and postconditions, 169-74
      -  from state transition diagrams, 174-79
    
 
-  test driver for, 168, 183-210
    
      -  design structures, 183-86
      -  example code for, 196-210
      -  requirements of, 186-88
      -  Tester class, 187-210
    
 
-  unit testing and, 164, 165
    -  ways of, 164-66
  
 
-  Class under test (CUT), 187
  
    -  assertion checking in, 194
  
 
-  Client/server model, 281
  
    -  tests for, 296-97
  
 
-  Code-based coverage, 181-82
  -  Code coverage, 106
  -  Code inspections, 165
  -  Code reviews, 186
  -  Code testing, 6
  -  Collaboration. See Interactions
  -  Collaboration diagrams, 51n, 54
  -  Collaborator classes, 213, 218-20, 223
  -  Collaborators, addressing, 217
  -  Collection classes, 218, 219, 222, 237
  -  Commercial-off-the-shelf (COTS) software, 323
  -  Common Object Request Broker Architecture. See CORBA
  -  Communication, component integration failure triggered by, 348
  -  Compatibility, lateral, 125
  -  Compilation, conditional, 265
  -  Completeness, 119
  
    -  of diagrams, 118
    -  of frameworks, 360
    -  of requirements model, 133
  
 
-  Components, 344-58
  
    -  of architecture, 142
    -  defined, 344
    -  distributed, 345
    -  Enterprise JavaBeans (EJB) model, 345-49
    -  GameBoard, 351-58
    -  objects vs., 346-48
    -  packaging technology for, 350
    -  protocol between, 350-51
    -  test cases based on interfaces, 349-51
    -  testing off-the-shelf, 237-41
    -  test processes, 348-49
  
 
-  Component test plan, 98-100, 101, 197
  -  Computational models, 271-72
  
    -  sequential vs. nonsequential, 272-74
  
 
-  Concrete subclasses, 36
  -  Concurrency, 51, 270. See also Distributed objects
  
    -  among components, 348
    -  as inspection trigger, 125
  
 
-  Concurrent model of computation, 271
  -  Concurrent state diagram, 49
  -  Concurrent state machines, 334
  -  Conditional compilation, 265
  -  Configurations, hardware, 315
  -  Connectors of architectural components, 142
  -  Consistency, 119-20
  
    -  checks for, 143
    -  between diagrams, 155
    -  of frameworks, 361
    -  of requirements model, 133
  
 
-  Constraint-based coverage, 181
  -  Construction, in STEP technique, 72
  -  Constructors, 25, 30, 266
  
    -  baseline testing of, 193, 194
    -  default, 280
  
 
-  Container classes, 218
  -  Context
  
    -  defining, 329
    -  for performance testing, 333
  
 
-  Contract approach, 27, 29, 31, 171
  
    -  object interaction testing and, 221, 224-25
  
 
-  CORBA, 282-83, 284, 300, 301, 345
  -  CORBA TestBox, 350
  -  Core assets, 362
  -  Correctness
  
    -  of frameworks, 361
    -  of models, 119
  
 
-  Correctness faults of requirements model, 133
  -  Coverage, 85-86, 106
  
    -  "All events" level of, 335
    -  code, 106
    -  code-based, 181-82
    -  concept of, 84
    -  constraint-based, 181
    -  estimating levels of, 91-92
    -  model-element, 106
    -  in models, 117
    -  of path testing, 275-76
    -  postcondition, 106, 181
    -  of preconditions, 181
    -  state-based, 179-81
    -  of system testing, 338-41
  
 
-  CTester, 185
  
	- 
		
- 
 
-  Data
  
    -  collecting for testing, 368
    -  problems with real, 332
    -  static, 168
  
 
-  Database, relational, 325
  -  Data members, 30
  -  Dates, 289
  -  DCOM, 283-84, 285, 300, 345
  -  Debugging, testing vs., 3
  -  Defect categories, 369. See also Orthogonal Defect Classification (ODC)
  -  Defect impacts, 339-40
  -  Defensive design approach, 27-29, 31, 171
  
    -  object interaction testing and, 221, 222, 224-25
  
 
-  Definitional aspect of object-oriented programming, 19
  -  Deployment testing, 300, 327-28
  -  Derived class. See Subclass
  -  Descendents, 32
  -  Design
  
    -  for testability, 53, 279-80
    -  tests for, 5-6
  
 
-  Design conformance, as inspection trigger, 125
  -  Design models, 56-59, 141-51
  
    -  architectural, 142-48
    
      -  evaluating performance and scalability, 147-48
      -  inspection criteria, 43
      -  roles in inspection, 142
      -  test case for, 142, 145, 146-47
      -  test execution, 146
      -  verification of results, 146
    
 
-  class diagrams in, 56-57
    -  coverage in, 117
    -  detailed class, 148-51
    -  sequence diagrams in, 57-59
    -  state diagrams in, 57
    -  testing, 78
  
 
-  Design patterns, 242-43
  
    -  vetoable-change, 346, 351, 354-56
  
 
-  Design phase, 66
  
    -  checklist, 129
  
 
-  Desk check, 121
  -  Destructors, 25, 30, 266
  -  Detailed class design models, 148-51
  -  Detailed design, 115
  
    -  testing activities, 90
  
 
-  Developer
  
    -  class testing by, 166-67
    -  in guided inspection, 120-21
    -  role of, 80
  
 
-  Developer hours/number of defects metric, 107
  -  Development-level component test process, 348
  -  Development process, 66-69
  
    -  changes in, 5
    -  feedback loop to, 70-71
    -  incremental, iterative, 66-69
    -  main activities in, 66
    -  place of guided inspection in, 115
    -  testing's fit into, 2
  
 
-  Development schedule, testing schedule and, 86
  -  Diagrams. See also Activity diagrams; Class diagrams; Sequence diagrams; State diagrams
  
    -  collaboration, 51n, 54
    -  consistency between, 155
    -  layering, 122-23, 125
    -  message-sequence, 146
    -  package, 41
    -  use case, 41, 42-45
  
 
-  Distributed callbacks, 296-97
  -  Distributed Common Object Model (DCOM), 283-84, 285, 300, 345
  -  Distributed model of computation, 272
  -  Distributed objects, 296-307
  
    -  additional infrastructure required by, 273
    -  class testing of, 272, 293-94
    -  "component" aspect of, 345
    -  dynamic nature of, 274
    -  failures in, 269-70
    
      -  partial, 273-74, 301, 303
    
 
-  generic distributed-component model, 284-87
    
      -  architecture of, 285-86
      -  local and remote interfaces, 287
    
 
-  interaction testing of, 295
    -  Internet, 303-6
    
      -  failures in, 303-4
      -  life-cycle testing of applications for, 305-6
      -  Web servers, 304-5
    
 
-  life cycle testing of, 280-81
    -  models of distribution, 281-84
    
      -  basic client/server model, 281
      -  CORBA, 282-83, 284, 300, 301
      -  DCOM, 283-84, 285, 300
      -  RMI, 284, 300
    
 
-  multitiered system, 336-37
    -  path testing in, 275-80
    -  performance of, 148
    -  sequential systems vs., 272-74
    -  specifying, 287-88
    -  system testing of, 338
    -  temporal logic in, 288-93
    -  tests, 295-302
    
      -  for client/server model, 296-97
      -  of infrastructure, 300-301
      -  language dependence issues, 300
      -  logic-specific cases, 301-2
      -  platform independence issues, 300
    
 
-  threads in, 270-71, 274-75, 278-80
  
 
-  DLLs, 328, 350
  -  Documentation, source code, 59
  -  Document templates. See Test plans
  -  Document/View architecture, 142
  -  Domain analysis, 40-41, 66, 115
  
    -  coverage in, 117
    -  guided inspection of, 138-39
    -  testing activities, 88
  
 
-  Domain experts, 120
  
    -  division into teams, 119
    -  in requirements inspection, 134-35, 137
  
 
-  Domain-level use cases, 43
  -  Domain life cycles, 331-32
  -  Domain models, mapping onto application-analysis model, 140
  -  Domain type, estimation based on, 92
  -  Drawer, in interactive inspection session, 131
  -  Drivers, interactions among, 315
  -  Dynamic binding, 34n
  -  Dynamic link library (DLL), 328, 350
  
	- 
		
- 
 
-  E-commerce systems, 303
  -  Editor inheritance, 265
  -  Effectiveness of testing process, 106-7
  -  Efficiency of testing process, 106, 107
  -  Embedded systems, 335-36
  -  End-to-end scenarios, 133
  -  End-to-end system-level use cases, 101
  -  Enterprise JavaBeans (EJB) model, 345-49
  -  Environmental interactions, 328-30
  -  Equipment required, estimating, 92
  -  Estimation, 91-93
  -  Event, 49
  -  Eventually temporal operator, 291-92
  -  Exceptions, 20, 28
  
    -  provider-related, 288
    -  testing, 245-48
  
 
-  Execution and evaluation, in STEP technique, 73
  -  Execution-based testing, 164, 165, 263-65
  -  Execution time, 289
  -  Expected results, 72
  -  Experts, domain, 120
  
    -  division into teams, 119
    -  in requirements inspection, 134-35, 137
  
 
-  Extends relation (in use cases), 43-44
  
	- 
		
- 
 
-  Facade, 324
  -  Factors, 228-31
  -  Factory Methods, object under test (OUT), 189-93, 195, 222n
  -  Fagan inspections, 110
  -  Frameworks, 344, 359-61
  -  Friend functions, 61, 223
  -  Functionality use cases, 101
  -  Functional sub-use cases, 101
  -  Functional test cases, 99, 187
  -  Functional testing, 84, 187
  
	- 
		
- 
 
-  GameBoard component, 351-58
  -  Generalization of inheritance relationship, 250
  -  Grand tour test cases, 144, 320
  -  Guard condition, 49
  -  Guided inspection, 109-62, 300, 370
  
    -  abstract class testing using, 266
    -  of analysis model, 138-41
    -  of design models, 141-51
    
      -  architectural, 142-48
      -  detailed, 148-51
    
 
-  of diagram completeness and consistency, 118
    -  evaluation criteria, 118-20
    -  of frameworks, 360
    -  metalevel questions about system using, 151-54
    -  organization of, 120-21
    -  overview of, 110-14
    -  place in development process, 115
    -  preparing for, 121-31
    
      -  checklist completion, 128
      -  creating test cases, 127-28
      -  interactive inspection session, 128-31
      -  realistic models, 121-23
      -  selecting test cases for, 123-27
      -  specifying inspection, 121
    
 
-  process checklist for, 155-56
    -  process definition for, 157-62
    -  of product line architecture, 364
    -  of requirements model, 131-38
    
      -  evaluation criteria, 132-34
      -  roles for, 134-37
      -  testing, 137-38
      -  use case for, 132-36
    
 
-  requirements of, 99
    -  scope and depth of, 111, 116, 121
    -  to transfer knowledge about model under test, 151
  
 
-  GUI testing, 304
  
	- 
		
- 
 
-  Hardware configurations, 315
  -  Hierarchies, class. See Class hierarchies
  -  Hierarchical incremental testing (HIT), 253-57, 370
  -  High-level use cases, 101
  -  Hot spots, 359
  
	- 
		
- 
 
-  IEEE standards, 94, 96, 311, 368
  -  Implementation-based testing (structural testing), 84, 167, 182, 187, 261-62
  -  Implementation for software entity, 83
  -  Implementation phase of development process, 66
  -  Implicit specifications, 288
  -  Implicit tests, 288
  -  In, out attribute, 287
  -  Include directive, 22
  -  Inclusion polymorphism, 32, 34-38, 83
  -  Incremental, iterative development process, 66-69
  -  Independent testers, 80, 92
  -  Infeasible test case, 320
  -  Inheritance, 31-32, 33, 37, 249, 250. See also Class hierarchies
  
    -  editor, 265
    -  inclusion polymorphism and, 34
    -  multiple, 31n, 264
    -  private, 34n
    -  protected, 34n
    -  public, 34n
  
 
-  Inheritance hierarchy, 32
  -  Inherited test cases, 253
  -  Input for test cases, 72, 177
  -  Insertion operator, 223
  -  Inspection, in software testing, 16
  -  Inspection team, assigning, 111
  -  Inspector (accessor) operations, 24-25, 53
  
    -  baseline testing of, 193, 194
  
 
-  Instances, 22, 27
  -  Instance variables, 30
  -  Instantiation, 22
  -  Integration-level component test process, 348-49
  -  Integration tester, 87
  -  Integration testing, 2, 5, 70, 83
  
    -  class testing and, 164
    -  scheduling, 91
  
 
-  Integration test plan, 101-2
  -  Interactions
  
    -  among components, 348
    -  environmental, 328-30
    -  in multiple representations, 324
    -  object. See Object interactions
    -  parameter, 216
    -  standard patterns of, 347
    -  test cases for memory/disk, 328-29
  
 
-  Interaction test cases, 100, 187
  -  Interaction testing, 78, 213-48
  
    -  of distributed objects, 295
    -  of exceptions, 245-47
    -  focus of, 214
    -  of off-the-shelf components, 237-41
    -  of protocols, 241
    -  sampling test cases, 225-37
    
      -  dimensions for, 227-28
      -  orthogonal array testing system (OATS), 228-37
    
 
-  at system level, 247-48
    -  test patterns, 242-45
  
 
-  Interaction test suite, 187
  -  Interactive inspection session, 128-31
  -  Interface(s)
  
    -  approaches to defining, 27-29
    -  in Java, 61
    -  to legacy software, 323
    -  object-oriented, 21-22
    -  PACT approach to, 349
    -  test cases based on, 349-51
    -  between two data representations, 325
  
 
-  Interface definition language (IDL), 287
  -  Internet, 303-6
  
    -  failures in, 303-4
    -  life-cycle testing of applications for, 305-6
    -  Web servers, 304-5
  
 
-  Internet Inter-Orb Protocol (IIOP), 284
  -  Invariant conditions, 27, 49
  -  Invariants, 26-27
  
    -  checking, 191
    -  class, 26-27, 289, 290
    -  for distributed components, 288
    -  object, 290
  
 
-  Iterative enhancement, 7
  
	- 
		
- 
 
-  Java
  
    -  class of referents in, 38
    -  inclusion polymorphism in, 34
    -  interfaces in, 61
    -  permissions file in, 330
    -  risks associated with, 75
    -  thread synchronization in, 270, 274, 275
    -  typing in, 61
  
 
-  Java Archives (JAR), 350
  -  JUnit, 370
  
	- 
		
- 
 
-  Languages, programming
  
    -  effect on testing, 61
    -  risks associated with, 75
  
 
-  Lateral compatibility as inspection trigger, 125
  -  Legacy projects, 323-24
  -  Levels, 229
  -  Life cycle(s)
  
    -  for an object, 18
    -  types of, 331-32
  
 
-  Life-cycle scenario, 238, 240-41
  -  Life-cycle testing
  
    -  of distributed system, 280-81
    -  of Internet applications, 305-6
    -  system, 331-32
  
 
-  Lifetime of software, expected, 84-85
  -  Listener design pattern, 242-43, 346
  -  Listener test pattern, 242-45
  -  Load test, 326-27
  -  Logic, temporal, 288-93, 370
  
	- 
		
- 
 
-  Maintenance, 66
  -  Management-level testing, 362-63
  -  Manager, test, 87
  -  Member function call, 20n. See also Messages
  -  Member functions, 30
  -  Memory/disk interaction, test cases for, 328-29