Chapter 23 Object-Oriented Testing
description
Transcript of Chapter 23 Object-Oriented Testing
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 R.S. Pressman & Associates, Inc., copyright © 1996, 2001
Chapter 23Chapter 23Object-Oriented Object-Oriented
TestingTesting
2
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001
Object-Oriented Object-Oriented TestingTesting
begins by evaluating the correctness and begins by evaluating the correctness and consistency of the OOA and OOD modelsconsistency of the OOA and OOD models
testing strategy changestesting strategy changes the concept of the ‘unit’ broadens due to the concept of the ‘unit’ broadens due to
encapsulationencapsulation integration focuses on classes and their execution integration focuses on classes and their execution
across a ‘thread’ or in the context of a usage across a ‘thread’ or in the context of a usage scenarioscenario
validation uses conventional black box methodsvalidation uses conventional black box methods
test case design draws on conventional test case design draws on conventional methods, but also encompasses special methods, but also encompasses special featuresfeatures
3
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001
Broadening the View of Broadening the View of “Testing”“Testing”
It can be argued that the review of OO analysis and It can be argued that the review of OO analysis and design models is especially useful because the same design models is especially useful because the same semantic constructs (e.g., classes, attributes, operations, semantic constructs (e.g., classes, attributes, operations, messages) appear at the analysis, design, and code level. messages) appear at the analysis, design, and code level. Therefore, a problem in the definition of class attributes Therefore, a problem in the definition of class attributes that is uncovered during analysis will circumvent side that is uncovered during analysis will circumvent side effects that might occur if the problem were not effects that might occur if the problem were not discovered until design or code (or even the next iteration discovered until design or code (or even the next iteration of analysis). of analysis).
4
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001
Testing the CRC Testing the CRC ModelModel1. Revisit the CRC model and the object-relationship model.
2. Inspect the description of each CRC index card to determine if a delegated responsibility is part of the collaborator’s definition.
3. Invert the connection to ensure that each collaborator that is asked for service is receiving requests from a reasonable source.
4. Using the inverted connections examined in step 3, 4. Using the inverted connections examined in step 3, determine whether other classes might be required or whether determine whether other classes might be required or whether responsibilities are properly grouped among the classes.responsibilities are properly grouped among the classes.
5. Determine whether widely requested responsibilities might 5. Determine whether widely requested responsibilities might be combined into a single responsibility.be combined into a single responsibility.
6. Steps 1 to 5 are applied iteratively to each class and 6. Steps 1 to 5 are applied iteratively to each class and through each evolution of the OOA model.through each evolution of the OOA model.
5
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001
OOT OOT StrategyStrategy
class testing is the equivalent of unit class testing is the equivalent of unit testingtesting
operations within the class are testedoperations within the class are tested the state behavior of the class is examinedthe state behavior of the class is examined
integration applied three different integration applied three different strategiesstrategies
thread-based testing—integrates the set of classes thread-based testing—integrates the set of classes required to respond to one input or eventrequired to respond to one input or event
use-based testing—integrates the set of classes use-based testing—integrates the set of classes required to respond to one use caserequired to respond to one use case
cluster testing—integrates the set of classes cluster testing—integrates the set of classes required to demonstrate one collaborationrequired to demonstrate one collaboration
6
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001
OOT—Test Case OOT—Test Case DesignDesignBerard [BER93] proposes the following approach:
1. Each test case should be uniquely identified and should be explicitly associated with the class to be tested,
2. The purpose of the test should be stated,
3. A list of testing steps should be developed for each test and should contain [BER94]:
a. a list of specified states for the object that is to be tested
b. a list of messages and operations that will be exercised as a consequence of the test
c. a list of exceptions that may occur as the object is tested
d. a list of external conditions (i.e., changes in the environment external to the software that must exist in order to properly conduct the test)
e. supplementary information that will aid in understanding or implementing the test.
7
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001
OOT Methods: Random OOT Methods: Random TestingTesting
Random testingRandom testing identify operations applicable to a classidentify operations applicable to a class define constraints on their usedefine constraints on their use identify a miminum test sequenceidentify a miminum test sequence
an operation sequence that defines the an operation sequence that defines the minimum life history of the class (object)minimum life history of the class (object)
generate a variety of random (but valid) test generate a variety of random (but valid) test sequencessequences
exercise other (more complex) class exercise other (more complex) class instance life historiesinstance life histories
8
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001
OOT Methods: Partition OOT Methods: Partition TestingTesting Partition TestingPartition Testing
reduces the number of test cases required to test a reduces the number of test cases required to test a class in much the same way as equivalence class in much the same way as equivalence partitioning for conventional softwarepartitioning for conventional software
state-based partitioningstate-based partitioning categorize and test operations based on their categorize and test operations based on their
ability to change the state of a classability to change the state of a class attribute-based partitioningattribute-based partitioning
categorize and test operations based on the categorize and test operations based on the attributes that they useattributes that they use
category-based partitioningcategory-based partitioning categorize and test operations based on the categorize and test operations based on the
generic function each performsgeneric function each performs
9
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 5/e and are provided with permission by R.S. Pressman & Associates, Inc., copyright © 1996, 2001
OOT Methods: Inter-Class OOT Methods: Inter-Class TestingTesting Inter-class testingInter-class testing
For each client class, use the list of class operators For each client class, use the list of class operators to generate a series of random test sequences. The to generate a series of random test sequences. The operators will send messages to other server operators will send messages to other server classes.classes.
For each message that is generated, determine the For each message that is generated, determine the collaborator class and the corresponding operator collaborator class and the corresponding operator in the server object.in the server object.
For each operator in the server object (that has For each operator in the server object (that has been invoked by messages sent from the client been invoked by messages sent from the client object), determine the messages that it transmits.object), determine the messages that it transmits.
For each of the messages, determine the next level For each of the messages, determine the next level of operators that are invoked and incorporate these of operators that are invoked and incorporate these into the test sequenceinto the test sequence