Testing Technique and Strategies

Download as pdf or txt
Download as pdf or txt
You are on page 1of 7

Abhijit A. Sawant, Pranit H. Bari, P. M.

Chawan / International Journal of Engineering Research and Applications


(IJERA) ISSN: 2248-9622 www.ijera.com
Vol. 2, Issue 3, May-Jun 2012, pp.980-986

Software Testing Techniques and Strategies


Abhijit A. Sawant1, Pranit H. Bari2 and P. M. Chawan3
Department of Computer Technology, VJTI, University of Mumbai, INDIA

Abstract
This paper describes Software testing, need for software Testing can also be used for verifying that the product or the
testing, Software testing goals and principles. Further it software works as desired and validate whether the software
describe about different Software testing techniques and fulfills condition laid down
different software testing strategies. Finally it describes
the difference between software testing and debugging. 2) Priority Coverage
Testing should be performed in efficient and effective manner
within the budget and schedule limits.
Keywords— Debugging, Software Testing Goals,
Software Testing principles, Software Testing Techniques, 3) Balanced
Software Testing strategies Testing process must balance the requirements, technical
limitation and user expectation.
I. INTRODUCTION
Software testing refers to process of evaluating the software 4) Traceable
with intention to find out error in it. Software testing is a Documents should be prepared of both success and failures of
technique aimed at evaluating an attribute or capability of a testing process. So no need to test same thing again.
program or product and determining that it meets its quality.
Software testing is also used to test the software for other 5) Deterministic
software quality factors like reliability, usability, integrity, We should know what we are doing, what we are targeting,
security, capability, efficiency, portability, maintainability, what will be the possible outcome.
compatibility etc.
For many years now we are still using the same testing 1.3. Testing principles
techniques .some of which is crafted method rather than good Principle is the rule or method in action that has to be
engineering methods. Testing can be costly but not testing followed. Different testing principles are as follows: [2]
software can be even more costly. Software testing aims at
achieving certain a goals and principles which are to be 1) Test a program to try to make it fail
followed. Testing is the process of executing a program with the intent
of finding errors. We should expose failures to make testing
1.1. Need for Software testing process more effective.
Software development involves developing software against a
set of requirements. Software testing is needed to verify and 2) Start testing early
validate that the software that has been built has been built to This helps in fixing enormous errors in early stages of
meet these specifications. If not we may probably loose our development, reduces the rework of finding the errors in the
client. So in order to make it sure, that we provide our client a initial stages.
proper software solution, we go for testing [1]. Testing
ensures that what you get in the end is what you wanted to 3) Testing is context dependant
build. We check out if there is any problem, any error in the Testing should be appropriate and different for different
system, which can make software unusable by the client. This points of time.
helps in the prevention of errors in a system.
4) Define Test Plan
1.2. Goals for software testing Test Plan usually describes test scope, test objectives, test
Goals are the output of the software process. Software testing strategy, test environment, deliverables of the test, risks and
has following goals. [2] mitigation, schedule, levels of testing to be applied, methods,
techniques and tools to be used. Test plan should efficiently
1) Verification and validation meet the needs of an organization and clients as well.

5) Design Effective Test cases

980 | P a g e
Abhijit A. Sawant, Pranit H. Bari, P. M. Chawan / International Journal of Engineering Research and Applications
(IJERA) ISSN: 2248-9622 www.ijera.com
Vol. 2, Issue 3, May-Jun 2012, pp.980-986

Test case must be specified in a way that is measurable so


that testing results are unambiguous.

6) Test for valid as well as invalid Conditions


In addition to valid inputs, we should also test system for
invalid and unexpected inputs/conditions

7) Testing must be done by different persons at different


levels
Different purpose addressed at different level of testing so
different person should perform testing differently using
different testing techniques at different level.

8) End of Testing
Testing has to be stopped somewhere. The testing can be
stopped when risk is under some limit or if there is limitation.

II. SOFTWARE TESTING TECHNIQUES


In this Section the focus is mainly on the different software
testing Techniques. Fig 1:-Further classification of Automated software Testing
Software Testing Techniques can be divided into two types:-
2.2.1. Correctness Testing
2.1. Manual testing (static testing) Correctness is the minimum requirement of software.
It is a slow process and laborious where testing is done Correctness testing will need some type of oracle, to tell the
statically .It is done in early phase of life cycle. It is also right behaviour from the wrong one. The tester may or may
called static testing. It is done by analyst, developer and not know the inside details of the software module under test.
testing team. [3] Therefore either white box testing or black box testing can
Different Manual testing Techniques are as follows:- be used.
A) walk through Correctness testing has following three forms:-
B) Informal Review 1) White box testing
C) Technical Review 2) Black box testing
D) Inspection 3) Grey box testing
2.2. Automated Testing (Dynamic testing)
In this tester runs the script on the testing tool and testing is
done. Automated testing is also called dynamic testing.
Automated testing is further classified into four types
A) Correctness testing
B) Performance testing
C) Reliability testing
D) Security testing

Fig 2:- Different form of Correctness testing [3]

981 | P a g e
Abhijit A. Sawant, Pranit H. Bari, P. M. Chawan / International Journal of Engineering Research and Applications
(IJERA) ISSN: 2248-9622 www.ijera.com
Vol. 2, Issue 3, May-Jun 2012, pp.980-986

1) White box testing Some Different types of Black box testing techniques are as
White box testing is highly effective in detecting and follows:-
resolving problems, because bugs can often be found before 1) Equivalent Partitioning
they cause trouble.[5] White box testing is the process of 2) Boundary value Analysis
giving the input to the system and checking how the system 3) Cause-Effect Graphing Techniques
processes that input to generate the required output.White box 4) Comparison Testing
testing is also called white box analysis, clear box testing or 5) Fuzz Testing
clear box analysis.[5] White box testing is applicable at 6) Model-based testing
integration, unit and system levels of the software testing
process.[3] White box testing is considered as a security Advantages of Black box testing:-
testing method that can be used to validate whether code 1) The number of test cases are reduced to achieve
implementation follows intended design, to validate reasonable testing
implemented security functionality, and to uncover 2) The test cases can show presence or absence of classes of
exploitable vulnerabilities. errors.
3) Black box tester has no “bond” with the code.
Some Different types of white box testing techniques are as 4) Programmer and tester both are independent of each
follows:- other.
1) Basis Path Testing 5) More effective on larger units of code than clear box
2) Loop Testing testing.
3) Control Structure Testing
Disadvantages of Black box testing:-
Advantages of white box testing:- 1) Test cases are hard to design without clear specifications.
1) All independent paths in a module will be exercised at 2) Only small numbers of possible input can actually be
least once. tested.
2) All logical decisions will be exercised. 3) Some parts of the back end are not tested at all.
3) All loops at their boundaries will be executed. 4) Chances of having unidentified paths during this testing
4) Internal data structures will be exercised to maintain their 5) Chances of having repetition of tests that are already
validity. done by programmer
5) Errors in hidden codes are revealed.
6) Approximate the partitioning done by execution 3) Grey box testing
equivalence. The Graybox Testing Methodology is a software testing
7) Developer carefully gives reason about implementation. method used to test software applications. The methodology
is platform and language independent. The current
Disadvantages of white box testing:- implementation of the Graybox methodology is heavily
1) Missed out the cases omitted in the code. dependent on the use of a host platform debugger to execute
2) As knowledge of code and internal structure is a and validate the software under test. Recent studies have
prerequisite, a skilled tester is needed to carry out this confirmed that the Graybox method can be applied in real
type of testing, which increases the cost. time using software executing on the target platform.
3) And it is nearly impossible to look into every bit of code Grey box testing techniques combined the testing
to find out hidden errors, which may create problems, methodology of white box and black box. Grey box testing
resulting in failure of the application. technique is used for testing a piece of software against its
specifications but using some knowledge of its internal
2) Black box testing working as well. The understanding of internals of the
Black box testing is testing software based on output program in grey box testing is more than black box testing,
requirements and without any knowledge of the internal but less than clear box testing. [3]
structure or coding in the program.[5] The Graybox methodology is a ten step process for testing
Basically Black box testing is an integral part of „Correctness computer software.
testing‟ but its ideas are not limited to correctness testing Ten Step Graybox Methodology
only. The goal is to test how well the component conforms to 1) Identify Inputs
the published requirement for the component. Black box 2) Identify Outputs
testing have little or no regard to the internal logical structure 3) Identify Major Paths
of the system, it only examines the fundamental aspect of the 4) Identify Subfunction (SF)X
system. It makes sure that input is properly accepted and 5) Develop Inputs for SF X
output is correctly produced. [3] 6) Develop Outputs for SF X

982 | P a g e
Abhijit A. Sawant, Pranit H. Bari, P. M. Chawan / International Journal of Engineering Research and Applications
(IJERA) ISSN: 2248-9622 www.ijera.com
Vol. 2, Issue 3, May-Jun 2012, pp.980-986

7) Execute Test Case for SF X 2.2.3. RELIABILITY TESTING


8) Verify Correct Result for SF X The purpose of reliability testing is to discover potential
9) Repeat Steps 4:8 for other SF problems with the design as early as possible and, ultimately,
10) Repeat Steps 7&8 for Regression provide confidence that the system meets its reliability
requirements. Reliability testing is related to many aspects of
The Graybox methodology utilizes automated software software in which testing process is included; this testing
testing tools to facilitate the generation of test unique process is an effective sampling method to measure software
software. Module drivers and stubs are created by the toolset reliability. In system after software is developed reliability
to relieve the software test engineer from having to manually testing techniques like analyze or fix techniques can be
generate this code. The toolset also verifies code coverage by carried out to check whether to use the software.
instrumenting the test code. “Instrumentation tools help with
the insertion of instrumentation code without incurring the 2.2.4. SECURITY TESTING
bugs that would occur from manual instrumentation”. Software quality, reliability and security are tightly coupled.
By operating in a debugger or target emulator, the Graybox Flaws in software can be exploited by intruders to opens
toolset controlled the operation of the test software. The security holes.
Graybox methodology has moved out of a debugger into the Security testing makes sure that only the authorized personnel
real world and into real-time. The methodology can be can access the program and only the authorized personnel can
applied in real-time by modifying the basic premise that access the functions available to their security level. The
inputs can be sent to the test software via normal system security testing is performed to check whether there is any
messages and outputs are then verified using the system information leakage in the sense by encrypting the application
output messages. or using wide range of software‟s and hardware's and firewall
etc.
2.2.2. PERFORMANCE TESTING
Performance Testing involve all the phases as the mainstream III. SOFTWARE TESTING STRATEGIES
testing life cycle as an independent discipline which involve A strategy for software Testing integrates software test case
strategy such as plan, design, execution, analysis and design methods into a well planned Series of steps that result
reporting. [3] in successful Construction of software that result in
Not all software has specification on performance explicitly. successful construction of software. Software testing
But every system will have implicit performance Strategies gives the road map for testing. A software testing
requirements. Strategy should be flexible enough to promote a customized
Performance has always been a great concern and driving testing approach at same time it must be right enough.
force of computer evolution. The goals of performance Strategy is generally developed by project managers, software
testing can be performance bottleneck identification, engineer and testing specialist.
performance comparison and evaluation. There are four different software testing strategies.
By performance testing we can measure the characteristics of 1) Unit testing
performance of any applications. One of the most important 2) Integration testing
objectives of performance testing is to maintain a low latency 3) Acceptance/Validation testing
of a website, high throughput and low utilization. [3] 4) System testing

Performance testing has two forms:- 3.1. Unit testing


Load testing Unit is the smallest module i.e. smallest collection of lines of
Load testing is the process of subjecting a code which can be tested. Unit testing is just one of the levels
computer, peripheral, server, network or application to a work of testing which go together to make the big picture of testing
level approaching the limits of its specifications. Load testing a system. IT complements integration and system level
can be done under controlled lab conditions to compare the testing. It should also complement code reviews and
capabilities of different systems or to accurately measure the walkthroughs.
capabilities of a single system. In this we can check whether Unit testing is generally seen as a white box test class. That is
the software can handle the load of many user or not. it is biased to looking at and evaluating the code as
implemented. Rather than evaluating conformance to some
Stress testing set of requirements.
Stress testing is a testing, which is conducted to evaluate a
system or component at or beyond the limits of its specified Benefits of Unit Testing:-
requirements to determine the load under which it fails and 1) Unit level testing is very cost effective.
how. [3] 2) It provides a much greater reliability improvement for
resources expanded than system level testing. In

983 | P a g e
Abhijit A. Sawant, Pranit H. Bari, P. M. Chawan / International Journal of Engineering Research and Applications
(IJERA) ISSN: 2248-9622 www.ijera.com
Vol. 2, Issue 3, May-Jun 2012, pp.980-986

particular, it tends to reveal bugs which are otherwise 2. Depending on the integration approach selected
insidious and are often catastrophic like the strange subordinate stubs are replaced one at a time with actual
system crashes that occur in the field when something components.
unusual happens. 3. Tests are conducted as each component is integrated.
3) Be able to test parts of a project without waiting for the 4. On completion of each set of tests, another stub is replaced
other parts to be available, with the real component.
4) Achieve parallelism in testing by being able to test and 5. Regression testing may be conducted to ensure that new
fix problems simultaneously by many engineers, errors have not been introduced.
5) Be able to detect and remove defects at a much less cost
compared to other later stages of testing, It is not as relatively simple as it looks. In this logistic
6) Be able to take advantage of a number of formal testing problem can arise. Problem arises when testing low level
techniques available for unit testing, module which requires testing upper level. Stub replace low
7) Simplify debugging by limiting to a small unit the level module at the beginning of top down testing. So no data
possible code areas in which to search for bugs, can flow in upward direction.
8) Be able to test internal conditions that are not easily
reached by external inputs in the larger integrated Bottom up Integration
systems Bottom-up integration testing, as its name implies, begins
9) Be able to achieve a high level of structural coverage of construction and testing with atomic modules. Because
the code, components are integrated from the bottom up, processing
10) Avoid lengthy compile-build-debug cycles when required for components subordinate to a given level is
debugging difficult problems. always available and the need for stubs is eliminated. [4]
A bottom-up integration strategy may be implemented with
Unit testing techniques the following steps:
A number of effective testing techniques are usable in unit 1. Low-level components are combined into clusters that
testing stage. The testing techniques may be broadly divided perform a specific software subfunction.
into three types: 2. A driver is written to coordinate test case input and output.
3. The cluster is tested.
1. Functional Testing 4. Drivers are removed and clusters are combined moving
2. Structural Testing upward in the program structure.
3. Heuristic or Intuitive Testing
3.3. Acceptance testing
3.2. Integration testing Acceptance testing (also known as user acceptance testing) is
Integration testing is a systematic technique for constructing a type of testing carried out in order to verify if the product is
the program structure while at the same time conducting tests developed as per the standards and specified criteria and
to uncover errors associated with interfacing. The objective is meets all the requirements specified by customer. [4] This
to take unit tested components and build a program structure type of testing is generally carried out by a user/customer
that has been dictated by design. where the product is developed externally by another party.
Acceptance testing falls under black box testing methodology
Different Integration testing Strategies are discussed below:- where the user is not very much interested in internal
working/coding of the system, but evaluates the overall
1) Top down Integration testing functioning of the system and compares it with the
2) Bottom up Integration testing requirements specified by them. User acceptance testing is
considered to be one of the most important testing by user
Top down Integration before the system is finally delivered or handed over to the
Top-down integration testing is an incremental approach to end user.
construct program structure. Modules are integrated by Acceptance testing is also known as validation testing, final
moving downward through the structure, beginning with the testing, QA testing, factory acceptance testing and application
main control module. Modules subordinate to the main testing etc. And in software engineering, acceptance testing
control module are incorporated into the structure in either a may be carried out at two different levels; one at the system
depth-first or breadth-first manner. [4] provider level and another at the end user level.

The integration process is performed in a series of five steps:


1. The main control module is used as a test driver and stubs
are substituted for all components directly subordinate to the
main control module.

984 | P a g e
Abhijit A. Sawant, Pranit H. Bari, P. M. Chawan / International Journal of Engineering Research and Applications
(IJERA) ISSN: 2248-9622 www.ijera.com
Vol. 2, Issue 3, May-Jun 2012, pp.980-986

Types of Acceptance Testing performed. If recovery is automatic, re-initialization, check


pointing mechanisms, data recovery, and restart are evaluated
User Acceptance Testing for correctness. If recovery requires human intervention, the
User acceptance testing in software engineering is considered mean-time-to-repair is evaluated to determine whether it is
to be an essential step before the system is finally accepted by within acceptable limits.
the end user. In general terms, user acceptance testing is a
process of testing the system before it is finally accepted by Security testing
user. Security testing attempts to verify that protection mechanisms
built into a system will, in fact, protect it from improper
Alpha Testing & Beta Testing penetration.
Alpha testing is a type of acceptance testing carried out at During security testing, the tester plays the role(s) of the
developer‟s site by users.[4] In this type of testing, the user individual who desires to penetrate the system. Anything
goes on testing the system and the outcome is noted and goes! The tester may attempt to acquire passwords through
observed by the developer simultaneously. external clerical means; may attack the system with custom
Beta testing is a type of testing done at user‟s site. The users software designed to breakdown any defenses that have been
provide their feedback to the developer for the outcome of constructed; may overwhelm the system, thereby denying
testing. This type of testing is also known as field testing. service to others; may purposely cause system errors, hoping
Feedback from users is used to improve the system/product to penetrate during recovery; may browse through insecure
before it is released to other users/customers. data, hoping to find the key to system entry.

Operational Acceptance Testing Graphical user interface testing


This type of testing is also known as operational Graphical user interface testing is the process of testing a
readiness/preparedness testing. It is a process of ensuring all product's graphical user interface to ensure it meets its written
the required components (processes and procedures) of the specifications. This is normally done through the use of a
system are in place in order to allow user/tester to use it. variety of test cases.

Contact and Regulation Acceptance Testing Compatibility testing


In contract and regulation acceptance testing, the system is Compatibility testing, part of software non-functional tests, is
tested against the specified criteria as mentioned in the testing conducted on the application to evaluate the
contract document and also tested to check if it meets/obeys application's compatibility with the computing environment.
all the government and local authority regulations and laws
and also all the basic standards. IV. DISCUSSION
In this section difference between testing and debugging is
3.4. System testing shown.
System testing of software or hardware is testing conducted
on a complete, integrated system to evaluate the system's Software testing is a process that can be systematically
compliance with its specified requirements. System testing planned and specified. Test case design can be conducted, a
falls within the scope of black box testing, and as such, strategy can be defined, and results can be evaluated against
should require no knowledge of the inner design of the code prescribed expectations.
or logic System testing is actually a series of different tests Debugging occurs as a consequence of successful testing.
whose primary purpose is to fully exercise the computer- That is, when a test case uncovers an error, debugging is the
based system. Although each test has a different purpose, all process that results in the removal of the error.
work to verify that system elements have been properly The purpose of debugging is to locate and fix the offending
integrated and perform allocated functions. code responsible for a symptom violating a known
specification. Debugging typically happens during three
Some of Different types of system testing are as follows:- activities in software development, and the level of
granularity of the analysis required for locating the defect
1. Recovery testing differs in these three.[1]
2. Security testing The first is during the coding process, when the programmer
3. graphical user interface testing translates the design into an executable code. During this
4. Compatibility testing process the errors made by the programmer in writing the
code can lead to defects that need to be quickly detected and
Recovery Testing fixed before the code goes to the next stages of development.
Recovery testing is a system test that forces the software to Most often, the developer also performs unit testing to expose
fail in a variety of ways and verifies that recovery is properly any defects at the module or component level.[1]

985 | P a g e
Abhijit A. Sawant, Pranit H. Bari, P. M. Chawan / International Journal of Engineering Research and Applications
(IJERA) ISSN: 2248-9622 www.ijera.com
Vol. 2, Issue 3, May-Jun 2012, pp.980-986

The second place for debugging is during the later stages of


testing, involving multiple components or a complete system,
when unexpected behavior such as wrong return codes or
abnormal program termination may be found. A certain
amount of debugging of the test execution is necessary to
conclude that the program under test is the cause of the
unexpected behavior.[1]

V. CONCLUSIONS
This paper on Software testing describes in detail about
software testing, need of software testing, Software testing
goals and principles. . Software testing is often less formal
and rigorous than it should, and a main reason for that is
because we have struggled to define best practices,
methodologies, principles, standards for optimal software
testing. To perform testing effectively and efficiently,
everyone involved with testing should be familiar with basic
software testing goals, principles, limitations and concepts.
We further explains different Software testing techniques
such as Correctness testing, Performance testing, Reliability
testing, Security testing. Further we have discussed the basic
principles of black box testing, white box testing and gray
box testing. We have surveyed some of the strategies
supporting these paradigms, and have discussed their pros
and cons. We also describes about different software testing
strategies such as unit testing, Integration testing, acceptance
testing and system testing.
Finally there is comparison between debugging and
testing. Testing is more than just debugging .Testing is not
only used to locate defects and correct them it is also used in
validation, verification process and measurement.

REFERENCES
[1] Sahil Batra and Dr. Rahul Rishi,”IMPROVING
QUALITY USING TESTING STRATEGIES,”
Journal of Gobal Research in Computer Science,
Volume 2,No.6,June 2011.
[2] S.M.K Quadri and Sheikh Umar Farooq,”Software
Testing-Goals,Principles and Limitations,”
International Journal of Computer Applications,
Volume 6-No.9,September 2010.
[3] Mohd. Ehmer Khan,”Different Forms of Software
Testing Techniques for Finding Errors,”IJCSI
International Journal of Computer Science
Issues,Vol. 7, Issue 3, No 1, May 2010.
[4] Ajay Jangra, Gurbaj Singh, Jasbir Singh and Rajesh
Verma,”EXPLORING TESTING
STRATEGIES,”International Journal of
Information Technology and Knowledge
Management, Volume 4, NO.1,January-June 2011.
[5] Jovanovic and Irena,”Software Testing Methods
and Techniques,” May 26,2008.
[6] ger S. Pressman, “Software engineering: A
practitioner‟s Approach,” fifth edition, 2001.

986 | P a g e

You might also like