KEMBAR78
Dynamic Testing | PDF | Software Testing | Control Flow
0% found this document useful (0 votes)
36 views76 pages

Dynamic Testing

Dynamic testing refers to analyzing code's dynamic behavior in the software. In this type of testing, you have to give input and get output as per the expectation through executing a test case. You can run the test cases manually or through an automation process, and the software code must be compiled and run for this.

Uploaded by

sadimula
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PPTX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
36 views76 pages

Dynamic Testing

Dynamic testing refers to analyzing code's dynamic behavior in the software. In this type of testing, you have to give input and get output as per the expectation through executing a test case. You can run the test cases manually or through an automation process, and the software code must be compiled and run for this.

Uploaded by

sadimula
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PPTX, PDF, TXT or read online on Scribd
You are on page 1/ 76

Module-2: Dynamic Testing

Syllabus
▪ Black-Box testing: Boundary value analysis, equivalence class
testing.
▪ White-box testing: Introduction, basis path testing, loop
testing.
▪ Static testing: inspections, structured walkthroughs, technical
reviews.

2
Black Box Testing Introduction
▪ Important technique in dynamic testing

▪ considers only the functional requirements of the software

▪ structure or logic of the software is not considered.

▪ It is also known as functional testing.

▪ Test cases are designed based on functional specifications.

▪ Input test data are checked against expected outputs

▪ It look for interface errors

▪ test the system behaviour and check its performance


▪ test the maximum load or stress on the system
3
Black Box Testing

4
Boundary Value Analysis (BVA)
▪ Test cases designed with boundary input values have a high chance to find
errors.
▪ BVA uncovers the bugs at the boundary of input values.
▪ Boundary means the maximum or minimum value

5
Boundary Value Analysis : Boundary value Checking

6
Boundary value checking

7
Boundary value analysis: Robustness Testing Method

BVC can be extended such that boundary values are exceeded

A value just greater than the Maximum value (Max+)

A value just less than Minimum value (Min−)

▪ It can be generalized that for n input variables in a module, 6n + 1 test cases can be designed
with robustness testing

▪ Add the following test cases to the list of 9 test cases designed in BVC

8
Boundary value analysis: Worst-case Testing Method

Extend the concept of BVC by assuming more than one variable on the
boundary. It is called worst-case testing method.

It can be generalized that for n input variables in a module, 5n (power )test

cases can be designed with worst-case testing.

9
Boundary value analysis: Worst-case Testing Method

10
Boundary value analysis: Example 1

program reads an integer number within the range [1,100] and determines whether it is a prime
number or not. Design test cases for this program using BVC, robust testing, and worst-case
testing methods

Test cases using BVC Since there is one variable, the total number of test cases
will be 4n + 1 = 5.
Test cases using worst-case testing Since there is one variable, the total
number of test cases will be 5n = 5. Therefore, the number of test cases will be
same as BVC.
11
Module 1 Syllabus

12
Boundary value analysis :Example 2

A program computes ab (a power b) where a lies in the range [1,10] and b within [1,5]. Design test

cases for this program using BVC, robust testing, and worst-case testing methods.

Solution

Test cases using BVC Since there are two variables, a and b, the total number of test cases will be

4n + 1 = 9. The set of boundary values is shown below:

13
Boundary value analysis Example 2

14
Boundary value analysis Example 2

15
Boundary value analysis: Example 2

▪ Test cases using worst-case testing Since there are


two variables, a and b, the total number of test cases will
be 5n = 25.

16
Boundary value analysis: Example 2

17
Equivalence Class Testing
▪ classes of input conditions called equivalence classes are identified

▪ each member of the class causes the same kind of processing and output to occur.

▪ only one test case is chosen from one class.

▪ testing covers the whole input domain

▪ It reduces the total number of test cases.

▪ get a good hit rate to find maximum errors with the smallest number of test cases.

▪ To use equivalence partitioning, one needs to perform two steps:

▪ 1. Identify equivalence classes

▪ 2. Design test cases

18
Equivalence partitioning method Goals

▪ Completeness we strive to touch the completeness of testing domain.

▪ Non-redundancy When the test cases are executed from the same class redundancy in executing the test
cases is reduced.
▪ Time and resources are not wasted

19
IDENTIFICATION OF EQUIVALENT CLASSES

▪ Two types of classes can always be identified

▪ Valid equivalence classes These classes consider valid inputs to the program.

▪ Invalid equivalence classes One must not be restricted to valid inputs only.

▪ We should also consider invalid inputs that will generate error conditions or unexpected
behaviour of the program

20
Guidelines for forming equivalence classes
▪ range should be split into two or more equivalence classes.

▪ If a program handles each valid input differently

▪ Boundary value analysis help in identifying the classes.

▪ If an input variable can identify more than one category, then for each category, we can make
equivalent classes.

▪ For example: if the input is a character, alphabet, a number, or a special character. So we can
make three valid classes for this input and one invalid class.

Guidelines for identify test cases through generated equivalence classes:

▪ Assign a unique identification number to each equivalence class.

21
Equivalence Class Testing

22
Equivalence Class Testing

23
Equivalence Class Testing

24
Dynamic Testing: White-Box Testing Techniques

▪ It is also known as glass-box testing/ structural or development testing.

▪ design, structure, and code of the software have to be studied for this type of testing.

▪ developer is very close to this type of testing.

▪ Developers use white-box testing techniques to test their own design and code

▪ white-box testing ensures that the internal parts of the software are adequately tested

▪ demands complete understanding of the program logic/ structure

25
Dynamic Testing: White-Box Testing Techniques

▪ Basis path testing method

▪ Loop testing

▪ Data flow testing method

▪ Some typographical errors are detected

▪ Errors which have come from the design phase

▪ logical path

▪ portions in the code

26
Basis Path Testing
▪ oldest structural testing technique.
▪ based on the control structure of the program. a flow graph is prepared all the possible paths can
be covered and executed during testing.
▪ Path coverage is a more important for detecting more errors.
▪ programs that contain loops may have an infinite number of possible paths
The guidelines for effectiveness of path testing are discussed below:
▪ It is based on control structure of the program for which flow graph is prepared.
▪ It requires complete knowledge of the program’s structure.
▪ It is closer to the developer
▪ path testing effectiveness reduces with the increase in size of software
27
▪ Choose enough paths in a program such that maximum logic coverage is achieved.
Control Flow Graph
▪ A simplified, abstract, and graphical representation of a program’s control structure using process
▪ blocks, decisions and junctions
▪ Process Block:
▪ A sequence of program statements uninterrupted by decisions or junctions with a single entry and
▪ single exit.
▪ Junction:
▪ A point in the program where control flow can merge (into a node of the graph)
▪ Examples: target of GOTO
▪ Decisions:
▪ A program point at which the control flow can diverge (based on evaluation of a condition).
▪ Examples: IF stmt. Conditional branch and Jump instruction.
▪ Case Statements:
▪  A Multi-way branch or decision.
▪  Examples: Case/Switch
28
▪ For test design, Case statement and decision are similar
Control Flow Graph

29
Control Flow Graph

▪ A directed graph (V, E) consists of a set of vertices V and a set of


edges E that are ordered pairs of elements of V. Based on the
concepts of directed graph, following notations are used for a flow
graph:
▪ Node : It represents one or more procedural statements. The
nodes are denoted by a circle. These are numbered or labeled.
▪ Edges or links: They represent the flow of control in a program.
This is denoted by an arrow on the edge. An edge must terminate
at a node.
▪ Decision node A node with more than one arrow leaving it is
called a decision node.
▪ Junction node A node with more than one arrow entering it is 30
called a junction.
Flow Graph Notations For Different Programming Constructs

▪ flow graph is prepared on the basis of control structure of a program,

▪ Sequential statements having no conditions

▪ flow graph is also known as decision-to-decision-graph or DD graph.

31
PATH TESTING TERMINOLOGY
▪ Path is a sequence of statements starting at an entry, junction or decision and ending at another,
or possibly the same junction or decision or an exit point.
▪ Link is a single process (block) in between two nodes.
▪ Node is a junction or decision.
▪ Segment is a sequence of links. A path consists of many segments.
▪ Path segment is a succession of consecutive links that belongs to the same path. (3,4,5)
▪ Length of a path is measured by number of links in the path or number of nodes traversed.
▪ Name of a path is the set of the names of the nodes along the path. (1,2,3 4,5, 6)
▪ (1,2,3,4, 5,6,7, 5,6,7, 5,6)
▪ Independent path introduces at least one new set of processing statements or new conditions.
▪ An independent path must move along at least one edge that has not been
▪ traversed
32
Cyclomatic Complexity
▪ measure the complexity by considering the number of paths in the control
graph of the program
▪ for simple programs, if they contain at least one cycle, the number of paths is
infinite
▪ considers only independent paths.
▪ there are six possible paths: acei, acgh, acfj, bdei, bdgh, bdfj.
▪ the number of independent paths is given by
▪ V(G) = e – n + 2
▪ where n is the number of nodes and e is the number of arcs/edges.

33
Cyclomatic Complexity
▪ cyclomatic number of a program can be calculated by knowing the number of decision nodes d in the
program. It is given by

▪ V(G) = d + 1 This is also known as Miller’s theorem.


▪ program may contain several separate flow graphs
▪ The cyclomatic number of the whole graph is then given by the sum of the numbers of each graph (P)

34
Formulae Based on Cyclomatic Complexity
Cyclomatic complexity number can be derived through any of the following three formulae

V(G) = e – n + 2p

V(G) = d + p

V(G) = number of regions in the graph

▪ E is number of edges, n is the number of nodes

▪ d is the number of decision nodes in the graph.

Calculating the number of decision nodes for Switch-Case/Multiple If-Else

▪ When a decision node has exactly two arrows leaving it, then we count it as a single decision node

▪ switch-case and multiple if-else statements

▪ d = k – 1, where k is the number of arrows leaving the node 35


Formulae Based on Cyclomatic Complexity

▪ Calculating the cyclomatic complexity number of the program having many connected

components

▪ Let us say that a program P has three components: X, Y, and Z. Then we prepare the flow graph for P

and for components, X, Y, and Z. The complexity number of the whole program is

▪ V (G ) = V (P ) + V (X ) + V (Y ) + V (Z )
Guidelines for Basis Path Testing

▪ Draw the flow graph using the code provided for which we have to write test cases.

▪ Determine the cyclomatic complexity of the flow graph.

▪ Cyclomatic complexity provides the number of independent paths.

▪ It provides the base for designing the test cases.

▪ choose the data such that this path is executed.

37
Basis Path Testing Example

38
Basis Path Testing Example

39
Basis Path Testing Example

40
Basis Path Testing Example

41
Module 1 Syllabus

42
Applications Of Path Testing

▪ Thorough testing / More coverage Path testing provides us the best code coverage,
leading to a thorough testing. Path coverage is considered better as compared to
statement or branch coverage

▪ Path testing is mainly used for structural testing of a module

▪ Unit testing path testing uncovers these errors in module testing and prepares them for
integration

▪ Integration testing Since modules in a program may call other modules or be called by
some other module

▪ Path testing analyses all the paths on the interface and explores all the errors

▪ Maintenance testing path testing is still able to detect any security threats on the
43
interface with the called modules.
Loop testing
▪ Loop testing can be viewed as an extension to branch coverage.
▪ Sufficient test cases should be designed to test every loop thoroughly.
▪ There are four different kinds of loops

44
Nested loops

▪ Nested loops When two or more loops are embedded, it is called a nested loop,

▪ The strategy is to start with the innermost loops while holding outer loops to their minimum values.

▪ Continue this outward in this manner until all loops have been covered

45
Concatenated loops

Two loops are concatenated if it is possible to reach one after exiting the other, while still on a path from entry
to exit.

▪ If the two loops are not on the same path, then they are not concatenated.

Unstructured loops

It is really impractical to test and they must be redesigned

or at least converted into simple or concatenated loops.

46
Inspections
▪ Inspection process is an in-process manual examination of an item to detect bugs.

▪ It may be applied to any product or partial product of the software development process, including
requirements, design and code, project management plan, SQA plan, software configuration plan risk
management plan, test cases, user manual, etc.

▪ An inspection process involves the interaction of the following elements:

▪ Inspection steps

▪ Role for participants

▪ Item being inspected


Inspections: Inspection Team
minimum of the following four team members are required.

Author/Owner/Producer A programmer or designer responsible for producing the program or document.

▪ responsible for fi xing defects discovered during the inspection process.

Inspector. he is not a manager or supervisor.

▪ He finds errors, omissions, and inconsistencies in programs and documents.

Moderator manages the whole inspection process

He schedules, leads, and controls the inspection session.

▪ He is the key person with the responsibility of planning and successful execution of the inspection.

Recorder One who records all the results of the inspection meeting.
Inspections: Inspection Process
Inspections: Planning
▪ The product to be inspected is identified.

▪ A moderator is assigned.

▪ The objective of the inspection is stated eg: defect detection,

moderator performs the following activities:

▪ Assures that the product is ready for inspection

▪ Selects the inspection team and assigns their roles

▪ Schedules the meeting venue and time

▪ Distributes the inspection material like checklists


Inspections: Overview

▪ Inspection team is provided with the background information for inspection.

▪ The author presents product function and intended use

▪ The opening meeting may also be called by the moderator.

▪ every member is familiar with the overall purpose of the inspection.


Inspections: Individual preparation

▪ potential errors or problems found are recorded in log.

▪ log is then submitted to the moderator.

▪ Checklists are used during this stage

▪ inspectors record the defects

▪ The moderator reviews the logs

▪ checks for trouble spots that need extra attention

▪ the compiled log file is submitted to the author.


Inspections: Inspection meeting

▪ inspection meeting starts with the author of the inspected item who has created it.

▪ The author first discusses every issue raised by different members in the compiled log fi le

▪ After the discussion, all the members arrive at a conclusion issues pointed out are errors /admitted by the
author.

▪ during the discussion on any issue, another error is found.

▪ Then new error is recorded as an error by the author.

▪ The author should not be attacked by other

▪ meeting remains focused towards its objective

▪ moderator concludes the meeting

▪ moderator produces a summary of the inspection meeting.


Inspections: Rework

▪ The summary list of the bugs needs to be reworked by the author.

▪ The author fi xes all these bugs and reports


Inspections : Follow-up

▪ moderator prepares a report and ascertains that all issues have been resolved.

▪ The document is then approved for release.

▪ the unresolved issues are mentioned in a report

▪ another inspection meeting is called by the moderator.


Inspections: Benefits Of Inspection Process
▪ Bug reduction

▪ Bug prevention

▪ Productivity

▪ Real-time feedback to software engineers

▪ Reduction in development resource

▪ Quality improvement

▪ Project management

▪ Checking coupling and cohesion

▪ Learning through inspection

▪ Process improvement

▪ Finding most error-prone modules


Inspections: Benefits Of Inspection Process
Inspections: Distribution of error-types
Inspections: Effectiveness Of Inspection Process
▪ effectiveness of the inspection process lies in its rate of
inspection
▪ If the rate is very fast, it means the coverage of item to be
evaluated is high.
▪ Similarly if the rate is too slow, it means that the coverage is
not much
Inspections: COST OF INSPECTION PROCESS

▪ inspection itself takes about an hour and that each member spends 1-2 hours
preparing for the inspection.
▪ Testing costs are variable and depend on the number of faults in the software.
▪ cost of inspection can be 5–10% of the total cost of the project.
Inspections: Variants Of Inspection Process
Inspections: Active Design Reviews

▪ inspecting the design stage of SDLC.

▪ reviews are conducted targeting a particular type of bugs

▪ it covers all the sections of the design document

▪ use of questionnaires to give the reviewers active role.


Inspections: Active Design Reviews
▪ Overview brief overview of the module being reviewed is presented.

▪ overview explains the modular structure

▪ Review Reviewers are assigned sections of the document to be reviewed

▪ questionnaires based on the bug type.

▪ They are also assigned a timeframe

▪ Meeting The designers read the completed questionnaires

▪ reviewers to resolve any queries that the designers may have

▪ This interaction continues until both designers and reviewers understand the issues

▪ an agreement on these issues is documented


Inspections: Formal Technical Asynchronous Review Method ( FTArm)

▪ online version of the document is made available to every member where they can add their comments
and point out the bugs.
▪ This process consists of the following steps
▪ Setup It involves choosing the members and preparing the document for an asynchronous inspection
process
▪ Orientation It is same as the overview step
▪ Private review each reviewer or inspector individually gives his comments on the document being
inspected.
▪ Public review In this step, all comments provided privately are made public
▪ Consolidation moderator analyses the result of private and public reviews and lists the fi ndings and
unresolved issues
▪ Group meeting unresolved issues are discussed
▪ decision to conduct a group meeting is taken
▪ Conclusion The final report of the inspection process along with the analysis is produced by the
moderator.
Gilb Inspection

Three different roles are defi ned in this type of inspection:

Leader is responsible for planning and running the inspection.

Author of the document

Checker is responsible for fi nding and reporting the defects in the document.
Gilb Inspection
▪ Entry The document must pass through an entry criteria
▪ Planning The leader determines the inspection participants and schedules the meeting.
▪ Kick-off The relevant documents are distributed
▪ participants are assigned roles
▪ Briefed about the agenda of the meeting.
▪ Checking Each checker works individually and fi nds defects.
▪ Logging Potential defects are collected and logged.
▪ Brainstorm In this stage, process improvement suggestions are recorded
▪ Edit After all the defects have been reported
▪ Follow-up The leader ensures that the edit phase has been executed
▪ properly.
▪ Exit The inspection must pass the exit criteria
N-Fold Inspection
▪ Planning and overview This is the formal planning and overview stage.

▪ it includes the planning

▪ Inspection stages There are many inspection processes adopted by many

▪ teams.

▪ The team is free to adopt any process.

▪ Collation phase The results from each inspection process are gathered, collated,
and a master list of all detected defects is prepared.

▪ Rework and follow-up This step is same as the tradition Fagan inspection process
N-Fold Inspection
Phased Inspection
▪ There are two types of

▪ Single inspector rigorous checklist is used by a single inspector

▪ verifies whether the features specifi ed are there in the item to be inspected.

▪ Multiple inspector Here, a checklist cannot be used.

▪ Item cannot be verifi ed

▪ There are many inspectors who are distributed

▪ Each inspector examines this information

▪ After individual checking by the inspectors, a reconciliationmeeting is organized where inspectors


READING TECHNIQUES

▪ It is defi ned as a series of steps or procedures whose purpose is to guide an inspector to acquire a
deep understanding of the inspected software product

▪ Adhoc Method

▪ Checklist

▪ Scenario-based reading

▪ Perspective-based reading

▪ Usage-based reading

▪ Abstraction driven reading

▪ Task-driven reading
Structured Walkthroughs
▪ proposed by Yourdon

▪ It is a less formal and less rigorous technique

▪ It is less formal process having no bars of organized meeting

▪ A typical structured walkthrough team consists of the following members:

▪ Coordinator Organizes, moderates, and follows up the walkthrough activities.

▪ Presenter/Developer Introduces the item to be inspected.

▪ This member is optional.

▪ Scribe/Recorder Notes down the defects found and suggestion proposed by the members.

▪ Reviewer/Tester Finds the defects in the item.

▪ Maintenance Oracle Focuses on long-term implications and future maintenance of the project. 73
Structured Walkthroughs

▪ Standards Bearer Assesses adherence to standards.

▪ User Representative/Accreditation Agent Reflects the needs and concerns of the user.

▪ Walkthroughs differ significantly from inspections.

▪ A walkthrough is less formal, has fewer steps

▪ tester comes to the test cases

▪ the test data are walked through the logic of the program.

▪ The walkthrough should have a follow-up

74
Technical Reviews

▪ A review is like an inspection or walkthrough,


▪ except that the review team also includes management.
▪ A technical review team is generally comprised of management-level representatives and
project management.
▪ Review agendas should focus less on technical
▪ The moderator should gather and distribute the documentation
▪ The moderator prepare a checklist to help the team focus on the key points.
▪ The review should be a document recording the events of the meeting, deficiencies identified,
and review team recommendations.
▪ Appropriate actions should then be taken to correct any deficiencies and address all
recommendations. 75
Technical Reviews

Moderator prepares a set of indicators to measure the following points:

 Appropriateness of the problem definition and requirements

 Adequacy of all underlying assumptions

 Adherence to standards

 Consistency

 Completeness

 Documentation

76

You might also like