KEMBAR78
STQA Lab Manual | PDF | Software Testing | Personal Identification Number
100% found this document useful (2 votes)
1K views43 pages

STQA Lab Manual

The document discusses the software testing lifecycle (STLC) which consists of six main phases: requirement analysis, test planning, test case development, test environment setup, test execution, and test cycle closure. It provides details on the activities and deliverables for each phase. It also describes different types of testing like unit testing, integration testing, regression testing, smoke testing, alpha testing, beta testing, system testing, stress testing, and performance testing.

Uploaded by

Shantam Sultania
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
100% found this document useful (2 votes)
1K views43 pages

STQA Lab Manual

The document discusses the software testing lifecycle (STLC) which consists of six main phases: requirement analysis, test planning, test case development, test environment setup, test execution, and test cycle closure. It provides details on the activities and deliverables for each phase. It also describes different types of testing like unit testing, integration testing, regression testing, smoke testing, alpha testing, beta testing, system testing, stress testing, and performance testing.

Uploaded by

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

CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

Practical No:-01

AIM:- Introduction to Software Testing Lifecycle. Expand the usage of various


types of testing.

Software Testing Life Cycle (STLC) is defined as a sequence of activities conducted to


perform Software Testing.

Contrary to popular belief, Software Testing is not a just a single activity. It consists of a
series of activities carried out methodologically to help certify your software product.

Different Phases of the STLC Model

STLC Diagram

Below are the phases of STLC:

 Requirement Analysis
 Test Planning
 Test case development
 Test Environment setup
 Test Execution
 Test Cycle closure

Each of these stages has a definite Entry and Exit criteria, Activities & Deliverables
associated with it.

What is Entry and Exit Criteria?

 Entry Criteria: Entry Criteria gives the prerequisite items that must be completed
before testing can begin.
 Exit Criteria: Exit Criteria defines the items that must be completed before testing
can be concluded

Requirement Analysis

1
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

During this phase, test team studies the requirements from a testing point of view to identify
the testable requirements.

The QA team may interact with various stakeholders (Client, Business Analyst, Technical
Leads, System Architects etc) to understand the requirements in detail.

Requirements could be either Functional (defining what the software must do) or Non
Functional (defining system performance /security availability )

Activities

 Identify types of tests to be performed.


 Gather details about testing priorities and focus.
 Prepare Requirement Traceability Matrix (RTM).
 Identify test environment details where testing is supposed to be carried out.
 Automation feasibility analysis (if required).

Deliverables

 RTM
 Automation feasibility report. (if applicable)

Test Planning

Typically, in this stage, a Senior QA manager will determine effort and cost estimates for the
project and would prepare and finalize the Test Plan. In this phase, Test Strategy is also
determined.

Activities

 Preparation of test plan/strategy document for various types of testing


 Test tool selection
 Test effort estimation
 Resource planning and determining roles and responsibilities.
 Training requirement

Deliverables

 Test plan /strategy document.


 Effort estimation document.

Test Case Development

This phase involves the creation, verification and rework of test cases & test scripts. Test
data, is identified/created and is reviewed and then reworked as well.

Activities

 Create test cases, automation scripts (if applicable)

2
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

 Review and baseline test cases and scripts


 Create test data (If Test Environment is available)

Deliverables

 Test cases/scripts
 Test data

Test Environment Setup

Test environment decides the software and hardware conditions under which a work product
is tested. Test environment set-up is one of the critical aspects of testing process and can be
done in parallel with Test Case Development Stage. Test team may not be involved in this
activity if the customer/development team provides the test environment in which case the
test team is required to do a readiness check (smoke testing) of the given environment.

Activities

 Understand the required architecture, environment set-up and prepare hardware and
software requirement list for the Test Environment.
 Setup test Environment and test data
 Perform smoke test on the build

Deliverables

 Environment ready with test data set up


 Smoke Test Results.

Test Execution

During this phase, the testers will carry out the testing based on the test plans and the test
cases prepared. Bugs will be reported back to the development team for correction and
retesting will be performed.

Activities

 Execute tests as per plan


 Document test results, and log defects for failed cases
 Map defects to test cases in RTM
 Retest the Defect fixes
 Track the defects to closure

Deliverables

 Completed RTM with the execution status


 Test cases updated with results
 Defect reports

Test Cycle Closure

3
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

Testing team will meet, discuss and analyze testing artifacts to identify strategies that have to
be implemented in the future, taking lessons from the current test cycle. The idea is to remove
the process bottlenecks for future test cycles and share best practices for any similar projects
in the future.

Activities

 Evaluate cycle completion criteria based on Time, Test coverage, Cost,Software,


Critical Business Objectives, Quality
 Prepare test metrics based on the above parameters.
 Document the learning out of the project
 Prepare Test closure report
 Qualitative and quantitative reporting of quality of the work product to the customer.
 Test result analysis to find out the defect distribution by type and severity.

Deliverables

 Test Closure report


 Test metrics

Types of Testing:-

 1. Unit Testing
 It focuses on smallest unit of software design. In this we test an individual unit or
group of inter related units.It is often done by programmer by using sample input and
observing its corresponding outputs.
Example:
 a) In a program we are checking if loop, method or
 function is working fine
 b) Misunderstood or incorrect, arithmetic precedence.
 c) Incorrect initialization
 2. Integration Testing
 The objective is to take unit tested components and build a program structure that has
been dictated by design.Integration testing is testing in which a group of components
are combined to produce output.
 Integration testing are of two types: (i) Top down (ii) Bottom up
Example
 (a) Black Box testing:- It is used for validation.
 In this we ignores internal working mechanism and
 focuses on what is the output?.

 (b) White Box testing:- It is used for verification.
 In this we focus on internal mechanism i.e.
 how the output is achieved?
 3. Regression Testing
 Every time new module is added leads to changes in program. This type of testing
make sure that whole component works properly even after adding components to the
complete program.
Example
 In school record suppose we have module staff, students

4
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

 and finance combining these modules and checking if on


 integration these module works fine is regression testing
 4. Smoke Testing
 This test is done to make sure that software under testing is ready or stable for further
testing
It is called smoke test as testing initial pass is done to check if it did not catch the fire
or smoked in the initial switch on.
Example:
 If project has 2 modules so before going to module
 make sure that module 1 works properly
 5. Alpha Testing
 This is a type of validation testing.It is a type of acceptance testing which is done
before the product is released to customers. It is typically done by QA people.
Example:
 When software testing is performed internally within
 the organization
 6. Beta Testing
 The beta test is conducted at one or more customer sites by the end-user of the
software. This version is released for the limited number of users for testing in real
time environment
Example:
 When software testing is performed for the limited
 number of people
 7. System Testing
 In this software is tested such that it works fine for different operating system.It is
covered under the black box testing technique. In this we just focus on required input
and output without focusing on internal working.
In this we have security testing, recovery testing , stress testing and performance
testing
Example:
 This include functional as well as non functional
 testing
 8. Stress Testing
 In this we gives unfavorable conditions to the system and check how they perform in
those condition.
Example:
 (a) Test cases that require maximum memory or other
 resources are executed
 (b) Test cases that may cause thrashing in a virtual
 operating system
 (c) Test cases that may cause excessive disk requirement
 9. Performance Testing
 It is designed to test the run-time performance of software within the context of an
integrated system.It is used to test speed and effectiveness of program.
Example:
 Checking number of processor cycles.

5
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

Practical No:-02

AIM:Write the test-cases of any known system. ( Take your project of last semester)

S/W Requirements:- Internet Explorer, Window Xp,7 or 8.

H/W Requirements:-

 Processor – Intel Pentium III, 500 MHz (or higher)


 Main Memory - minimum 512 MB RAM
 Hard Disk – minimum 20 GB IDE Hard Disk
 Removable Drives–1.44 MB Floppy Disk Drive and 52X IDE CD-ROM
Drive.
 PS/2 HCL Keyboard and Mouse.
Description: FIRST NAME
Test Id Test Step Test Expected Actual Error Message Status
Data Result Result
T1 Enter Null Should Not Pass Only letter, spaces Pass
Null Accepted ,’’,” ” accepted
T2 Enter * * Should Fail Only letter, spaces Pass
Accepted ,’’,” ” accepted
T3 Enter & & Should Fail Only letter, spaces Pass
Accepted ,’’,” ” accepted
T4 Enter % % Should Not Fail Only letter, spaces Fail
Accepted ,’’,” ” accepted
T5 Enter A A Should Pass No error massage, Fail
Accepted data accepted
T6 Enter $$ $$ Should Fail Only letter, spaces Pass
Accepted ,’’,” ” accepted
T7 Enter -- -- Should Not Pass No error massage, Pass
Accepted data accepted
T8 Enter @ @ Should Fail Only letter, spaces Pass
Accepted ,’’,” ” accepted
T9 Enter \ \ Should Not Fail Only letter, spaces Fail
Accepted ,’’,” ” accepted
T10 Enter ; ; Should Fail Only letter, spaces Pass
Accepted ,’’,” ” accepted
T11 Enter ! ! Should Fail Only letter, spaces Pass
Accepted ,’’,” ” accepted
T12 Enter ^ ^ Should Not Fail Only letter, spaces Fail
Accepted ,’’,” ” accepted
T13 Enter + + Should Fail Only letter, spaces Pass
Accepted ,’’,” ” accepted
T14 Enter { { Should Fail Only letter, spaces Pass
Accepted ,’’,” ” accepted

6
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

T15 Enter = = Should Fail Only letter, spaces Fail


Accepted ,’’,” ” accepted
T16 Enter? ? Should Not Pass No error massage, Pass
Accepted data accepted
T17 Enter < < Should Fail Only letter, spaces Pass
Accepted ,’’,” ” accepted
T18 Enter [ [ Should Fail Only letter, spaces Pass
Accepted ,’’,” ” accepted
T19 Enter 2 2 Should Fail Only letter, spaces Pass
Accepted ,’’,” ” accepted
T20 Enter _ _ Should Not Fail Only letter, spaces Fail
Accepted ,’’,” ” accepted
T21 Enter B2 B2 Should Fail Only letter, spaces Pass
Accepted ,’’,” ” accepted
T22 Enter. . Should Not Pass No error massage, Pass
Accepted data accepted
T23 Enter Z Z Should Pass No error massage, Fail
Accepted data accepted
TEST ID:
T1:-

T2:-

T3:-

7
T4:-

T5:-

T6:-

T7:-

T8:-

5
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

T9:-

T10:-

T11:-

T12:-

6
T13:-

T14:-

T15:-

T16:-

7
T17:-

T18:-

8
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

T19:-

T20:-

T21:-

T22:-

T23:-

6
7
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

Practical No:-3

AIM:- . Test the Website of "Chandigarh University" by:


 Write 25 test cases.
 Test it using LamdaTest and generate bug-reports.

H/W Requirements:-

 Processor – Intel Pentium III, 500 MHz (or higher)


 Main Memory - minimum
 512 MB RAM
 Hard Disk – minimum 20 GB IDE Hard Disk
 Removable Drives–1.44 MB Floppy Disk Drive and 52X IDE CD-ROM Drive.
 PS/2 HCL Keyboard and Mouse.

To perform screenshot testing in LambdaTest, you have to Login to your LambdaTest account.
1. Once you have logged in, select Screenshot under Visual UI Testing.

Note: By the term Visual UI testing, it means that you get the list of different tests that involve the visual user
interface of your website. In simpler meaning, how your website will be viewed by the user.

2. Enter the website URL you want to test in the URL box field.

8
3. Select the browsers on which you want to test your website.

Note: You can choose a maximum of 25 browsers from the list. You can also see the number of browsers you have
selected on the top options bar.

As you can see I have selected 11 Desktop Browsers and 0 Mobile Browsers. You can select mobile browsers from
the side device selection bar which can also be seen in the above image.

4. Once you are done with the selection. Press Capture from the top address bar.

5. Once you press Capture, LambdaTest will start to run your website on different devices, browsers, and versions and
capture their screenshot. This might take a few minutes depending upon your selection.
6. After all the screenshots have been generated, you will see them on the window screen. You can download the
screenshot for a particular browser and particular version by clicking the down arrow beside the screenshot.

7. The top panel will show you three option to work with.

9
1
0
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

Practical No:-4

AIM:- Take one project like a website/web-application/Android-App and submit a Test- plan Document for
it following the IEEE format of Test Plan Template.

TEST PLAN FOR

<<PROJECT NAME>>
ChangeLog

Version Change Date By Description

version number Date of Name of person who Description of the changes


Change made changes made

1 INTRODUCTION..................................................................................................... 14
1.1 SCOPE.................................................................................................................... 14
1.1.1 In Scope ......................................................................................................... 14
1.1.2 Out of Scope................................................................................................... 14
1.2 QUALITY OBJECTIVE ............................................................................................. 14
1.3 ROLES AND RESPONSIBILITIES .............................................................................. 14
2 TEST METHODOLOGY ........................................................................................ 14
2.1 OVERVIEW ............................................................................................................ 14
2.2 TEST LEVELS ......................................................................................................... 15
2.3 BUG TRIAGE .......................................................................................................... 15
2.4 SUSPENSION CRITERIA AND RESUMPTION REQUIREMENTS ................................... 15
2.5 TEST COMPLETENESS ............................................................................................ 15
3 TEST DELIVERABLES .......................................................................................... 15
13
4 RESOURCE & ENVIRONMENT NEEDS ............................................................ 16
4.1 TESTING TOOLS ..................................................................................................... 16
4.2 TEST ENVIRONMENT ............................................................................................. 16
5 TERMS/ACRONYMS .............................................................................................. 16
Introduction
Brief introduction of the test strategies, process, workflow and methodologies used for the project

Scope

In Scope

Scope defines the features, functional or non-functional requirements of the software that will be tested

Out of Scope

Out Of Scope defines the features, functional or non-functional requirements of the software that will NOT be
tested

Quality Objective

Here make a mention of the overall objevtie that you plan to achive withou your testing

Some objectives of your testing project could be

 Ensure the Application Under Test conforms to functional and non-functional requirements
 Ensure the AUT meets the quality specifications defined by the client
 Bugs/issues are identified and fixed before go live

Roles and Responsibilities


Detail description of the Roles and responsibilities of different team members like
 QA Analyst
 Test Manager
 Configuration Manager
 Developers
 Installation Team
Amongst others

Test Methodology

Overview

Mention the reason of adopting a particular test methodology for the project. The test methodology selected for
the project could be
14
 WaterFall
 Iterative
 Agile
 Extreme Programming
The methodology selected depends on multiple factors. You can read about Test Methodology here

Test Levels

Test Levels define the Types of Testing to be executed on the Application Under Test (AUT). The Testing
Levels primarily depends on the scope of the project, time and budget constraints.

Bug Triage

The goal of the triage is to

 To define the type of resolution for each bug


 To prioritize bugs and determine a schedule for all “To Be Fixed Bugs’.

Suspension Criteria and Resumption Requirements

Suspension criteria define the criteria to be used to suspend all or part of the testing procedure while Resumption
criteria determine when testing can resume after it has been suspended

Test Completeness
Here you define the criterias that will deem your testing complete.
For instance, a few criteria to check Test Completeness would be
 100% test coverage
 All Manual & Automated Test cases executed
 All open bugs are fixed or will be fixed in next release

Test Deliverables

Here mention all the Test Artifacts that will be delivered during different phases of the testing lifecycle.

Here are the sample deliverables


15
 Test Plan
 Test Cases
 Requirement Traceability Matrix
 Bug Reports
 Test Strategy
 Test Metrics
 Customer Sign Off

Resource & Environment Needs

Testing Tools

Make a list of Tools like


 Requirements Tracking Tool
 Bug Tracking Tool
 Automation Tools
Required to test the project

Test Environment
It mentions the minimum hardware requirements that will be used to test the Application.

Following software’s are required in addition to client-specific software.

 Windows 8 and above


 Office 2013 and above
 MS Exchange, etc.

Terms/Acronyms
Make a mention of any terms or acronyms used in the project

TERM/ACRONY DEFINITION
M
API Application Program Interface
AUT Application Under Test

16
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

Practical No:-5
AIM:- Explore Black Box Testing. Take a simple program in C/C++ and perform equivalence
testing by writing test cases.
BLACK BOX TESTING, also known as Behavioral Testing, is a software testing method in which the
internal structure/design/implementation of the item being tested is not known to the tester. These tests can be
functional or non-functional, though usually functional.

This method is named so because the software program, in the eyes of the tester, is like a black box; inside
which one cannot see. This method attempts to find errors in the following categories:

 Incorrect or missing functions


 Interface errors
 Errors in data structures or external database access
 Behavior or performance errors
 Initialization and termination errors

Example: Design and develop a program in a language of your choice to solve the triangle problem defined as
follows: Accept three integers which are supposed to be the three sides of a triangle and determine if the three
values represent an equilateral triangle, isosceles triangle, scalene triangle, or they do not form a triangle at all.
Assume that the upper limit for the size of any side is 10. Derive test cases for your program based on boundary-
value analysis, execute the test cases and discuss the results.

ALGORITHM:
Step 1: Input a, b & c i.e three integer values which represent three sides of
the triangle.
Step 2: if (a < (b + c)) and (b < (a + c)) and (c < (a + b) then

do step 3
else
print not a triangle. do step 6.

Step 3: if (a=b) and (b=c) then


Print triangle formed is equilateral. do step 6.
Step 4: if (a ≠ b) and (a ≠ c) and (b ≠ c) then
Print triangle formed is scalene. do step 6.
Step 5: Print triangle formed is Isosceles.
Step 6: stop

19
PROGRAM CODE:
#include<stdio.h>
#include<ctype.h>
#include<conio.h>
#include<process.h>
int main()
{
int a, b, c;
clrscr();
printf("Enter three sides of the triangle");
scanf("%d%d%d", &a, &b, &c);
if((a > 10) || (b > 10) || (c > 10))
{
printf("Out of range");
getch();
exit(0);
}
if((a<b+c)&&(b<a+c)&&(c<a+b))
{
if((a==b)&&(b==c))
{
printf("Equilateral triangle");
}
else if((a!=b)&&(a!=c)&&(b!=c))
{
printf("Scalene triangle");
}
else
printf("Isosceles triangle");
}
else
{
printf("triangle cannot be formed");
}
getch();
return 0;
}

Test Report:

Case Id Description Input data Expected Actual comments


a b c output output

20
Practical No:-06

AIM:- Take a simple program in C/C++ and perform boundary value analysis by
writing test cases.

Example: Design and develop a program in a language of your choice to solve the triangle problem defined as
follows: Accept three integers which are supposed to be the three sides of a triangle and determine if the three
values represent an equilateral triangle, isosceles triangle, scalene triangle, or they do not form a triangle at all.
Assume that the upper limit for the size of any side is 10. Derive test cases for your program based on boundary-
value analysis, execute the test cases and discuss the results.
ALGORITHM:
Step 1: Input a, b & c i.e three integer values which represent three sides of
the triangle.
Step 2: if (a < (b + c)) and (b < (a + c)) and (c < (a + b) then

do step 3
else
print not a triangle. do step 6.

Step 3: if (a=b) and (b=c) then


Print triangle formed is equilateral. do step 6.
Step 4: if (a ≠ b) and (a ≠ c) and (b ≠ c) then
Print triangle formed is scalene. do step 6.
Step 5: Print triangle formed is Isosceles.
Step 6: stop

PROGRAM CODE:
#include<stdio.h>
#include<ctype.h>
#include<conio.h>
#include<process.h>
int main()
{
int a, b, c;
clrscr();
printf("Enter three sides of the triangle");
scanf("%d%d%d", &a, &b, &c);
if((a > 10) || (b > 10) || (c > 10))
{
printf("Out of range");
getch();
exit(0);
}
if((a<b+c)&&(b<a+c)&&(c<a+b))
{
if((a==b)&&(b==c))
{
printf("Equilateral triangle");
}
else if((a!=b)&&(a!=c)&&(b!=c))
{
printf("Scalene triangle");
21
}
else
printf("Isosceles triangle");
}
else
{
printf("triangle cannot be formed");
}
getch();
return 0;
}
Test Report:

Case Id Description Input data Expected Actual comments


a b c output output

22
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

Practical No:-7

AIM:- Explore White Box Testing. Take a simple program in C/C++ and perform branch
coverage by writing test cases.
Branch/Decision Coverage:

Test coverage criteria requires enough test cases such that each condition in a decision takes on all possible
outcomes at least once, and each point of entry to a program or subroutine is invoked at least once. That is, every
branch (decision) taken each way, true and false. It helps in validating all the branches in the code making sure
that no branch leads to abnormal behavior of the application.

How to Calculate Statement Coverage, Branch Coverage and Path Coverage?

Draw the flow in the following way-

 Nodes represent entries, exits, decisions and each statement of code.


 Edges represent non-branching and branching links between nodes.

Example:

Read P
Read Q
IF P+Q > 100 THEN
Print “Large”
ENDIF
If P > 50 THEN
Print “P Large”
ENDIF

Calculate statement coverage, branch coverage and path coverage.

Solution:
The flow chart is-

22
Branch Coverage (BC):

To calculate Branch Coverage, find out the minimum number of paths which will ensure covering of all the
edges. In this case there is no single path which will ensure coverage of all the edges at one go. By following
paths 1A-2C-3D-E-4G-5H, maximum numbers of edges (A, C, D, E, G and H) are covered but edges B and F
are left. To covers these edges we can follow 1A-2B-E-4F. By the combining the above two paths we can ensure
of traveling through all the paths. Hence Branch Coverage is 2. The aim is to cover all possible true/false
decisions.

23
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

Practical No:-08
AIM: Write a „c‟ program to demonstrate the working of the fallowing
constructs: i) do…while ii) while…do iii) if …else iv) switch v) for Loops in C
language

//A. AIM: To demonstrate the working of do..while construct

Objective
To understand the working of do while with different range of values and test cases
#include <stdio.h>
void main (){
int i, n=5,j=0; clrscr();
printf(―enter a no‖);

Test case no: 1


Test case name: Positive values within range

Input =2 Expected output Actual output Remarks


2 is even number 2 is even number
3 is odd number 3 is odd number success
4 is even number 4 is even number
5 is odd number 5 is odd number
6 is even number 6 is even number

24
Test case no:2
Test case name: Negative values within a range

Input = -2 Expected output Actual output Remarks


-2 is even number -2 is an even number
-3 is odd number fail
-4 is even number
-5 is odd number
-6 is even number

Test case no: 3

Test case name: Out of range values testing

Input Expected output Actual output Remarks


1234567891222222222222 123456789122222222213 234567891222222215 fail

//B. Aim:To demonstrate the working of while construct

Objective
To understand the working of while with different range of values and test cases

#include<stdio.h>
#include <conio.h>
void main (){
int i, n=5,j=1; clrscr();
printf(―enter a no‖);
scanf(―%d‖,&i);
while (i>0 && j<n){
if(i%2==0){
printf(―%d‖,i);
printf(―is a even
number‖; i++;
j++;
}
else{
printf(―%d‖,i);
printf(―is a odd
number‖); i++;
j++;
}}
getch();
}
Input Actual output

2 2 is even number 3
is odd number 4 is
even number 5 is
odd number 6 is
even number

25
Test cases:

Test case no: 1


Test case name: Positive values within range

Input =2 Expected output Actual output Remarks


2 is even number 2 is even number
3 is odd number 3 is odd number success
4 is even number 4 is even number
5 is odd number 5 is odd number
6 is even number 6 is even number

Input Expected output Actual output Remarks


1234567891222222222222 123456789122222222213 234567891222222215 fail

int i;
clrscr();
printf(―enter a number
‖); scanf(―%d‖,&i);

if(i%2==0){
printf(―%d‖,i);
printf(―is a even number‖);
}
else{

26
printf(―%d‖,i);
printf(―is a odd number‖);
}
getch();

Input Actual output


2 2 is even number 3
is odd number 4 is
even number 5 is
odd number 6 is
even number
Test cases:
Test case no: 1
Test case name: Positive values within range

Input =2 Expected output Actual output Remarks


2 is even number 2 is even number
3 is odd number 3 is odd number success
4 is even number 4 is even number
5 is odd number 5 is odd number 6
is even number 6 is even number

Test case no:2


Test case name: Negative values within a range

Input = -2 Expected output Actual output Remarks


-2 is even number -2 is an even number
-3 is odd number fail
-4 is even number
-5 is odd number
-6 is even number

Test case no: 3

Test case name: Out of range values testing

Input Expected output Actual output Remarks


1234567891222222222222 123456789122222222213 234567891222222215 fail

// D. To demonstrate the working of switch construct

Objective
To understand the working of switch with different range of values and test cases void
main() {

int a,b,c;
clrscr();
printf(―1.Add/n 2.Sub /n 3.Mul /n 4.Div /n Enter Your
choice‖); scanf(―%d‖ , &i);

27
printf(―Enter a,b values‖);
scanf(―%d%d‖,&a,&b);
switch(i){
case 1: c=a+b;
printf(― The sum of a & b is: %d‖
,c); break;
case 2: c=a-b;
printf(― The Diff of a & b is: %d‖
,c); break;
case 3: c=a*b;
printf(― The Mul of a & b is: %d‖
,c); break;
case 4: c=a/b;
printf(― The Div of a & b is: %d‖
,c); break;
default:
printf(― Enter your
choice‖); break;
}
getch();
}

Output:

Input Output

Enter Ur choice: 1
Enter a, b Values: 3, 2 The sum of a & b is:5

Enter Ur choice: 2
Enter a, b Values: 3, 2 The diff of a & b is: 1

Enter Ur choice: 3
Enter a, b Values: 3, 2 The Mul of a & b is: 6

Enter Ur choice: 4
Enter a, b Values: 3, 2 The Div of a & b is: 1

Test cases:

Test case no: 1


Test case name: Positive values within range

Input Expected output Actual output Remarks

Enter Ur choice: 1
Enter a, b Values: 3, 2 The sum of a & b is:5 5

Enter Ur choice: 2
The diff of a & b is: 1 1 Success
Enter a, b Values: 3, 2

28
Enter Ur choice: 3
Enter a, b Values: 3, 2 The Mul of a & b is: 6 6

Enter Ur choice: 4
The Div of a & b is: 1 1
Enter a, b Values: 3, 2

Test case no:2

Test case name: Out of range values testing

Input Expected output Actual output Remarks

Option: 1
a= 22222222222222

b=22222222222222 44444444444444 -2 fail

Test case no: 3

Test case name: Divide by zero

Input Expected output Actual output Remarks

Option: 4

a= 10 & b=0 error fail

// E. Aim: To demonstrate working of for construct

Objective
To understand the working of for with different range of values and test cases

#include <stdio.h>
#include <conio.h>

void main (){ int


i; clrscr();
printf(―enter a no‖);
scanf(―%d‖,&i);
for(i=1;i<=5;i++){
if(i%2==0){
printf(―%d‖, i);
printf(― is a even
no‖); i++;
}
else{
printf(―%d‖, i);
printf(― is a odd

29
no‖); i++;
}
}
getch();
}

Output:

Enter a no: 5

30
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)
0 is a even no
1 is a odd no
3 is a even no
4 is a odd
no
5 is a odd
no

Test cases:

Test case no: 1


Test case name: Positive values within range

Input =2 Expected output Actual output Remarks


0 is even number 0 is even number
1 is odd number 1 is odd number success
2 is even number 2 is even number

Test case no:2


Test case name: Negative values within a range

Input = -2 Expected output Actual output Remarks


0 is even number 0 is an even number
-1 is odd number -1 is even no fail
-2 is even number -2 is odd no

Test case no: 3

Test case name: Out of range values testing

Input Expected output Actual output Remarks


1234567891222222222222 123456789122222222213 234567891222222215 fail

31
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

Practical-9
Aim: Take any system (e.g. ATM system) and study its system
specifications and report the various bugs.
Program:

Features to be tested:

1. Validity of the card.


2. Withdraw Transaction flow of ATM.
3. Authentication of the user’s.
4. Dispense the cash from the account.
5. Verify the balance enquiry.
6. Change of PIN number.

Bugs Identified:

Bug-Id Bug Name


ATM_001 Invalid Card

ATM_002 Invalid PIN

ATM_003 Invalid Account type

ATM_004 Insufficient Balance

ATM_005 Transaction Limit

ATM_006 Day limit

ATM_007 Invalid money denominations

ATM_008 Receipt not printed

ATM_009 PIN change mismatch

Bug Report:

Bug Id: ATM_001


Bug Description: Invalid card
Steps to reproduce: 1. Keep valid card in the ATM.
Expected Result: Welcome Screen
Actual Result: Invalid card
Status : Pass/Fail

Bug Id: ATM_002


Bug Description: Invalid PIN entered
Steps to reproduce:
32
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

1. Keep a valid card in ATM.


2. Enter the authorized PIN.
3. Menu screen should be displayed.
Expected Result: Menu screen displayed
Actual Result: Invalid PIN screen is displayed
Status : Pass/Fail

Bug Id: ATM_003


Bug Description: Invalid Account type selected.
Steps to reproduce:
1. Enter a valid user PIN number.
2. Select the withdraw option on the main menu.
3. Choose the correct type of account (either savings or current account).
Expected Result: Enter the Amount screen displayed
Actual Result: Invalid Account type screen is displayed.
Status : Pass/Fail

Bug Id: ATM_004


Bug Description: Insufficient Balance
Steps to reproduce:
1. Menu screen should be displayed.
2. Select the withdraw option.
3. Select the correct type of account.
4. Enter the sufficient amount to withdraw from the account.
5. Dispense the cash screen & amount to be deducted from account
Expected Result: Collect the amount screen displayed
Actual Result: Insufficient balance in the account
Status : Pass/Fail

Bug Id: ATM_005


Bug Description: Withdraw Limit per transaction.
Steps to reproduce:
1. Menu screen should be displayed.
2. Select the withdraw option.
3. Select the correct type of account.
4. Enter sufficient amount to withdraw from the account Transaction within the limit.
5. Dispense the cash screen & amount to be deducted from account.
Expected Result: Cash is dispensed and collect the receipt
Actual Result: Transaction limit exceeded screen is displayed
Status : Pass/Fail

Bug Id: ATM_006


Bug Description: Withdraw limit per day
Steps to reproduce:
1. Keep a valid card in ATM.
2. Enter the authorized PIN.
3. Enter the amount to withdraw from the account.
33
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

4. Amount enter is over the day limit (>40000)


5. Amount enter is over the day limit and display screen is displayed.
Expected Result: Cash is dispensed and collect the receipt.
Actual Result: Day limit exceeded screen is displayed.
Status : Pass/Fail

Bug Id: ATM_007


Bug Description: Amount enter denominations
Steps to reproduce:
1. Keep a valid card in ATM.
2. Enter the authorized PIN.
3. Enter the amount which should be in multiples of 100.
4. Cash Dispenser screen is displayed.
Expected Result: Collect the amount screen is displayed.
Actual Result: Amount enter not in required denominations.
Status : Pass/Fail

Bug Id: ATM_008


Bug Description: Statement not printed
Steps to reproduce:
1. Keep a valid card in ATM.
2. Enter the authorized PIN.
3. Select the mini statement.
4. Current balance is displayed on the screen.
5. Collect printed receipt of the statement.
Expected Result: Collect the mini statement receipt
Actual Result: receipt not printed.
Status : Pass/Fail

Bug Id: ATM_009


Bug Description: PIN mismatch
Steps to reproduce:
1. Keep a valid card in ATM.
2. Enter the authorized PIN.
3. Select the change PIN option on the menu.
4. Enter the current PIN.
5. Enter the new PIN.
6. Retype the new PIN
7. PIN successfully changed displayed on the screen.
Expected Result: PIN change successful.
Actual Result: PIN mismatched due to wrong PIN entered
Status : Pass/Fail

34
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

A TES TEST SCENARIO TEST CASE EXPECTE ACTUA STAT TEST


P T D RESULT L US DAT
P CAS RESUL A
L E ID T
I
C
A
T
I
O
N

N
A
M

35
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

S 1 Validate the login Enter invalid user System should Customer Pass Ex:
B page enter invalid/ name and valid not allow the is not able
I wrong user name password in SBI customer to login to login UID:a
and valid password online Banking login the SBI online SBI online bcdef
page Banking login banking
page and it account PWD:x
should display yz123
the message like
”please enter
O valid user name
N and password”
L
I
N 2 validate the login Enter invalid user System should Customer Pass Ex:
E page enter invalid name and invalid pass not allow the is not able
user name and word in SBI online customer to login to login UID:a
invalid password Banking login page the SBI online SBI online bcd
Banking login Banking
page and it account PWD:x
B should display yz12
A the message like
“ please enter
N valid user name
and password
K 3 Validate the login Enter valid user System should Customer Pass Ex:
I page enter valid name and invalid allow the user to is logged in
N user name and password in SBI login the SBI to SBI UID:a
invalid password online Banking login online Banking online bcdefg
G page login page Banking
login page PWD:x
yz123
4

4 Validate the login Enter valid user name System should Customer Pass Ex:
A page enter valid and valid password in allow the user to is logged
P user name and SBI online Banking login the SBI into SBI UID:a
P valid password login page online Banking online bcdefg
L login page Banking
I login page PWD:x
C yz
A
T 123
I 5 Validate the user a) User should
36 a) User/cus Customer fail
O information or able to login tomer is not able
N detail in the SBI login should to see
page able to phone or
b) User should login
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

profile page able to click SBI mobile


on profile login number
link page
c) On clicking with
profile link valid
uses should b) Custome
able to see r should
all user be able
details like to click
1) User profile
/custome link.
r name c) Custome
2) User/cust r should
omer see all
address the
details custome
3) User/cust r
omer informat
phone ion
number once he
clicking
on
profile
hyper
link

37
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

Practical-10

Aim: Study of any web testing tool (e.g. Selenium)

Selenium is a robust set of tools that supports rapid development of test automation for
web-based applications. Selenium provides a rich set of testing functions specifically
geared to the needs of testing of a web application. These operations are highly flexible,
allowing many options for locating UI elements and comparing expected test results
against actual application behavior.
One of Selenium‘s key features is the support for executing one‘s tests on multiple
browser platforms.
Selenium Components
Selenium is composed of three major tools. Each one has a specific role in aiding
the development of web application test automation.
Selenium-RC provides an API (Application Programming Interface) and library for each
of its supported languages: HTML, Java, C#, Perl, PHP, Python, and Ruby. This ability
to use Selenium-RC with a high-level programming language to develop test cases also
allows the automated testing to be integrated with a project‘s automated build
environment.
Selenium-Grid

Selenium-Grid allows the Selenium-RC solution to scale for large test suites or test suites
that must be run in multiple environments. With Selenium-Grid, multiple instances of
Selenium-RC are running on various operating system and browser configurations; Each

38
CHANDIGARH UNIVERSITY, GHARUAN (MOHALI)

of these when launching register with a hub. When tests are sent to the hub they are then
redirected to an available Selenium-RC, which will launch the browser and run the test.
This allows for running tests in parallel, with the entire test suite theoretically taking only
as long to run as the longest individual test.
* Tests developed on Firefox via Selenium-IDE can be executed on any other supported
browser via a simple Selenium-RC command line.
** Selenium-RC server can start any executable, but depending on browser security
settings there may be technical limitations that would limit certain features.
Flexibility and Extensibility
Selenium is highly flexible. There are multiple ways in which one can add functionality
to Selenium‘s framework to customize test automation for one‘s specific testing needs.
This is, perhaps, Selenium‘s strongest characteristic when compared with proprietary test
automation tools and other open source solutions. Selenium-RC support for multiple
programming and scripting languages allows the test writer to build any logic they need
into their automated testing and to use a preferred programming or scripting language of
one‘s choice.
Selenium-IDE allows for the addition of user-defined ―user-extensions‖ for creating
additional commands customized to the user‘s needs. Also, it is possible to re-configure
how the Selenium-IDE generates its Selenium-RC code. This allows users to customize
the generated code to fit in with their own test frameworks. Finally, Selenium is an Open
Source project where code can be modified and enhancements can be submitted for
contribution.
.Test Suites

A test suite is a collection of tests. Often one will run all the tests in a test suite as one
continuous batch-job.
When using Selenium-IDE, test suites also can be defined using a simple HTML file.
The syntax again is simple. An HTML table defines a list of tests where each row
defines the filesystem path to each test. An example tells it all.

<html>
<head>
<title>Test Suite Function Tests – Priority 1</title>
</head> <body>
<table>
<tr><td><b>Suite Of Tests</b></td></tr>
<tr><td><a href=‖./Login.html‖>Login</a></td></tr>
<tr><td><a href=‖./SearchValues.html‖>Test Searching for
Values</a></td></tr> <tr><td><a href=‖./SaveValues.html‖>Test
Save</a></td></tr>
</table>
</body> </html>
A file similar to this would allow running the tests all at once, one after another, from the
Selenium-IDE.

Test suites can also be maintained when using Selenium-RC. This is done via
programming and can be done a number of ways. Commonly Junit is used to maintain a
test suite if one is using Selenium-RC with Java. Additionally, if C# is the chosen
language, Nunit could be employed. If using an interpreted language like Python with
Selenium-RC than some simple programming would be involved in setting up a test
suite. Since the whole reason for using Sel-RC is to make use of programming logic for

39
your testing this usually isn‘t a problem.
Few typical Selenium commands.

open – opens a page using a URL.


click/clickAndWait – performs a click operation, and optionally waits for a new page to
load.
verifyTitle/assertTitle – verifies an expected page title.
verifyTextPresent – verifies expected text is somewhere on the page.
verifyElementPresent – verifies an expected UI element, as defined by its HTML tag, is
present on the page.
verifyText – verifies expected text and it‘s corresponding HTML tag are present on the
page.
verifyTable – verifies a table‘s expected contents.
waitForPageToLoad – pauses execution until an expected new page loads. Called
automatically when clickAndWait is used.
waitForElementPresent – pauses execution until an expected UI element, as defined by its
HTML tag, is present on the page.

40

You might also like