Testing Strategy

Download as ppt, pdf, or txt
Download as ppt, pdf, or txt
You are on page 1of 31

Software Testing

Strategy

1
Testing Strategy
Unit test Integration test

System test Validation test

2
Testing Strategy
• Testing Strategy outlines in broad terms how to use testing to
assess the extent to which the goal for a product has been met.

• Testing Strategy integrates software test case designing


methods into a well planned series of steps that results
in the successful development of a software.

3
Testing Strategy Characteristics
• Testing begins at component level and works towards the
integration of the entire system.

• Different testing techniques at different points of time.

• Testing is conducted by the developer and ITG.

• Testing and debugging are different, but debugging is


accommodated in any testing strategy.

4
Why Testing Strategy?

• Testing often takes more project effort than any


other software engineering activity.

• If it is conducted haphazardly, time is wasted,


unnecessary effort is expended, and even worse,
errors sneak through undetected.

5
The V-Model

6
The W-Model

7
Unit Testing

module
to be
tested

Results
Software Engineer
Test Cases

8
Unit Testing
module
to be
tested
interface
local data structures
boundary conditions
independent paths
error handling paths

test cases

9
Unit Test Environment

driver
interface
local data structures
Module boundary conditions
independent paths
error handling paths

stub stub

test cases
RESULTS

10
Integration Testing Strategies
Options:
• The “big bang” approach
• An incremental construction strategy

Big bang integration testing is an approach that tests an


application when all its modules have been combined into
a single unit. It is similar to testing a complete application
as how an end-user would operate but only through 
test tools, automation testing, etc.(added by me) 11
Top Down Integration

A
top module is tested with
stubs

B F G

stubs are replaced one at


a time, "depth first"
C
as new modules are integrated,
some subset of tests is re-run (regression testing)
D E

12
Steps for integration process
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.

2. Depending on the integration approach selected subordinate stubs are replaced one at a time
with actual components.

3. Tests are conducted as each component is integrated.

4. On completion of each set of tests, another stub is replaced with the real component.

5. Regression testing may be conducted to ensure that new errors have not been introduced.

The process continues from step 2 until the entire program structure is built.

13
Bottom-Up Integration
A

B F G

drivers are replaced one at a


time, "depth first"
C

worker modules are grouped into


builds and integrated
D E

cluster

14
Steps for Bottom Up Integration
1. Low level components are combined into clusters that
perform a specific software sub function.

2. A driver is written to coordinate test case input and output

3. The cluster is tested.

4. Drivers are removed and clusters are combined moving


upward in the program structures

15
Smoke
Testing
Used for “Shrink Wrapped” software and time – critical project

Activities Included in Smoke testing:

1. Software Components are integrated into build

2. A series of tests is designed to expose errors that will keep the


build from properly performing functions

3. The build is integrated with other builds and the entire product is
smoke tested daily. The integration approach may be top down
or bottom up.

16
Smoke
Testing

17
Comments on Integration Testing

1. Stub problem

2. Sandwich testing

3. Critical Module

18
Sandwich Testing
A
Top modules are
tested with stubs

B F G

Worker modules are grouped into


builds and integrated
D E

cluster

19
Validation Testing

Validation:
Validation succeeds when software functions in a manner that can
be reasonably expected by the customer.

Validation Criteria:
• Test plan which conforms the user requirements

Consequences are tackled accordingly.

“Are we building the product right”--------(Verification)


“Are we building the right product”----------(Validation)

20
Alpha and Beta
• Alpha Testing:
Testing
AT is conducted at the developer’s sites by the customer in a
controlled environment.

• Beta Testing:
The beta test is conducted at one or more sites by the end-user of the
software

21
System Testing
 Testing of the software when it interacts with
hardware, people, and information.
 These tests are out of the scope of the software

Types of system Testing:

1. Recovery Testing

2. Security Testing

3. Stress Testing

4. Performance Testing

22
Recovery Testing

 RT is a system test that forces the software to fail


in a variety of ways and verifies that recovery is
properly performed.

Security Testing

 ST attempts to verify that protection mechanisms


built into a system will, in fact, protect it from
improper penetration.

23
Stress Testing

 Stress testing executes a system in a manner that demands


resources in abnormal quantity, frequency, or volume.

Performance Testing

 PT is designed to test the run-time performance of


software within the context of an integrated system.

24
Debugging: A Diagnostic Process

Debugging occurs as a
consequence of successful
testing. That is, when a
test case uncovers an
error, debugging is the
process that results in the
removal of the error.

25
Debugging Process:

26
Debugging Effort

time required to correct time required to


the error and conduct diagnose the
regression tests symptom and
determine the cause

27
Symptoms & Causes
symptom and cause may be
geographically separated

symptom may disappear when


another problem is fixed

cause may be due to a


combination of non-errors
cause may be due to a system
or compiler error

cause may be due to


symptom assumptions that everyone
cause believes

28
Debugging Techniques

brute force / testing

backtracking

cause elimination

29
Debugging: Final Thoughts

1. Don't run off half-cooked, think about the


symptom you're seeing.
2. Use tools (e.g., dynamic debugger) to gain
more insight.
3. If at an impasse, get help from someone else.

4. Be absolutely sure to conduct regression tests


when you do "fix" the bug.

30
Thank You!

31

You might also like