Unit Testing CS 4311 Hans Van Vliet, Software Engineering, Principles and Practice, 3rd edition, John Wiley & Sons, 2008. Chapter 13.

Slides:



Advertisements
Similar presentations
Software Testing Techniques
Advertisements

Chapter 14 Software Testing Techniques - Testing fundamentals - White-box testing - Black-box testing - Object-oriented testing methods (Source: Pressman,
Unit-V testing strategies and tactics.
DETAILED DESIGN, IMPLEMENTATIONA AND TESTING Instructor: Dr. Hany H. Ammar Dept. of Computer Science and Electrical Engineering, WVU.
1 Integration Testing CS 4311 I. Burnstein. Practical Software Testing, Springer-Verlag, 2003.
1 ECE 453 – CS 447 – SE 465 Software Testing & Quality Assurance Lecture 11 Instructor Paulo Alencar.
SOFTWARE TESTING. INTRODUCTION  Software Testing is the process of executing a program or system with the intent of finding errors.  It involves any.
Testing in the Small (aka Unit Testing, Class Testing)
CMSC 345, Version 11/07 SD Vick from S. Mitchell Software Testing.
Testing an individual module
Chapter 18 Testing Conventional Applications
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.
SOFTWARE TESTING WHITE BOX TESTING 1. GLASS BOX/WHITE BOX TESTING 2.
1 Software Testing Techniques CIS 375 Bruce R. Maxim UM-Dearborn.
Chapter 13 & 14 Software Testing Strategies and Techniques
Software Testing Sudipto Ghosh CS 406 Fall 99 November 9, 1999.
Software Systems Verification and Validation Laboratory Assignment 3
CMSC 345 Fall 2000 Unit Testing. The testing process.
Prof. Mohamed Batouche Software Testing.
CS4311 Spring 2011 Unit Testing Dr. Guoqiang Hu Department of Computer Science UTEP.
CS4311 Spring 2011 Unit Testing Dr. Guoqiang Hu Department of Computer Science UTEP.
Software Testing The process of operating a system or component under specified conditions, observing and recording the results, and making an evaluation.
Agenda Introduction Overview of White-box testing Basis path testing
Software Testing. 2 CMSC 345, Version 4/12 Topics The testing process  unit testing  integration and system testing  acceptance testing Test case planning.
1 Software Testing. 2 Path Testing 3 Structural Testing Also known as glass box, structural, clear box and white box testing. A software testing technique.
Test Coverage CS-300 Fall 2005 Supreeth Venkataraman.
Unit Testing 101 Black Box v. White Box. Definition of V&V Verification - is the product correct Validation - is it the correct product.
INTRUDUCTION TO SOFTWARE TESTING TECHNIQUES BY PRADEEP I.
White-box Testing.
1 Program Testing (Lecture 14) Prof. R. Mall Dept. of CSE, IIT, Kharagpur.
BASIS PATH TESTING.
Testing in the Small (aka Unit Testing, Class Testing) 1209.
Theory and Practice of Software Testing
SOFTWARE TESTING. Introduction Software Testing is the process of executing a program or system with the intent of finding errors. It involves any activity.
White Box Testing by : Andika Bayu H.
Black Box Unit Testing What is black-box testing? Unit (code, module) seen as a black box No access to the internal or logical structure Determine.
White-Box Testing Techniques I Prepared by Stephen M. Thebaut, Ph.D. University of Florida Software Testing and Verification Lecture 7.
System Testing 12/09. Hierarchy of Testing Testing Program Testing Top Down Bottom Up Integration TestingUnit Testing System Testing Big Bang Sandwich.
Dynamic White-Box Testing What is code coverage? What are the different types of code coverage? How to derive test cases from control flows?
SOFTWARE TESTING LECTURE 9. OBSERVATIONS ABOUT TESTING “ Testing is the process of executing a program with the intention of finding errors. ” – Myers.
Software Testing. SE, Testing, Hans van Vliet, © Nasty question  Suppose you are being asked to lead the team to test the software that controls.
1 Software Testing. 2 What is Software Testing ? Testing is a verification and validation activity that is performed by executing program code.
Testing Integral part of the software development process.
Software TestIng White box testing.
Software Testing.
BASIS PATH TESTING.
Software Testing.
Rekayasa Perangkat Lunak Part-13
White-Box Testing Pfleeger, S. Software Engineering Theory and Practice 2nd Edition. Prentice Hall, Ghezzi, C. et al., Fundamentals of Software Engineering.
Software Testing.
Software Testing Techniques
Software Engineering (CSI 321)
Chapter 13 & 14 Software Testing Strategies and Techniques
Structural testing, Path Testing
White-Box Testing Techniques
Types of Testing Visit to more Learning Resources.
White Box Testing.
UNIT-IV ECS-602 Software engineering PART-I
UNIT-4 BLACKBOX AND WHITEBOX TESTING
Software Testing (Lecture 11-a)
Chapter 14 Software Testing Techniques
Static Testing Static testing refers to testing that takes place without Execution - examining and reviewing it. Dynamic Testing Dynamic testing is what.
Test Case Test case Describes an input Description and an expected output Description. Test case ID Section 1: Before execution Section 2: After execution.
White-Box Testing Techniques I
Software Testing “If you can’t test it, you can’t design it”
UNIT-4 BLACKBOX AND WHITEBOX TESTING
By: Lecturer Raoof Talal
Software Testing.
Chapter 13 & 14 Software Testing Strategies and Techniques 1 Software Engineering: A Practitioner’s Approach, 6th edition by Roger S. Pressman.
Unit III – Chapter 3 Path Testing.
Presentation transcript:

Unit Testing CS 4311 Hans Van Vliet, Software Engineering, Principles and Practice, 3rd edition, John Wiley & Sons, 2008. Chapter 13.

Hierarchy of Testing Testing Ad Hoc Program Testing System Testing Acceptance Testing Unit Testing Integration Testing Function Benchmark Properties Black Box Black Box Black Box Black Box Black Box Black Box Top Down Pilot Performance Equivalence Equivalence Equivalence Equivalence Equivalence Equivalence Bottom Up Boundary Boundary Boundary Boundary Boundary Reliability Alpha Big Bang Decision Table Decision Table Availability Beta Sandwich State Transition State Transition State Transition State Transition State Transition Security Use Case Use Case Use Case Use Case Usability Documentation Domain Analysis Domain Analysis Domain Analysis White Box White Box Portability Control Flow Data Flow Capacity

Outline Basic concepts Black box testing White box testing

Basic Concepts What is unit testing? Test focusing on the smallest units of code, such as Functions, procedures, subroutines, subprograms Methods, classes Component tested in isolation from the rest of the system and in a controlled environment: Uses appropriately chosen input data Uses component-level design description as guide Often the target of testing frameworks such as JUnit

Basics Why unit testing? What to test? When and who? Foundation for other testing like integration and system testing What to test? Data transformations across the unit are tested Data structures are tested to ensure data integrity When and who? Frequently done (at least partially) during code development by code developers

Unit Test Procedures Driver Module to Be Tested Results Test cases Stub Stub

Two Different Techniques Black box Based on specification Inner structure of test object is not considered White box Based on source code Inner structure of test object is the basis of test case selection Often complementary Effectiveness of black box is similar to white box, but the mistakes found are different (Hetzel 1976, Myers 1978) Use in combinations

Outline Basic concepts Black box testing White box testing Equivalence classes … White box testing

What Is Black Box Testing? Unit (code, module) seen as a black box No access to the internal or logical structure Determine if given input produces expected output Input Output

Black Box Testing Test set is derived from specifications or requirements Goal is to cover the input space Lots of approaches to describing input space: Equivalence classes Boundary value analysis Decision tables State transitions Use cases . . .

Advantage and Disadvantage (Dis)Advantages It does not require access to the internal logic of a component However, in most real-world applications, impossible to test all possible inputs Need to define an efficient strategy to limit number of test cases

General Process Analyze specifications or requirements Select valid and invalid inputs (i.e., positive and negative tests) Determine expected outputs Construct tests Run tests Compare actual outputs to expected outputs

Outline Basic concepts Black box testing White box testing Equivalence classes Boundary values … White box testing

Motivation Assume you test a sign function, int sign(int x), whose result is defined as: 1 if x > 0 0 if x = 0 -1 otherwise (i.e., x < 0) One way to reduce the number of test cases is: to partition the input into three subsets { x | x > 0}, { x | x = 0}, { x | x < 0} to pick one from each subset, e.g., 10, 0, and -10.

Basic Strategy of Equivalence Classes Partition the input into equivalence classes This is the tricky part. It’s an equivalence class if: Every test using one element of the class tests the same thing that any other element of the class tests If an error is found with one element, it should be found with any element If an error is not found with some element, it is not found by any element Test a subset from each class

Exercise Consider a factorial function, fact(n): if n < 0 or n >= 200, error if 0  n  20, exact value if 20 < n < 200, approximate value within 0.1%. Q: What equivalence classes can you see?

Simple Example Suppose you are building an airline reservation system. A traveler can be a child, an adult, or a senior. The price depends on the type of traveler. The seat reservation does not depend on the type of traveler. Q: How many test cases can you identify for the reservation component and the billing component?

Heuristics for Finding Equivalence Classes Identify restrictions for inputs and outputs in the specification.

Heuristics for Finding Equivalence Classes Identify restrictions for inputs and outputs in the specification. If there is a continuous numerical domain, create one valid and two or three invalid classes (above, below, and NaN).

Heuristics for Finding Equivalence Classes Identify restrictions for inputs and outputs in the specification. If there is a continuous numerical domain, create one valid and two or three invalid classes (above, below, and NaN). If a number of values is required, create one valid and one or more invalid classes.

Heuristics for Finding Equivalence Classes Identify restrictions for inputs and outputs in the specification. If there is a continuous numerical domain, create one valid and two or three invalid classes (above, below, and NaN). If a number of values is required, create one valid and one or more invalid classes. If a set of values is specified where each may be treated differently, create a class for each element of the set and one more for elements outside the set.

Heuristics for Finding Equivalence Classes Identify restrictions for inputs and outputs in the specification. If there is a continuous numerical domain, create one valid and two or three invalid classes (above, below, and NaN). If a number of values is required, create one valid and one or more invalid classes. If a set of values is specified where each may be treated differently, create a class for each element of the set and one more for elements outside the set. If there is a condition, create two classes, one satisfying and one not satisfying the condition.

Exercise Define test cases for a program that reserves a golf tee time. The standard green fee is $65 on weekdays (Monday-Friday) and $80 on weekend (Saturday and Sunday). However, an El Paso resident pays a reduced green fee of $45 and $60 on weekdays and weekend, respectively. A senior (of age 60+) pays only $40 and $50 on weekdays and weekend, respectively. A junior (of age <17) pays only $20 and $30 on weekdays and weekend, respectively. Q: How many equivalence classes? Define them. Q: Define one test case per equivalence class.

Outline Basic concepts Black box testing White box testing Equivalence classes Boundary values Decision tables … White box testing

Boundary Values Observations Test the boundaries Programs that fail at interior elements of an equivalence class usually fail at the boundaries too. Programmers often make errors on boundary conditions (e.g., branch/loop condition x <= 10 instead of x < 10). Test the boundaries if it should work for 1-99, test 0, 1, 99, 100. if it works for A-Z, try @, A, Z, [, a, and z The hard part is identifying boundaries.

Hints If a domain is a restricted set, check the boundaries. e.g., D=[1,10], test 0, 1, 10, 11 It may be possible to test the boundaries of outputs, also. For ordered sets, check the first and last elements. For complex data structures, the empty list, full lists, the zero array, and the null pointer should be tested. Extremely large data sets should be tested. Check for off-by-one errors.

More Hints Some boundaries are not obvious and may depend on the implementation (use gray box testing if needed) Numeric limits (e.g., test 255 and 256 for 8-bit values) Implementation limits (e.g., max array size)

Example Consider a simple voltage stabilizer with an input range of 190-240 volts 50-60 hertz.

Example Consider a simple voltage stabilizer with an input range of 190-240 volts 50-60 hertz. Voltage boundaries 189 volts (below the lowest boundary) 190 volts (lowest boundary) 240 volts (highest boundary) 241 volts (above the highest boundary) Cycles (hertz) boundaries 49 hertz (below) 50 hertz (lowest) 60 hertz (highest) 61 hertz (above)

One extremes with others fixed. Example Consider a simple voltage stabilizer with an input range of 190-240 volts 50-60 hertz. Voltage boundaries 189 volts (below the lowest boundary) 190 volts (lowest boundary) 240 volts (highest boundary) 241 volts (above the highest boundary) Cycles (hertz) boundaries 49 hertz (below) 50 hertz (lowest) 60 hertz (highest) 61 hertz (above) How to combine? Exhaustive, Pairwise (later), One extremes with others fixed.

Exercise Determine the boundary values for US Postal Service ZIP codes (5 digits such as 79912 or 5 digits hyphen 4 digits such as 79912-1818). Determine the boundary values for a 15-character last name entry. Hints: Two kinds of boundaries---size boundary and value boundary.

Outline Basic concepts Black box testing White box testing Equivalence classes Boundary values Decision tables Pairwise testing State transitions Use cases White box testing

Decision Tables Construct a table (to help organize the testing) Identify each rule or condition in the system that depends on some input For each input to one of these rules, list the combinations of inputs and the expected results

Example Theater ticket prices are discounted for senior citizens and students. Test Case C1 Student? C2 Senior? Result Discount? 1 T 2 F 3 4

Exercise Construct a decision table for a program that reserves a golf tee time. The standard green fee is $65 on weekdays (Monday-Friday) and $80 on weekend (Saturday and Sunday). However, an El Paso resident pays a reduced green fee of $45 and $60 on weekdays and weekend, respectively. A senior (of age 60+) pays only $40 and $50 on weekdays and weekend, respectively. A junior (of age <17) pays only $20 and $30 on weekdays and weekend, respectively.

Pairwise Testing: Motivation Consider a website that must: operate correctly with different browsers: IE 5, IE 6, and IE 7; Mozilla 1.1; Opera 7; FireFox 2, 3, and 4, and Chrome. work using RealPlayer, MediaPlayer, or no plug-in. run under Windows ME, NT, 2000, XP, and Vista, 7.0, and 8.0 accept pages from IIS, Apache and WebLogic running on Windows NT, 2000, and Linux servers. How many different configurations are there?

Motivation Consider a website that must: operate correctly with different browsers: IE 5, IE 6, and IE 7; Mozilla 1.1; Opera 7; FireFox 2, 3, and 4, and Chrome. work using RealPlayer, MediaPlayer, or no plug-in. run under Windows ME, NT, 2000, XP, and Vista, 7.0, and 8.0 accept pages from IIS, Apache and WebLogic running on Windows NT, 2000, and Linux servers. How many different configurations are there? A: 9 browsers x 3 plug-ins x 7 OS’s x 3 web servers x 3 server OS’s = 1701 combinations

Motivation Many such examples (i.e., finite sets of discrete values). A bank is ready to test a data processing system Customer types: Gold, Platinum, Business, Non profits Account types: Checking, Savings, Mortgages, Consumer loans, Commercial loans States (with different rules): CA, NV, UT, ID, AZ, NM How many different configurations are there?

Approaches? When given a large number of combinations: Give up and don’t test Test all combinations: miss targets, delay product launch, and go out of business Choose one or two cases Choose a few that the programmers already ran Choose the tests that are easy to create List all combinations and choose first few List all combinations and randomly choose some “Magically” choose a small subset with high probability of revealing defects

Pairwise Testing Combinatorial testing technique in which every pair of input parameters of software is tested. Reasonable cost-benefit compromise Much faster than exhaustive testing More effective than less exhaustive methods that fail to exercise all possible pairs of input parameters Why? Majority of software failures are caused by a single input parameter or a combination of two input parameters. Each pair of input parameter values should be captured at least by one test case. However, finding the least number of test cases is an NP-complete problem.

Example Consider software that takes three input parameters, say x, y, and z. If each parameter can have three different values, then there will be 27 different pairs: (x1, y1), (x1, y2), …, (y3, z3). A test case (x1, y3, z2), for example, captures three of these 27 pairs: (x1, y3), (x1, z2), and (y3, z3). By selecting test cases judiciously, all pairs of input parameters can be exercised with a minimum number of test cases; e.g., a set of 9 test cases can capture all 27 pairs of three parameters, each with three different values.

State Transitions Use state transitions (e.g., UML state machine diagrams) to derive test inputs Cover a state transition diagram, e.g., Visit each state at least once Trigger each event at least once Exercise each transition at least once Exercise each path at least once* * Might not be possible.

Example and Exercise Customer makes a reservation and has a limited time to pay. May cancel at any time. printed Paid paid Ticketed ordered/ start timer Reserved delivered canceled canceled/ refund canceled/ refund timer expired Cancelled Used Unpaid Groups: How many tests to visit each state, trigger each event, exercise each transition, and exercise each path?

Use Cases Use the use cases to specify test cases Use case specifies both normal, alternate, and exceptional operations However, use cases may not have sufficient details, esp. for unit testing

Outline Basic concepts Black box testing White box testing Control flow graph (CFG) Statement coverage …

White Box Testing Test set is derived from structure of (source) code Also known as: Glass box testing Structural testing Often use a graph called a control flow graph (CFG) To represent code structure To cover it (CFG), e.g., all statements Input Output

Control Flow Graphs Programs are made of three kinds of statements: Sequence (i.e., series of statements) Condition (i.e., if statement) Iteration (i.e., while, for, repeat statements)

Control Flow Graphs Programs are made of three kinds of statements: Sequence (i.e., series of statements) Condition (i.e., if statement) Iteration (i.e., while, for, repeat statements) CFG: visual representation of flow of control Node represents a sequence of statements with single entry and single exit Edge represents transfer of control from one node to another

Control Flow Graph (CFG) Sequence If-then-else If-then Iterative

Control Flow Graph (CFG) Join Join Sequence If-then-else If-then Iterative When drawing CFG, ensure that there is one exit: include the join node if needed

Example 1. read (result); 2. read (x,k) 3. while result < 0 { 5 6 7 9 8 2 1 4 1. read (result); 2. read (x,k) 3. while result < 0 { 4. ptr  false 5. if x > k then 6. ptr  true 7. x  x + 1 8. result  result + 1 } 9. print result

Example 1. read (result); 2. read (x,k) 3. while result < 0 { 5 6 7 9 8 2 1 4 1,2 1. read (result); 2. read (x,k) 3. while result < 0 { 4. ptr  false 5. if x > k then 6. ptr  true 7. x  x + 1 8. result  result + 1 } 9. print result 3 9 4,5 6 Join 7,8

Exercise: Draw CFGs Example 1 if (a < b) then while (a < n) 3. a  a + 1; 4. else 5. while (b < n) 6. b  b + 1; Example 2 1. read (a, b); 2. if (a  0 && b  0) then { 3. c  a + b; if c > 10 then c  max; else c  min; } 7. else print ‘Done’; Example 3 1. read (a, b); 2. if (a  0 || b  0) then { 3. c  a + b; 4. while( c < 100) 5. c  a + b; } 6. c  a * b;

Outline Basic concepts Black box testing White box testing Control flow graph (CFG) Statement coverage Branch coverage Condition coverage Path coverage …

Coverage Coverage-based testing Control-flow coverage Adequacy of testing in terms of the coverage of the product to be tested, e.g., the percentage of statements executed or the percentage of functional requirements tested. Control-flow coverage Statement Branch Condition Path Data-flow coverage Def-use

Statement Coverage Every statement gets executed at least once Every node in the CFG gets visited at least once, also known as all-nodes coverage

Example Q: Number of paths needed for statement coverage? 1 6 1 6 2 7 3 8 3 8 4 9 4 9 5 5

Branch Coverage Every decision is made true and false. Every edge in a CFG of the program gets traversed at least once. Also known as Decision coverage All edges coverage Basis path coverage Branch is finer than statement. C1 is finer than C2 if T1  C1  (T2  C2  T2  T1) true false

Example Q: Number of paths needed for branch coverage? 1 6 1 6 2 7 2 7 3 8 3 8 4 9 4 9 5 5

Condition Coverage Make each Boolean sub-expression (called a condition) of a decision evaluated both to true and false Example: if (x > 0 || y > 0) { … } else { … } C1: x > 0, x  0 C2: y > 0, y  0 Q: How many tests?

Many Variances of Condition Coverage Condition coverage is not finer than branch coverage. There are pathological cases where you can achieve condition and not branch. E.g., if (x > 0 || y > 0) { … } (x = 10, y = 0), (x = 0, y = 10): condition but not branch Under most circumstances, achieving condition achieves branch Many variances, e.g., Multiple condition Condition/decision Modified condition/decision (MC/DC)

CFG for Condition Coverage One way to determine the number of paths is to break the compound conditional into atomic conditionals Suppose you were writing the CFG for the assembly language implementation of the control construct if (A AND B) then C endif (short circuit eval) (no short circuit eval) LD A LD A ; in general, lots of BZ :endif LAND B ; code for A and B LD B BZ :endif BZ :endif JSR C JSR C :endif nop :endif nop

AND Condition 1 2A 2B 4 3 Join 1. read (a, b); 2. if (a == 0 && b == 0) then { 3. c  a + b; } 4. else c  a * b; paths: 1, 2A,2B,3, J 1, 2A, 2B, 4, J 1, 2A, 4, J 2A true false 2B 4 true false 3 Join

OR Condition 1 2A 3 2B 4 5 Join 1. read (a,b); 2. if (a == 0 || b == 0) then { 3. c  a + b; 4. while( c < 100) 5. c  a + b;} Paths: 1, 2A, 3, 4, 5, 4 … J 1, 2A, 3, 4, J 1, 2A, 2B, 3, 4, 5, 4, … J 1, 2A, 2B, J 2A true false 3 2B true false 4 5 Join

Outline Basic concepts Black box testing White box testing Control flow graph (CFG) Statement coverage Branch coverage Condition coverage Path coverage Def-use coverage

Path Coverage Every distinct path through code is executed at least once. All-paths coverage similar to exhaustive testing A path is a sequence of: Statements Branches Edges

Example 1,2,3 4,5 6 Test Paths: 1, 2, 3, 4, 5, J1, 7, 8, J2 Join1 1. read (x) 2. read (z) 3. if x  0 then { 4. y  x * z; 5. x  z; } 6. else print ‘Invalid’; 7. if z > 1 then 8. print z; 9. else print ‘Invalid’; Test Paths: 1, 2, 3, 4, 5, J1, 7, 8, J2 1, 2, 3, 4, 5, J1, 7, 9, J2 1, 2, 3, 6, J1, 7, 8, J2 1, 2, 3, 6, J1, 7, 9, J2 1,2,3 4,5 Join1 6 7 8 Join2 9 P353 Pfleeger 2nd ed 67

Linearly Independent Paths It is not feasible to calculate the total number of paths. It is feasible to calculate the number of linearly independent paths: A complete path which, disregarding back tracking (such as loops), has an unique set of decisions in a program. Any path through the program that introduces at least one new edge that is not included in any other linearly independent paths. The number of linearly independent paths is the number of end-to-end paths required to touch every path segment at least once.

McCabe’s Cyclomatic Complexity Software metric for the logical complexity of a program Defines the number of independent paths in the basis set of a program (basis set: maximal linearly independent set of paths). Provides the upper bound for the number of tests that must be conducted to ensure that all statements have been executed at least once. For edges (E) and nodes (N), cyclomatic complexity number V is: V = E – N + 2

Example: Complexity of CFG 3,4 3,4 1 1 5 5 6 2 Join Join 3 N = 1 E = 0 V = E - N + 2 = 0 - 1 + 2 = 1 N = 3 E = 2 V = E - N + 2 = 2 – 3 + 2 = 1 N = 4 E = 4 V = E - N + 2 = 4 - 4 + 2 = 2 N = 3 E = 3 V = E - N + 2 = 3 - 3 + 2 = 2

Example 1 2,3 6 4,5 8 7 9 10 11 V = 11 – 9 + 2 = 4 Independent paths: 1-11 1-2-3-4-5-10-1-11 1-2-3-6-8-9-10-1…-11 1-2-3-6-7-9-10-1…-11

Exercise: Cyclomatic Complexity 3 4,5 6 Join 9 7,8 1,2 1,2 Join 3,4 5 6 7 1, 2 3 Join 4 5 6 1 2 3 Join 5 6

Linearly Independent Path Coverage Cyclomatic-number criterion: construct a test set such that all linearly independent paths are covered. 1. read (x) 2. read (z) 3. if x  0 then { 4. y  x * z; 5. x  z; } 6. else print ‘Invalid’; 7. if z > 1 then 8. print z; 9. else print ‘Invalid’; Cyclomatic complexity: 3 (= 9 – 8 + 2) Test Paths: 1, 2, 3, 4, 5, J1, 7, 8, J2 1, 2, 3, 4, 5, J1, 7, 9, J2 1, 2, 3, 6, J1, 7, 8, J2, 1,2,3 4,5 Join1 6 7 8 Join2 9 P353 Pfleeger 2nd ed 73

Outline Basic concepts Black box testing White box testing Control flow graph (CFG) Statement coverage Branch coverage Condition coverage Path coverage Def-use coverage

Data Flow Coverage Consider how variables are treated along the various paths, a.k.a. data flow analysis, e.g., definitions and uses. Many variations All-defs-uses All-defs All-uses All-C-uses/Some-P-uses All-P-uses/Some-C-uses All-P-uses * P-uses are predicate uses, e.g., in conditions; all others are C-uses.

Def-Use Coverage Def-use coverage: every path from every definition of every variable to every use of that definition is exercised in some test. 1. read (x); 2. read (z); 3. if x  0 then { 4. y  x * z; 5. x  z; } 6. else print ‘Invalid’; 7. if y > 1 then 8. print y; 9. else print ‘Invalid’; Test Path: 1, 2, 3, 4, 5, 7, 8, J D: x, z U: x 1,2,3 U: x, z D: y, x 4,5 6 U: none Join 7 U: y 8 U: y 9 U: none Join

Strength of Coverage Statement Arrows point from weaker to stronger coverage. Stronger coverage requires more test cases. Branch Def-Use Condition Path

Limitation of Paths What they don’t tell you: Timing errors Unanticipated error conditions User interface inconsistency (or anything else) Configuration errors Capacity errors