practical – Programmerbay https://programmerbay.com A Tech Bay for Tech Savvy Mon, 19 Sep 2022 18:06:44 +0000 en-US hourly 1 https://wordpress.org/?v=6.5.5 https://programmerbay.com/wp-content/uploads/2019/09/cropped-without-transparent-32x32.jpg practical – Programmerbay https://programmerbay.com 32 32 Difference between Statement Coverage and Branch Coverage in Tabular form https://programmerbay.com/distinguish-between-statement-coverage-and-branch-coverage/ https://programmerbay.com/distinguish-between-statement-coverage-and-branch-coverage/#respond Wed, 14 Sep 2022 16:20:57 +0000 https://programmerbay.com/?p=5540 In software testing, code coverage is a measure that determines how much code in a program is successfully tested. It provides various methods such as branch coverage, statement coverage,decision coverage, FSM coverage and more. In this article, we’ll be discussing branch coverage and statement coverage.

Branch coverage and Statement Coverage are form of white box testing techniques.

The main difference between them is, the aim of statement coverage is to traverse all statements at least once, whereas the goal of branch coverage it to traverse all the branches at least once.

Difference between Statement Coverage and Branch Coverage in Tabular form

Statement CoverageBranch Coverage
Statement coverage is a technique which aims to cover all the statements at least once by executing the programThe main goal of branch coverage is to cover branches at least once (true and false)
It focuses on covering all statements or lines of a programIt focuses on covering branches, both conditional and unconditional
It is weaker criteria than branch coverage as test cases that cover all statements may not cover all the branchesIt is stronger criteria than branch coverage that cover all branches would also cover all the statements too
Coverage Measurement,
Statement coverage = (Total Statements covered/Total Statements )* 100
Coverage Measurement,
Branch coverage = (Total branch covered/Total Branches )* 100

Statement Coverage

It is also termed as Line coverage.
The goal of this technique is to cover all the statements at least once by executing the program.

It requires test cases that make possible to run all the statement consisting of the program in order to achieve 100% coverage. It only assures that all the statements have executed but not assures whether all the paths have covered or not.

For example:

READ A
IF A == 10
THEN
PRINT I am True
ElSE
PRINT I am False
ENDIF

 

Test case #1 ( A = 5 )

Statement coverage = (Total Statements covered/Total Statements )* 100

=(5/7)*100

statement coverage

In the above code, 71.5% statement coverage is achieved by test case #1.

Test case #2 ( A = 10 )

Statement coverage = (Total Statements covered/Total Statements )* 100

=(5/7)*100

statement coverage

Again, 71.5% statement coverage is covered, and altogether these two test cases executed all the possible paths with 71.5% statement coverage each.

Executing every statement of a program helps in finding faults, unreachable or useless statements.

Branch Coverage

In a flow graph, an arrow represents edges and counting a statement as a node, where two nodes are connected with an edge.

A diamond symbol represents the decision node where more than one edges are present in an outgoing manner which is termed as Branches.

The main aim of branch coverage is to cover all the branches ( two separate paths) at least once (true and false).
Branch Coverage is a structurally based technique that checks both conditional and unconditional branches.

Branch  coverage = (number of executed branches/ total number of branches) * 100

For example:

READ A 
IF A == 10
THEN 
PRINT I am True 
ElSE 
PRINT I am False 
ENDIF

 

branch coverage corrected

Branches:

  • 2,5,6,7
  • 2,3,4,7

To cover all the branches we would require 2 test cases:

Test case #1 ( A = 12 )

Branch coverage = (Total branch covered/Total Branches )* 100

=(1/2)*100

branch coverage 50

In the above code, 50% branch coverage is achieved by test case #1.

Test case #2 ( A = 10 )

Branch coverage = (Total branch covered/Total Branches )* 100

=(1/2)*100

branch coverage 50

Again, 50% branch coverage is achieved by test case #2.

Altogether these two test cases executed all the possible branches with 50% branch coverage each.

 

]]>
https://programmerbay.com/distinguish-between-statement-coverage-and-branch-coverage/feed/ 0
Design the test cases and test the program of Quadratic Equation by using Decision Table Based testing https://programmerbay.com/design-the-test-cases-and-test-the-program-of-quadratic-equation-by-using-decision-table-based-testing/ https://programmerbay.com/design-the-test-cases-and-test-the-program-of-quadratic-equation-by-using-decision-table-based-testing/#respond Fri, 27 Sep 2019 06:01:49 +0000 https://programmerbay.com/?p=5388 Program

If you’re interested to see “Quadratic Equation Problem “ code, then the link is here with tested test cases.

Decision Table Based Testing

In Decision table based testing,  Condition stubs and Action stubs are recognized as inputs and outputs. Here, we’ll be using this black box testing technique to generate test cases:

Let’s create the decision table first,

Desicion Table testing 1

Now, we will accordingly create test cases based on the above decision table.

Test IDabcExpected OutputProgram OutputTested Outcome
1055Not QuadraticNot QuadraticPass
2155RealRealPass
3955ImaginaryImaginaryPass
45105EqualEqualPass

]]>
https://programmerbay.com/design-the-test-cases-and-test-the-program-of-quadratic-equation-by-using-decision-table-based-testing/feed/ 0
Software Testing Practical Questions https://programmerbay.com/ways-to-solve-software-testing-practical-questions/ https://programmerbay.com/ways-to-solve-software-testing-practical-questions/#respond Mon, 23 Sep 2019 04:56:38 +0000 https://programmerbay.com/?p=5327 1. Design the test cases and test the program of following problems by using BVT/Robustness testing

2. Design the test cases and test the program of following problems by using Equivalence Class testing

3.Design the test cases and test the program of following problems by using Decision Table Based testing

4.Design the test cases and test the program of following problems by using Path testing

5. Design the test cases and test the program of following problems by using Data Flow testing

 

]]>
https://programmerbay.com/ways-to-solve-software-testing-practical-questions/feed/ 0