Unit III
LEVELS OF TESTING
The Need for Levels of Testing :
Levels of Testing and Software
Development Paradigms
• There are two major approaches to system
development—bottom-up, and top-down.
• These approaches are supported by two major
types of programming languages—procedure-
oriented and object-oriented.
Unit Test: Functions, Procedures, Classes,
and Methods as Units
• A workable definition for a software unit is -
• A unit is the smallest possible testable software component.
• It can be characterized in several ways. For example, a unit in
a typical procedure-oriented software system:
• performs a single cohesive function;
• can be compiled separately;
• is a task in a work breakdown structure (from the
manager’s point of view);
• contains code that can fit on a single page or
screen.
Unit Test: The Need for Preparation
• The principal goal for unit testing is insure that
each individual software unit is functioning
according to its specification.
• Good testing practice calls for unit tests that
are planned and public. Planning includes
designing tests to reveal defects such as
functional description defects, algorithmic
defects, data defects, and control logic and
sequence defects.
• To prepare for unit test the developer/tester
must perform several tasks. These are:
• (i) plan the general approach to unit testing;
• (ii) design the test cases, and test procedures
(these will be attached to the test plan);
• (iii) define relationships between the tests;
• (iv) prepare the auxiliary code necessary for
unit test.
Unit Test Planning
• A general unit test plan should be prepared. It may be
prepared as a component of the master test plan or as a
stand-alone plan. It should be developed in conjunction
with the master test plan and the project plan for each
project.
• Documents that provide inputs for the unit test plan are
the project plan, as well the requirements, specification,
and design documents that describe the target units.
• Components of a unit test plan are described in detail
the IEEE Standard for Software Unit Testing
• Phase 1: Describe Unit Test Approach and
Risks
• Phase 2: Identify Unit Features to be Tested
• Phase 3: Add Levels of Detail to the Plan
Designing the Unit Tests
• It is important to specify (i) the test cases
(including input data, and expected outputs
for each test case), and, (ii) the test
procedures (steps required run the tests).
The Class as a Testable Unit: Special
Considerations
• If an organization is using the object-oriented
paradigm to develop software systems it will
need to select the component to be
considered for unit test.
• Some of these issues are raised
• Issue 1: Adequately Testing Classes
• Issue 2: Observation of Object States and
State Changes
• Issue 3: The Retesting of Classes—I
• Issue 4: The Retesting of Classes—II
The Test Harness
• In addition to developing the test cases, supporting code
must be developed to exercise each unit and to connect it
to the outside world. Since the tester is considering a
stand-alone function/procedure/class, rather than a
complete system, code will be needed to call the target
unit, and also to represent modules that are called by the
target unit.
• This code called the test harness, is developed especially
for test and is in addition to the code that composes the
system under development. The role is of the test harness
is shown in Figure
• The auxiliary code developed to support
testing of units and components is called a
test harness. The harness consists of drivers
that call the target code and stubs that
represent modules it calls.
• The development of drivers and stubs requires testing
resources. The drivers and stubs must be tested
themselves to insure they are working properly and that
they are reusable for subsequent releases of the software.
• Drivers and stubs can be developed at several levels of
functionality. For
• example, a driver could have the following options and
combinations of options:
• (i) call the target unit;
• (ii) do 1, and pass inputs parameters from a table;
• (iii) do 1, 2, and display parameters;
• (iv) do 1, 2, 3 and display results (output parameters).
• The stubs could also exhibit different levels of
functionality. For example a stub could:
• (i) display a message that it has been called
by the target unit;
• (ii) do 1, and display any input parameters
passed from the target unit;
• (iii) do 1, 2, and pass back a result from a
table;
• (iv) do 1, 2, 3, and display result from table.
Running the Unit Tests and Recording
Results
• Unit tests can begin when
• (i) the units becomes available from the developers
(an estimation of availability is part of the test plan),
• (ii) the test cases have been designed and reviewed,
and
• (iii) the test harness, and any other supplemental
supporting tools, are available.
• The testers then proceed to run the tests and
record results.
Integration Test: Goals
• Integration test for procedural code has two
major goals:
• (i) to detect defects that occur on the
interfaces of units;
• (ii) to assemble the individual units into
working subsystems and finally a complete
system that is ready for system test.
• There is some simple testing of unit interfaces
when the units interact with drivers and stubs.
However,
• the interfaces are more adequately tested
during integration test when each unit is
finally connected to a full and working
implementation of those units it calls, and
those that call it.
Integration Strategies for Procedures and
Functions
• For conventional procedural/functional-
oriented systems there are two major
integration strategies—top-down and bottom-
up.
• In both of these strategies only one module at a
time is added to the growing subsystem.
• To plan the order of integration of the modules
in such system a structure chart such as shown
in Figure
• Structure charts, or call graphs as they are
otherwise known, are used to guide integration.
These charts show hierarchical calling relationships
between modules.
• Each node, or rectangle in a structure chart,
represents a module or unit, and the edges or lines
between them represent calls between the units.
• In the simple chart in Figure 6.6 the rectangles M1–
M11 represent all the system modules.
• Again, a line or edge from an upper-level module to
one below it indicates that the upper level module
calls the lower module.
Integration Strategies for Classes
• A cluster consists of classes that are related,
for example, they may work together
(cooperate) to support a required
functionality for the complete system.
Designing Integration Tests
Integration Test Planning
• Integration test must be planned. Planning can begin
when high-level design is complete so that the system
architecture is defined. Other documents relevant to
integration test planning are the requirements
document, the user manual, and usage scenarios.
• These documents contain structure charts, state charts,
data dictionaries, cross-reference tables, module
interface descriptions, data flow descriptions, messages
and event descriptions, all necessary to plan integration
tests. The strategy for integration should be defined.
System Test: The Different Types
• System test planning should begin at the requirements phase with
the development of a master test plan and requirements-based
(black box) tests.
• The goal is to ensure that the system performs according to its
requirements.
• System test evaluates both functional behavior and quality
requirements such as reliability, usability, performance and
security.
• This phase of testing is especially useful for detecting external
hardware and software interface defects, for example, those
causing race conditions, deadlocks, problems with interrupts and
exception handling, and ineffective memory usage.
There are several types of system tests:
• Functional testing
• Performance testing
• Stress testing
• Configuration testing
• Security testing
• Recovery testing
• Two other types of system testing called
reliability and usability testing.
Functional Testing
• Functional tests at the system level are used to ensure that
the behavior of the system adheres to the requirements
specification.
• All functional requirements for the system must be
achievable by the system.
• For example, if a personal finance system is required to
allow users to set up accounts, add, modify, and delete
entries in the accounts, and print reports, the function-
based system and acceptance tests must ensure that the
system can perform these tasks.
• Clients and users will expect this at acceptance test time.
• Functional tests are black box in nature. The focus is
on the inputs and proper outputs for each function.
The tests should focus on the following goals.
• All types or classes of legal inputs must be accepted by
the software.
• All classes of illegal inputs must be rejected (however,
the system should remain available).
• All possible classes of system output must exercised
and examined.
• All effective system states and state transitions must
be exercised and examined.
• All functions must be exercised.
Performance Testing
• An examination of a requirements document
shows that there are two major types of
requirements:
• 1. Functional requirements.
• 2. Quality requirements.
Stress Testing
• When a system is tested with a load that
causes it to allocate its resources in maximum
amounts, this is called stress testing.
• The goal of stress test is to try to break the
system; find the circumstances under which it
will crash. This is sometimes called “breaking
the system.”
Configuration Testing
• Configuration testing allows developers/
testers to evaluate system performance and
availability when hardware exchanges and
reconfigurations occur.
• Configuration testing also requires many
resources including the multiple hardware
devices used for the tests.
• According to Beizer configuration testing has
the following objectives:
• Show that all the configuration changing
commands and menus work properly.
• Show that all interchangeable devices are really
interchangeable, and that they each enter the
proper states for the specified conditions.
• Show that the systems’ performance level is
maintained when devices are interchanged, or
when they fail.
• Security Testing
• Configuration testing
• Alpha and Beta , Accepatance Testing