800 likes | 1.3k Views
Csci 565 Fall 2012. Data Flow Testing. Objectives. Define/Use Testing DU-Path Test Coverage Metrics Example Commission problem. Test coverage criteria. The main focus is structural testing Data flow Control flow Test coverage criteria?
E N D
Csci 565 Fall 2012 Data Flow Testing
Objectives • Define/Use Testing • DU-Path Test Coverage Metrics • Example Commission problem
Test coverage criteria • The main focus is structural testing • Data flow • Control flow • Test coverage criteria? • A minimal set of test requirements (e.g. p0, p1, etc.) that must be collectively exercised by the test cases when we execute the program
Test Coverage criteria • Control flow Coverage Criteria • All-nodes • All-edges • All-paths
Informal Definitions of The DF Testing • Refers to the form of structural testing (or path testing) • used for compiler optimization • Attempts to “bridge the gap” between branch testing and path testing • Suffers from un-executable paths (infeasible paths) • Focus on the locations (i.e., statements) where variables are defined and used • A definition (value is stored in MM) • A Use (a value is fetched from MM) • It is different from Data Flow Diagrams (DFD)
Data flow analysis (DFA)’s anomalies • Detects Defines/reference anomalies, such as • A variable that is defined but never used • (unused variable) • A variable that is used but never defined • (undefined variable) • A variable that is defined twice before it is used • (redundant operations) • Data reads from location not previously written to • (uninitialized variables) • The anomalies can be discovered by “static analysis”
Define/Use Testing • Early work was done in 1980s by [Rapps 85] • The research adopts the formalization of program graph in which • Nodes correspond to program statements • Edges correspond to the flow of information • Single entry and single exist points • No self-looping nodes
Defining node? • Node n G(P) is a defining node of the variable v V, written as DEF(v, n), • iff the value of the variable v is defined at the statement fragment corresponding to node n • G(P) represents Flow Graph of Program P
Example of defining statements • Defining Statements include • Input statements (e.g., read) • Assignments statements • Loop control statements • Procedure calls • When the code corresponding to the above statements executes, the contents of the memory locations related to the variables are changed
Usage node of the variable v • Node n G(P) is a usage node of the variable v V, written as USE(v, n), iff • the value of the variable v is used at the statement fragment corresponding to node n
Example of Usage statements • Usage Statements include • Output statements (e.g., write) • Assignments statements (r.h.s.) • Conditional statements • Loop control statements • Procedure calls • When the code corresponding to the above statements executes, the contents of the memory locations related to the variables are unchanged
Predicate use:(P-use) • A usage node USE(v, n) is either • a predicate use (denoted by P-use) • Or, a computation use (denoted by C-use) • The nodes corresponding to P-use have out-degree 2 • The nodes corresponding to C-use always have outdegree 1
Definition-use (sub)path • A definition-use (sub)path w.r.t. a variable v (denoted du-path) is a (sub)path in PATHS(P) such that for some vV, there exist both defined and usage nodes such that • DEF(v, m) • USE(v,n) • Where • m is initial node • n is final nodes
Definition-clear(dc-path) • A definition-clear(sub)path w.r.t. a variable v is a DU(sub)path in PATHS(P) with initial and final nodes DEF(v, m) and USE (v, n) such that no other node in the (sub)path is a defining node of v • DF testing • Requires that the test data execute dc-path from each node containing a global definition of a variable to specified nodes containing global c-uses and edge containing p-uses of that variable
The significant of DU-Paths and DC-Paths • Du-paths and dc-paths capture the essence of computing with stored data values • Du-Paths and dc-Paths describe the flow of data across source statements from the locations where the values are defined to the locations where the values are used • Du-paths that are not Dc-paths are considered as problematic spots
About VAR and CONST • VAR and CONST declaration • Should they be considered as defining nodes? • Yes and no
Example: The Commission problem discussed in [Jorgenson95] • The Commission Problem Statement • Rifle salesperson in the Arizona Territory sold rifle locks, stocks, and barrels made by a gunsmith in Missouri. Locks cost $45.00, stocks cost $30.00, and barrels cost $25.00. Salespersons had to sell at least one complete rifle per month, and production limits are such that the most one salesperson could sell in one month is 70 locks, 80 stocks, 90 barrels. Each rifle salesperson sent a telegram to the Missouri company with the total order for each town s/he visits; salespersons visit at least on town per month, but travel difficulties made ten towns the upper limit. At the end of each month, the company computed commission as follows: • 10% on sales up to $1000 • 15% on the next $800 • 20% on any sales in excess of $1800. • The company had four salespersons. The telegram from each salesperson were sorted into piles (by person) and at the end of each month a data file is prepared, containing the salesperson's name, followed by one line for each telegram order, showing the number of locks, stocks, and barrels in that order. At the end of the sales data lines, there is an entry of “-1” in the position where the number of locks would be to signal the end of input for that salesperson. The program produces a monthly sales report that gives the salesperson’s name, the total number of locks, stocks, and barrels sold, the salesperson's total dollar sales, and finally his/her commission.
Some Du-paths • Stocks variable • DEF(stocks, 25) • USE(stocks, 27) • DuPath • P0=<25, 27> • Dc-Path • P0=<25,27> • Locks variable • DEF(locks,22) • DEF(locks, 29) • USE(locks,23) • Use(locks,26) • Du-path • p1=<22,23> • p2=<22,23,24,25,26> (begin the loop) • P3=<29,30,23> • p4=<29,30,23,24,25,26> (repeat the loop) • p1’=<22,23,31> (by pass the loop) • p3’=<29,30,23,31> (exist the loop) • Dc-paths • p1,p2,p3,p4,p1’,p3’ • Complete set of test cases for the WHILE-loop: p1’, p2, p3’, p4
DU-paths w.r.t. num_locks • DU-Paths w.r.t. num_locks • Used in computational uses (c-uses) • Defining nodes • DEF(num_locks,19) • DEF(num_locks,26) • Usage nodes • USE(num_locks,26) • USE(num_locks,33) • USE(num_locks,36) • DU-paths • P5=<19,20,21,22,23,24,25,26> (dc-path) • P6=<19,20,21,22,23,24,25,26, 26, 27,28,29,30,31,32,33> (NOT dc-path) • Corrected p6 • P6=<19,20,21,22,23,24,25,26, 27,28,29,30,31,32,33> • p7 = <19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36) • p7 can also be rewritten as P7= <p6,34,35,36> (NOT dc-path because it contains node 26) • P8=<26,27,28,29,30,31,32,33> (subpath of p7; dc-path) • P9=<26,27,28,29,30,31,32,33,34,35,36> (subpath of p7; dc-path)
DU-paths w.r.t. sales • Du-paths w.r.t. sales • ONLY one defining node for sales (i.e. the paths are dc-paths) • p10=<36,37> • p11=<36,37,38,39> • p12=<36,37,38,39,40,41,42,43> • Look at IF, ELSE IF (statements 39-50) • p13=<36,37,38,39,45,46,47,48> • p14=<36,37,38,39,45,50>
DU-paths w.r.t. Commission • Du-paths w.r.t. Commission • Consider only du-paths that begin with three “real” defining nodes for commission • p15 =<43,51> • p16=<48,51> • p17=<50,51> • Table 4 shows the full set of du-paths
DU-PATH TEST Coverage Metrics (or Rapps-Weyuker dataflow criteria) • Idea behind analyzing a program is to define a set of test coverage (AKA the Rapps-Weyuker DF criteria) • ALL-paths • All-edges • All-nodes • All-Defs • All-Uses • All P-Uses/Some C-Uses • ALL-C-Uses/Some P-Uses • All-DU-paths
ALL-Defs • The set T Satisfies the All-Defs criterion for the program P iff • for every variable vV, T contains dc-paths from every defining node of v to at least one use of v where • V: a set of variables • T: a set of (sub)paths in G(P) of a program P
ALL-Uses • The set T Satisfies the All-Uses criterion for the program P iff • for every variable vV, T contains dc-paths from every defining node of v to ALL possible use of v • where • V: a set of variables • T: a set of (sub)paths in G(P) of a program P
ALL-P-Uses/Some C-Uses • The set T Satisfies the All-P-Uses/Some C-Uses criterion for the program P iff • for every variable vV, T contains dc (sub)paths from every defining node of v to every predicate use of v , and if a definition of v has no P-uses, there is a definition-clear path to at least one computation use • where • V: a set of variables • T: a set of (sub)paths in G(P) of a program P
ALL-C-Uses/Some P-Uses • The set T Satisfies the All-P-Uses/Some C-Uses criterion for the program P iff for every variable vV, T contains definition clear (sub)paths from every defining node of v to every use of v , and if a definition of v has no C-uses, there is a definition-clear path to at least one predicate use • where • V: a set of variables • T: a set of (sub)paths in G(P) of a program P
All-DU Paths • The set T Satisfies the All-DU paths criterion for the program P iff for every variable vV, T contains definition clear (sub)paths from every defining node of v to all possible du-paths
In class Quiz 1 read x x<0 x>=0 2 3 y:=0 y:= 2 4 Even x Odd x 5 6 Z:= 1 z:= 3 67 code:= y+z Print code Identify paths according to: All-def, All-uses, and All-du-paths
Part 2: Sliced Based Testing
Slice Based Testing (SBT) • Originally proposed by [Weiser 88]and [Gallagher 91] in software maintenance • Useful for • Software Debugging • Software Maintenance • Program understanding • Quantification of functional cohesion
What is Program Slicing? • A decomposition technique • decomposes a program in terms of computational behaviors by extracting interested behavior which are represented as the values of some sets of variables at some set of statements. • S<v, n> is called slicing criteria • Has the added advantage of being executable • Finding slice is in general unsolvable
Example Fig. b.1) deletes those statements from the program which have no effect upon the semantics (value) of product
Formal definition of SBT (Slicing Criterion) • Given a program P, a program graph G(P) in which statements and/or statement fragments are numbered, and a set V of variables in P, the slice on the variable set V at statement n, S(V,n) as follows • the set node numbers of all statements fragments in P prior to n that contribute to the values of variables in V at statement fragment n
Alternative definition: Program Slice • For statement s and variable v, the slice of program P w.r.t. the slicing criterion <s, v > includes only those statements of P needed to contribute to the behavior of v at s.
example • 1 y := x • 2 z := y • S(z,2)={y,x} • The value of x before the first statement can contribute (affect) the value of z after second
The notion of contribution: USE • The notion of contribution can be described by the USE relationship (e.g., C-use and P-use) • P-use: used in a predicate (decision) • C-use: used in computation (assignment) • O-use: used for output (write/print, etc.) • L-use: used for location (e.g., pointers/subscripts) • I-use: iteration (e.g., internal counter)