Software Testing Printed Full Notes
Software Testing Printed Full Notes
Testing Methods:
1. Static Testing
2. Dynamic Testing
Static Testing: It is also known as Verification in Software Testing. Verification is
a static method of checking documents and files. Verification is the process, to
ensure that whether we are building the product right i.e., to verify the
requirements which we have and to verify whether we are developing the product
accordingly or not.
Activities involved here are Inspections, Reviews, Walkthroughs
Testing Approaches:
There are three types of software testing approaches.
White Box Testing: It is also called as Glass Box, Clear Box, Structural
Testing. White Box Testing is based on application’s internal code structure.
In white-box testing, an internal perspective of the system, as well as
programming skills, are used to design test cases. This testing is usually
done at the unit level.
Black Box Testing: It is also called as Behavioral/Specification-
Based/Input-Output Testing. Black Box Testing is a software testing method
in which testers evaluate the functionality of the software under test without
looking at the internal code structure.
Grey Box Testing: Grey box is the combination of both White Box and
Black Box Testing. The tester who works on this type of testing needs to
have access to design documents. This helps to create better test cases in this
process.
Testing Levels:
1. Unit Testing
2. Integration Testing
3. System Testing
4. Acceptance Testing
Unit Testing: Unit Testing is done to check whether the individual modules
of the source code are working properly. i.e. testing each and every unit of
the application separately by the developer in the developer’s environment.
It is AKA Module Testing or Component Testing. To learn about Unit
Testing, check out our detailed Unit Testing Guide
Integration Testing: Integration Testing is the process of testing the
connectivity or data transfer between a couple of unit tested modules. It is
AKA I&T Testing or String Testing. It is subdivided into the Top-Down
Approach, Bottom-Up Approach, and Sandwich Approach (Combination of
Top-Down and Bottom-Up). To learn about Integration Testing, check out
our detailed Integration Testing Guide
System Testing (end to end testing): It’s a black box testing. Testing the
fully integrated application this is also called as an end to end scenario
testing. To ensure that the software works in all intended target systems.
Verify thorough testing of every input in the application to check for desired
outputs. Testing of the user’s experiences with the application.
Acceptance Testing: To obtain customer sign-off so that software can be
delivered and payments received. Types of Acceptance Testing are Alpha,
Beta & Gamma Testing.
Testing Artifacts:
Test Artifacts are the deliverables that are given to the stakeholders of a software
project. A software project which follows SDLC undergoes the different phases
before delivering to the customer. In this process, there will be some deliverables
in every phase. Some of the deliverables are provided before the testing phase
commences and some are provided during the testing phase and rest after the
testing phase is completed.
Test plan
Traceability matrix
Test case
Test script
Test suite
Test data or Test Fixture
Test harness
Some of the reasons why software testing becomes a very significant and integral
part in the field of information technology are as follows.
1. Cost-effectiveness
2. Customer Satisfaction
3. Security
4. Product Quality
1. Cost-effectiveness
As a matter of fact, design defects can never be completely ruled out for any
complex system. It is not because developers are careless but because the
complexity of a system is intractable. If the design issues go undetected, then it
will become more difficult to trace back defects and rectify it. It will become more
expensive to fix it. Sometimes, while fixing one bug we may introduce another one
in some other module unknowingly. If the bugs can be identified in the early stages
of development then it costs much less to fix them. That is why it is important to
find defects in the early stages of the software development life cycle. One of the
benefits of testing is cost-effectiveness.
It is better to start testing earlier and introduce it in every phase of the software
development life cycle and regular testing is needed to ensure that the application
is developed as per the requirement.
2. Customer Satisfaction
In any business, the ultimate goal is to give the best customer satisfaction. Yes,
customer satisfaction is very important. Software testing improves the user
experience of an application and gives satisfaction to the customers. Happy
customers mean more revenue for a business. One of the reasons why software
testing is necessary is to provide the best user experience.
3. Security
This is probably the most sensitive and vulnerable part of software testing. Testing
(penetration testing & security testing) helps in product security. Hackers gain
unauthorized access to data. These hackers steal user information and use it for
their benefit. If your product is not secured, users won’t prefer your product. Users
always look for trusted products. Testing helps in removing vulnerabilities in the
product.
4. Product Quality
Software Testing is an art that helps in strengthening the market reputation of a
company by delivering the quality product to the client as mentioned in the
requirement specification documents.
Missing: A requirement of the customer that was not fulfilled. This is a variance
from the specifications, an indication that a specification was not implemented, or
a requirement of the customer was not noted correctly.
Extra: A requirement incorporated into the product that was not given by the end
customer. This is always a variance from the specification, but may be an attribute
desired by the user of the product. However, it is considered a defect because it’s a
variance from the existing requirements.
Unit Testing
It is a method by which individual units of source code are tested to
determine if they are fit for use.
Integration Testing
Here individual software modules are combined and tested as a group.
Functionality Testing
It is a type of black box testing that bases its test cases on the specifications
of the software component under test.
Usability Testing
It is a technique used to evaluate a product by testing it on users.
System Testing
It is testing conducted on a complete, integrated system to evaluate the
system’s compliance with its specified requirements.
Performance Testing
It is testing that is performed, to determine how fast some aspect of a system
performs under a particular workload.
Load Testing
It refers to the practice of modeling the expected usage of a software
program by simulating multiple users accessing the program concurrently.
Stress Testing
It is a form of testing that is used to determine the stability of a given system
or entity.
Debugging :
In the context of software engineering, debugging is the process of fixing a bug in
the software. In other words, it refers to identifying, analyzing and removing
errors. This activity begins after the software fails to execute properly and
concludes by solving the problem and successfully testing the software. It is
considered to be an extremely complex and tedious task because errors need to be
resolved at all stages of debugging.
Debugging Process: Steps involved in debugging are:
Problem identification and report preparation.
Assigning the report to software engineer to the defect to verify that it is
genuine.
Defect Analysis using modeling, documentations, finding and testing
candidate flaws, etc.
Defect Resolution by making required changes to the system.
Validation of corrections.
Debugging Strategies:
1. Study the system for the larger duration in order to understand the system. It
helps debugger to construct different representations of systems to be
debugging depends on the need. Study of the system is also done actively to
find recent changes made to the software.
2. Backwards analysis of the problem which involves tracing the program
backward from the location of failure message in order to identify the region
of faulty code. A detailed study of the region is conducting to find the cause of
defects.
3. Forward analysis of the program involves tracing the program forwards using
breakpoints or print statements at different points in the program and studying
the results. The region where the wrong outputs are obtained is the region that
needs to be focused to find the defect.
4. Using the past experience of the software debug the software with similar
problems in nature. The success of this approach depends on the expertise of
the debugger.
Debugging Tools:
Debugging tool is a computer program that is used to test and debug other
programs. A lot of public domain software like gdb and dbx are available for
debugging. They offer console-based command line interfaces. Examples of
automated debugging tools include code based tracers, profilers, interpreters, etc.
Some of the widely used debuggers are:
Radare2
WinDbg
Valgrind
Difference Between Debugging and Testing:
Debugging is different from testing. Testing focuses on finding bugs, errors, etc
whereas debugging starts after a bug has been identified in the software. Testing is
used to ensure that the program is correct and it was supposed to do with a certain
minimum success rate. Testing can be manual or automated. There are several
different types of testing like unit testing, integration testing, alpha and beta
testing, etc.
Debugging requires a lot of knowledge, skills, and expertise. It can be supported
by some automated tools available but is more of a manual process as every bug is
different and requires a different technique, unlike a pre-defined testing
mechanism.
Unit 2 : Approaches to Testing -I
Example
A tester, usually a developer as well, studies the implementation code of a certain
field on a webpage, determines all legal (valid and invalid) AND illegal inputs and
verifies the outputs against the expected outcomes, which is also determined by
studying the implementation code.
White Box Testing is like the work of a mechanic who examines the engine to see
why the car is not moving.
White Box Testing method is applicable to the following levels of software testing:
Unit Testing: For testing paths within a unit.
Integration Testing: For testing paths between units.
System Testing: For testing paths between subsystems.
Advantages
Testing can be commenced at an earlier stage. One need not wait for the
GUI to be available.
Testing is more thorough, with the possibility of covering most paths.
Disadvantages
Since tests can be very complex, highly skilled resources are required, with a
thorough knowledge of programming and implementation.
Test script maintenance can be a burden if the implementation changes too
frequently.
Since this method of testing is closely tied to the application being tested,
tools to cater to every kind of implementation/platform may not be readily
available.
Black box test design technique: Procedure to derive and/or select test
cases based on an analysis of the specification, either functional or non-
functional, of a component or system without reference to its internal
structure.
Example
A tester, without knowledge of the internal structures of a website, tests the web
pages by using a browser; providing inputs (clicks, keystrokes) and verifying the
outputs against the expected outcome.
Black Box Testing method is applicable to the following levels of software testing:
Integration Testing
System Testing
Acceptance Testing
The higher the level, and hence the bigger and more complex the box, the more
black-box testing method comes into use.
Techniques
Following are some techniques that can be used for designing black box tests.
Advantages
Tests are done from a user’s point of view and will help in exposing
discrepancies in the specifications.
Tester need not know programming languages or how the software has been
implemented.
Tests can be conducted by a body independent from the developers,
allowing for an objective perspective and the avoidance of developer-bias.
Test cases can be designed as soon as the specifications are complete.
Disadvantages
Only a small number of possible inputs can be tested and many program
paths will be left untested.
Without clear specifications, which is the situation in many projects, test
cases will be difficult to design.
Tests can be redundant if the software designer/developer has already run a
test case.
Example
An example of Gray Box Testing would be when the codes for two units/modules
are studied (White Box Testing method) for designing test cases and actual tests
are conducted using the exposed interfaces (Black Box Testing method).
Unit Testing
Unit Testing is a software testing technique by means of which individual units of
software i.e. group of computer program modules, usage procedures and operating
procedures are tested to determine whether they are suitable for use or not. It is a
testing method using which every independent modules are tested to determine if
there are any issue by the developer himself. It is correlated with functional
correctness of the independent modules.
Unit Testing is defined as a type of software testing where individual components
of a software are tested.
Unit Testing of software product is carried out during the development of an
application. An individual component may be either an individual function or a
procedure. Unit Testing is typically performed by the developer.
In SDLC or V Model, Unit testing is first level of testing done before integration
testing. Unit testing is such type of testing technique that is usually performed by
the developers. Although due to reluctance of developers to tests, quality assurance
engineers also do unit testing.
Integration testing
The meaning of Integration testing is quite straightforward- Integrate/combine the
unit tested module one by one and test the behavior as a combined unit.
The main function or goal of this testing is to test the interfaces between the
units/modules.
We normally do Integration testing after “Unit testing”. Once all the individual
units are created and tested, we start combining those “Unit Tested” modules and
start doing the integrated testing.
The main function or goal of this testing is to test the interfaces between the
units/modules.
The individual modules are first tested in isolation. Once the modules are unit
tested, they are integrated one by one, till all the modules are integrated, to check
the combinational behavior, and validate whether the requirements are
implemented correctly or not.
Here we should understand that Integration testing does not happen at the end of
the cycle, rather it is conducted simultaneously with the development. So in most
of the times, all the modules are not actually available to test and here is what the
challenge comes to test something which does not exist!
Why Integration Test?
We feel that Integration testing is complex and requires some development and
logical skill. That’s true! Then what is the purpose of integrating this testing into
our testing strategy?
Some reasons:
1. In the real world, when applications are developed, it is broken down into
smaller modules and individual developers are assigned 1 module. The logic
implemented by one developer is quite different than another developer, so it
becomes important to check whether the logic implemented by a developer
is as per the expectations and rendering the correct value in accordance with
the prescribed standards.
2. Many a time the face or the structure of data changes when it travels from
one module to another. Some values are appended or removed, which causes
issues in the later modules.
3. Modules also interact with some third party tools or APIs which also need to
be tested that the data accepted by that API / tool is correct and that the
response generated is also as expected.
4. A very common problem in testing – Frequent requirement change! :) Many
a time developer deploys the changes without unit testing it. Integration
testing becomes important at that time.
Advantages
This testing makes sure that the integrated modules/components work
properly.
Integration testing can be started once the modules to be tested are available.
It does not require the other module to be completed for testing to be done,
as Stubs and Drivers can be used for the same.
It detects the errors related to the interface.
Challenges Listed below are few challenges that are involved in
Integration Test.
1) Integration testing means testing two or more integrated systems in order to
ensure that the system works properly. Not only the integration links should be
tested but an exhaustive testing considering the environment should be done to
ensure that the integrated system works properly.
There might be different paths and permutations which can be applied to test the
integrated system.
2) Managing Integration testing becomes complex because of few factors involved
in it like the database, Platform, environment etc.
3) While integrating any new system with the legacy system, it requires a lot of
changes and testing efforts. Same applies while integrating any two legacy
systems.
4) Integrating two different systems developed by two different companies is a big
challenge as for how one of the systems will impact the other system if any
changes are done in any one of the systems is not sure.
In order to minimize the impact while developing a system, few things should be
taken into consideration like possible integration with other systems, etc.
1. Bottom-up approach
2. Top-down approach.
Let’s consider the below figure to test the approaches:
Bottom-up approach:
Bottom-up testing, as the name suggests starts from the lowest or the innermost
unit of the application, and gradually moves up. The Integration testing starts from
the lowest module and gradually progresses towards the upper modules of the
application. This integration continues till all the modules are integrated and the
entire application is tested as a single unit.
In this case, modules B1C1, B1C2 & B2C1, B2C2 are the lowest module which is
unit tested. Module B1 & B2 are not yet developed. The functionality of Module
B1 and B2 is that it calls the modules B1C1, B1C2 & B2C1, B2C2. Since B1 and
B2 are not yet developed, we would need some program or a “stimulator” which
will call the B1C1, B1C2 & B2C1, B2C2 modules. These stimulator programs are
called DRIVERS.
In simple words, DRIVERS are the dummy programs which are used to call the
functions of the lowest module in a case when the calling function does not exist.
The bottom-up technique requires module driver to feed test case input to the
interface of the module being tested.
The advantage of this approach is that, if a major fault exists at the lowest unit of
the program, it is easier to detect it, and corrective measures can be taken.
The disadvantage is that the main program actually does not exist until the last
module is integrated and tested. As a result, the higher level design flaws will be
detected only at the end.
Top-down approach
This technique starts from the topmost module and gradually progress towards the
lower modules. Only the top module is unit tested in isolation. After this, the lower
modules are integrated one by one. The process is repeated until all the modules
are integrated and tested.
In the context of our figure, testing starts from Module A, and lower modules B1
and B2 are integrated one by one. Now here the lower modules B1 and B2 are not
actually available for integration. So in order to test the topmost modules A, we
develop “STUBS”.
“Stubs” can be referred to as code a snippet which accepts the inputs/requests from
the top module and returns the results/ response. This way, in spite of the lower
modules, do not exist, we are able to test the top module.
In practical scenarios, the behavior of stubs is not that simple as it seems. In this
era of complex modules and architecture, the called module, most of the time
involves complex business logic like connecting to a database. As a result, creating
Stubs becomes as complex and time taking as the real module. In some cases, Stub
module may turn out to be bigger than the stimulated module.
Both Stubs and drivers are dummy piece of code which is used for testing the
“non- existing” modules. They trigger the functions/method and return the
response, which is compared to the expected behavior
Let’s conclude some difference between Stubs and Driver:
Stubs Driver
Top most module is tested first Lowest modules are tested first.
Stimulates the lower level of components Stimulates the higher level of components
Dummy program of lower level components Dummy program for Higher level component
The only change is Constant in this world, so we have another approach called
“Sandwich testing” which combines the features of both Top-down and bottom-
up approach. When we test huge programs like Operating systems, we have to
have some more techniques which are efficient and boosts more confidence.
Sandwich testing plays a very important role here, where both, the Top down and
bottom up testing are started simultaneously.
Integration starts with the middle layer and moves simultaneously towards up and
down. In case of our figure, our testing will start from B1 and B2, where one arm
will test the upper module A and another arm will test the lower modules B1C1,
B1C2 & B2C1, B2C2.
Since both the approach starts simultaneously, this technique is a bit complex and
requires more people along with specific skill sets and thus adds to the cost.
GenNext software developed this product for me and below was the architecture:
UI – User Interface module, which is visible to the end user, where all the inputs
are given.
BL – Is the Business Logic module, which has all the all the calculations and
business specific methods.
VAL – Is the Validation module, which has all the validations of the correctness of
the input.
CNT – Is the content module which has all the static contents, specific to the
inputs entered by the user. These contents are displayed in the reports.
EN – Is the Engine module, this module reads all the data that comes from BL,
VAL and CNT module and extracts the SQL query and triggers it to the database.
Scheduler – Is a module which schedules all the reports based on the user
selection (monthly, quarterly, semiannually & annually)
DB – Is the Database.
Now, having seen the architecture of the entire web application, as a single unit,
Integration testing, in this case, will focus on the flow of data between the
modules.
Steps to Kick off Integration Tests
1. Understand the architecture of your application.
2. Identify the modules
3. Understand what each module does
4. Understand how the data is transferred from one module to another.
5. Understand how the data is entered and received into the system ( entry
point and exit point of the application)
6. Segregate the application to suit your testing needs.
7. Identify and create the test conditions
8. Take one condition at a time and write down the test cases.
So, it’s not specific that integration testing is a black box or white box technique.
Once all the modules are tested, system integration testing is done by integrating
all the modules and the system as a whole is tested.
System testing is a testing where the system as a whole is tested i.e. all the
modules/components are integrated together to verify whether the system works as
expected and no issues occur because of the integrated modules.
Unit 3 : Testing for Specialized Environment
Test Environment for Software Testing
A testing environment is a setup of software and hardware for the testing teams to
execute test cases. In other words, it supports test execution with hardware,
software and network configured.
Test bed or test environment is configured as per the need of the Application
Under Test. On a few occasion, test bed could be the combination of the test
environment and the test data it operates.
Tests are limited to what can be tested and what not should be tested.
System Admins,
Developers
Testers
Sometimes users or techies with an affinity for testing.
The test environment requires setting up of various number of distinct areas like,
Setup of Test Server
Every test may not be executed on a local machine. It may need establishing a test
server, which can support applications.
For example, Fedora set up for PHP, Java-based applications with or without mail
servers, cron set up, Java-based applications, etc.
Network
Internet setup
LAN Wifi setup
Private network setup
It ensures that the congestion that occurs during testing doesn't affect other
members. (Developers, designers, content writers, etc.)
Test PC setup
For web testing, you may need to set up different browsers for different testers. For
desktop applications, you need various types of OS for different testers PCs.
Bug Reporting
Many companies use a separate test environment to test the software product. The
common approach used is to copy production data to test. This helps the tester, to
detect the same issues as a live production server, without corrupting the
production data.
Testers or developers can copy this to their individual test environment. They can
modify it as per their requirement.
Privacy is the main issue in copy production data. To overcome privacy issues you
should look into obfuscated and anonymized test data.
BlackList: In this approach, all the data fields are left unchanged. Except
those fields specified by the users.
WhiteList: By default, this approach, anonymizes all data fields. Except for
a list of fields which are allowed to be copied. A whitelisted field implies
that it is okay to copy the data as it is and anonymization is not required.
Also, if you are using production data, you need to be smart about how to source
data. Querying the database using SQL script is an effective approach.
Test Environment Management deals with the maintenance and upkeep of the test
bed.
Besides these, there are a few more questions to answer before setting up the test
environment.
Whether to develop an internal Test Environment or to outsource?
Whether to follow an internal company standard or follow any External
(IEE, ISO, etc.)?
How long the test environment is required?
Differences between the test and production systems and their impact on test
validity must be determined.
Can you re-use an existing setup for other projects in the company?
Ineffective planning for resource usage can affect the actual output. Also, it
may lead to conflict between teams.
2. Remote environment
Summary:
This type of testing usually done for 2 tier applications (usually developed for
LAN). Here we will be having Front-end and Backend.
The application launched on front-end will be having forms and reports which will
be monitoring and manipulating data
For Example, applications developed in VB, VC++, Core Java, C, C++, D2K,
PowerBuilder, etc., The backend for these applications would be MS Access, SQL
Server, Oracle, Sybase, Mysql, Quadbase
The tests performed on these types of applications would be
User Interface Testing
Manual Support Testing
Functionality Testing
Compatibility Testing & Configuration Testing
Intersystem Testing
WEB TESTING
This is done for 3 tier applications (developed for Internet / intranet / xtranet)
Here we will be having Browser, web server and DB server.
Applications for the webserver would be developed in Java, ASP, JSP, VBScript,
JavaScript, Perl, Cold Fusion, PHP, etc. (All the manipulations are done on the
webserver with the help of these programs developed)
The DB server would be having Oracle, SQL Server, Sybase, MySQL, etc. (All
data is stored in the database available on the DB server)
The types of tests, which can be applied to this type of applications, are
User Interface Testing for validation & user-friendliness
Functionality Testing to validate behaviors, i/p, error handling, o/p,
manipulations, services levels, the order of functionality, links, content of
web page & backend coverage’s
Security Testing
Browser Compatibility
Load/Stress Testing
Interoperability Testing
Storage & Data Volume Testing
A Client-Server Application is a Two-Tier Application
This has forms & reporting at front-end (monitoring & manipulations are done)
[using vb, vc++, core java, c, c++, d2k, power builder etc.,] -> database server at
the backend [data storage & retrieval) [using ms access, SQL Server, Oracle,
Sybase, MySQL, quad base etc.,]
For Client-Server application users are well known, whereas for web application
any user can log in and access the content, he/she will use it as per his intentions.
So, there are always issues of security and compatibility for a Web Application.
Testing Documentation
Documentation as part of process
Testing documentation is usually associated with the documentation of artifacts
that should be developed before or during the testing of software.
Test Plan.
Test Case.
Test Scenario.
Traceability Matrix.
Test Plan
A Test plan outlines the common strategy that will be applied to test an
application, the resources that will be used, the test environment in which testing
will be performed, and the schedule of testing activities along with the limitations.
Typically writing a Test Plan is the competence of the Quality Assurance Team
Lead.
Test plan outlines the common strategy that will be applied to test an application.
Test case is a complexity of inputs, serious of steps, and conditions that can be
used during the process of testing. The key point of this activity is to find out
whether a software is successful in terms of its functionality and other aspects.
There are various types of test cases such as logical, functional, error, negative test
cases, physical test cases, UI test cases, etc.
What's more, test cases are written to keep track of the software testing coverage.
Basically, there are no formal templates that can be used while writing a test case.
Test case is a complexity of inputs, serious of steps, and conditions that can be
used during the process of testing.
A single test scenario can be applied to many test cases. In addition, sometimes
numerous test cases are written for a single software which are collectively known
as test suites.
Test Step – is the smallest unit of testing. This is the minimum action which is
done by a tester during testing. As an example, a good test scenario is the wish to
brush your teeth. Rather simple and clear wish, I may say. The test case can be
performed by the process of squeezing a toothpaste from the tube. This process can
easily be divided into smaller steps, such as: taking the tube, unscrewing the cap,
pressing it until there is enough toothpaste etc.
Test Scenario
Test scenarios are used to ensure that all process flows are thoroughly tested.
The terms 'test scenario' and 'test cases' are sometimes used interchangeably,
however a test scenario usually consists of several steps, whereas a test case has a
single step. Taking this into account, test scenarios are test cases, but they include
several test cases and the sequence that they should be executed. Moreover, each
test relies on the output from the previous test.
Traceability Matrix
Traceability Matrix is a table that is used to trace the requirements during the
Software Development Life Cycle.
Each requirement in the RTM document is linked with its associated test case so
that testing can be done as per the mentioned requirements. Moreover, Bug ID is
also included and linked with its associated requirements and test case.
In the field of software testing, real time testing refers to the process of testing the
real time software product or system i.e. the system is constrained by some specific
time limits to perform and complete the job. Air Traffic Control and space
navigation system, may be seen as the examples of real time system, i.e. they
responses in real time.
First of all, real time systems are associated with the time-constraints as such
testing the system endorsed with the deadlines and real-time responses may seems
to be a tedious & complex job. Moreover, the results being generated by the real
time systems are non –predictable and have non-deterministic outcomes as such
conventional methods may not prove to be effective to test the real time systems.
Further, analyzing and testing the real time systems may be carried out in various
ways as such it would not recommendable to rely on one strategy or approach, i.e.
it would need exhaustive type of testing to evaluate the real time system and
thereby, may prove to be a time-consuming and expensive process.
How to do it?
Real time testing technique follow a simple and basic strategy to execute the
testing task, as described below:
Task Testing
Behavioral Testing
The simulated real environment is being created based on the design model
with the help of automated tools to study the behaviour of the system under
the impact of external forces.
Intertask Testing
After getting through the task of revealing errors in code and behavorial
aspect of the system, time-constraints are being introduced through intertask
testing.
System Testing
Tools
Below mentioned are some of the testing tools to perform testing on real
time systems.
o TTCN-3
Unit 4 : Software Testing Strategies and Software
Matrices
Strategy of testing
Integration testing
An integration testing focuses on the construction and design of the software.
Validation testing
Check all the requirements like functional, behavioral and performance
requirement are validate against the construction software.
System testing
System testing confirms all system elements and performance are tested entirely.
As per the procedural point of view the testing includes following steps.
1) Unit testing
2) Integration testing
3) High-order tests
4) Validation testing
These steps are shown in following figure:
1) Unit testing
Unit testing focus on the smallest unit of software design, i.e module or software
component.
Test strategy conducted on each module interface to access the flow of input and
output.
The local data structure is accessible to verify integrity during execution.
Boundary conditions are tested.
In which all error handling paths are tested.
An Independent path is tested.
Following figure shows the unit testing:
Stub Driver
Stub is considered as subprogram. It is a simple main program.
Stub does not accept test case data. Driver accepts test case data.
It replace the modules of the program into subprograms Pass the data to the tested components and
and are tested by the next driver. print the returned result.
2) Integration testing
a. Top-down integration
b. Bottom-up integration
In bottom up integration testing the components are combined from the lowest
level in the program structure.
3) Regression testing
In regression testing the software architecture changes every time when a new
module is added as part of integration testing.
4) smoke testing
The developed software component are translated into code and merge to
complete the product.
Difference between Regression and smoke testing
Definition
During the process of manufacturing a ballpoint pen, the cap, the body, the tail, the
ink cartridge and the ballpoint are produced separately and unit tested separately.
When two or more units are ready, they are assembled and Integration Testing is
performed. When the complete pen is integrated, System Testing is performed.
Method
Usually, Black Box Testing method is used.
Tasks
When is it performed?
System Testing is the third level of software testing performed after Integration
Testing and before Acceptance Testing.
Who performs it?
Normally, independent Testers perform System Testing.
This test is mainly performed to check whether the software meets the expected
requirements for application speed, scalability, and stability
Generally, Stress Testing has an incremental approach where the load is increased
gradually. The test is started with a load for which the application has already been
tested. Then, more load is added slowly to stress the system. The point at which we
start seeing servers not responding to the requests is considered the breaking point.
Capacity Testing
=> Is the application capable of meeting business volume under both normal and
peak load conditions?
Online Banking is a perfect example of where capacity testing could play a major
role.
Reliability/Recovery Testing
If an online trading site experiences a failure where the users are not able to
buy/sell shares at a certain point of the day (peak hours) but are able to do so after
an hour or two, we can say the application is reliable or recovered from the
abnormal behavior.
Performance Test Process
Here are all the activities performed in this testing:
1) Requirement Analysis/Gathering
The performance team interacts with the client for identification and gathering of
requirements – technical and business. This includes getting information on the
application's architecture, technologies, and database used, intended users,
functionality, application usage, test requirement, hardware & software
requirements, etc.
2) POC/Tool selection
Once the key functionality is identified, POC (Proof Of Concept – which is a sort
of demonstration of the real-time activity but in a limited sense) is done with the
available tools.
The list of available tools depends on the cost of the tool, protocol that application
is using, the technologies used to build the application, the number of users we are
simulating for the test, etc. During POC, scripts are created for the identified key
functionality and executed with 10-15 virtual users.
Test Planning involves information on how the performance test is going to take
place – test environment, workload, hardware, etc.
Some of the best practices that help the Result Analysis process:
1. A unique and meaningful name to every test result – this helps in
understanding the purpose of the test.
2. Include the following information in the test result summary:
Reason for the failure/s
Change in the performance of the application compared to the previous test
run
Changes made in the test from the point of application build or test
environment.
It’s a good practice to make a result summary after each test run so that
analysis results are not compiled every time test results are referred.
PT generally requires many test runs to reach the correct conclusion.
It is good to have the following points in result summary:
Purpose of test
Number of virtual users
Scenario summary
Duration of test
Throughput
Graphs
Graphs comparison
Response Time
Error occurred
Recommendations
8) Report
Test results should be simplified so the conclusion is clearer and should not need
any derivation. Development Team needs more information on analysis,
comparison of results, and details of how the results were obtained.
The test report is considered to be good if it is brief, descriptive and to the point.
How To Write Performance Test Strategy Document?
This tutorial will explain how to write a sample Performance Test Strategy for a
Messaging Application.
Remember, that this is just an example and the requirements will differ from one
client to another, we will also get to know the best practices for Performance
Testing in this tutorial.
About ABC chat Application – Let’s assume that this is a chat workbench that is
used in a company by their customer support agent, this chat application uses
XMPP protocol i.e, Extensible Messaging and Presence Protocol and Open fire
server for sending and receiving Instant messages.
Some enhancements have been made to this existing chat client like Remote PC
control, PC diagnosis, Repair tools, Online chat, etc., so this performance Test
strategy is a sample of such applications.
For this application let’s assume that the project team has decided to use JMeter for
Performance Testing and JIRA for defect tracking.
The first page of the Performance Test Strategy document should contain
Title of the Document and the Copyrights of the Company.
The second page should contain Document Control which includes, Document
Version history, Reviewers & Approvers list and Contributors list.
The third page should contain the Table of contents, followed by the below
topics.
1) Introduction
The purpose of this document is to define/explain how Performance Testing will
be performed on the ABC chat application for the current and future state.
Objective
The key objectives of Performance Testing are as follows:
To gain the confidence that the changes to the existing chat application are
in line with the defined Service Level Agreement.
To ensure that the application performance, service availability, and the
stability of the application are not impacted as a result of the new
enhancements.
Transaction Response Times remain within the acceptable tolerance over the
increasing Load profile.
JVMs show stable memory usage over the increasing load profiles.
The below picture clearly explains Performance Testing & Optimization
process:
Architecture
You need to incorporate the architecture diagram of your project in this session.
2) Scope
Below is the Performance Testing scope for ABC chat workbench:
Knowledge acquisition of the key business transactions and build load
distribution after a detailed study of the system.
Identify the critical scenarios for performance testing with assistance from
different project tracks.
Use the previous release results as a baseline for future releases.
Verify and validate the performance test environment and the
Performance/Load test tool infrastructure for any additional Agent
Machines.
Preparation of performance test scripts using JMeter for the identified
scenarios that mimic the identified peak load.
Setup performance monitoring on the servers for monitoring the test in order
to identify the bottlenecks during the test execution phase.
Publish Performance test results.
Coordinate with various stakeholders to resolve the identified performance
issues.
Baseline the performance level for future releases.
Out of Scope
Functional Testing, UAT, System Testing & Security Testing.
Performance testing/monitoring of any third-party interfaces.
Performance Tuning. (Most of the times Tuning is done by a different team,
if in case you have performance engineers to tune the system then you can
add this in the Inscope).
Code profiling / Hardware sizing / Capacity planning.
Security / Vulnerability testing / UAT/ White box testing.
Data generation for Performance Testing.
Non-functional tests (For Example, failover, disaster recovery, back-up,
usability) other than the performance tests.
Testing of any mobile solution.
Third-Party Application Performance Testing & Tuning.
Realization of performance recommendations, Application code changes and
the vendor-supported products/server configuration changes will be out of
scope from the Performance Team perspective.
Infrastructure Support / Build Deployment/ Environment Readiness/
Database Restore/ Network Support etc.
3) Approach
Performance testing for ABC chat will be conducted using Jmeter by writing
custom XMPP plugins that use a smack library for XMPP connections. These
libraries are used to set up connections, login and send chat messages to the XMPP
server.
These libraries are bundled into a jar file that is deployed into the Jmeter and is
designed based on the scenarios to be tested. The Jmeter Work Bench is installed
in the local machine which connects to the JMeter server which has the Load
Generators to generate the required load on the Chat server system to monitor the
system behavior.
The test scenario will be scripted using the JMeter tool. The scripts would be
customized as required. The schedule will be created with the required ramp-up to
simulate the real-world scenarios.
The Test Scenario would be broken up and measured in the below aspects:
a) Baseline Test: To run each scenario with 1 Vuser and multiple iterations in
order to identify whether the application performance meets the business Service
Level Agreement or not.
b) Base Load Test: To meet the Business Benchmark under load test, the
Performance Testing team will perform a baseload test which will help to identify
any system performance issues with increasing load and creates the baseline for the
next level of performance testing.
c) Peak Load / Scalability Test: Performance Testing team will perform multiple
tests with increasing Vusers to meet the expected load and also to measure the
application performance to establish the performance curve and identify whether
the deployment can support the service level agreements under the peak user load.
It helps in tuning or capacity planning of the individual Java virtual machines
(JVM), the total number of required JVMs, and the processors. This will be
achieved by increasing the no of Vusers to 50%, 75%, 100% and 125% of peak
capacity.
d) Endurance Test: Performance Testing team will run this test for a period of 8
Hours / 16 Hours /24 hours to identify memory leaks, performance issues over
time, and overall system stability. During endurance tests, the Performance Testing
team monitors the key performance indicators, such as transaction response times
and the stability of memory usage.
System resources like CPU, Memory, and IO need to be monitored with the help of
the project team.
For Example,
Scenario 1: To validate the Agent and customer chat for X no. of concurrent
sessions.
Performance Test Types
The table given below explains the various types of Performance Tests along
with their objectives.
Test Type Objective
Baseline Test Establish the best performance under specific volumes which will be used as a
reference for subsequent measurements.
Load Test Measure the system performance under anticipated peak production load.
Endurance Measuring the system stability under high volume for an extended period.
Test
1 Transaction Response Time Response time of pages during the steady state of Graph
the performance test
2 Throughput The amount of data that the VUsers received from Graph
the server over time
4 Number of Passed/Failed Total number of transactions that Passed and Failed Excel
Transactions during the test execution
5 Transaction Error Rate The Percentage of transactions that failed during the Graph
test execution
System & Network Performance Metrics
4) Test Data
It is being assumed that the Performance environment data will be a copy of the
production data and the required test data will be provided by the project team.
Major A serious problem was detected for which the workaround exists that might not be c
all the users, however, product should not be released without fixing
Severity Description for Development and Enhancement Problems
Medium Problem exists with easy/simple work around but this type of defect may be release
approval by Business and/or Project Manager
Low Cosmetic issues that do not interfere with business functionality or other inter
problems that are not reproducible every time
Jmeter To verify the Load and Performance of the ABC Chat application.
Test Data not available Testing cannot proceed. Test Data ready
Regression Testing is a type of testing that is done to verify that a code change in
the software does not impact the existing functionality of the product. This is to
make sure the product works fine with new functionality, bug fixes or any change
in the existing feature. Previously executed test cases are re-executed in order to
verify the impact of change.
Regression Testing is the process of testing the modified parts of the code and the
parts that might get affected due to the modifications to ensure that no new errors
have been introduced in the software after the modifications have been made.
Regression means return of something and in the software field, it refers to the
return of a bug.
When to do regression testing?
When a new functionality is added to the system and the code has been
modified to absorb and integrate that functionality with the existing code.
When some defect has been identified in the software and the code is
debugged to fix it.
When the code is modified to optimize its working.
Process of Regression testing:
Firstly, whenever we make some changes to the source code for any reasons like
adding new functionality, optimization, etc. then our program when executed fails
in the previously designed test suite for obvious reasons. After the failure, the
source code is debugged in order to identify the bugs in the program. After
identification of the bugs in the source code, appropriate modifications are made.
Then appropriate test cases are selected from the already existing test suite which
covers all the modified and affected parts of the source code. We can add new test
cases if required. In the end regression testing is performed using the selected test
cases.
Tools for regression testing: In regression testing, we generally select the test
cases form the existing test suite itself and hence, we need not to compute their
expected output and it can be easily automated due to this reason. Automating the
process of regression testing will be very much effective and time saving.
Most commonly used tools for regression testing are:
Selenium
WATIR (Web Application Testing In Ruby)
QTP (Quick Test Professional)
RFT (Rational Functional Tester)
Winrunner
Silktest
Advantages of Regression Testing:
It ensures that no new bugs has been introduced after adding new
functionalities to the system.
As most of the test cases used in Regression Testing are selected from the
existing test suite and we already know their expected outputs. Hence, it can
be easily automated by the automated tools.
It helps to maintain the quality of the source code.
Disadvantages of Regression Testing:
It can be time and resource consuming if automated tools are not used.
It is required even after very small changes in the code.
Unit 5 : Specialized Testing and Testing Tools
Testing Tools:
Tools from a software testing context can be defined as a product that supports
one or more test activities right from planning, requirements, creating a build, test
execution, defect logging and test analysis.
Classification of Tools
Types of Tools:
LoadRunner
LoadRunner is a software testing tool from Micro Focus. It is used to
test applications, measuring system behaviour and performance under load.
LoadRunner can simulate thousands of users concurrently using application
software, recording and later analyzing the performance of key components of the
application.
Learning Resources:
1. Software Engineering – A Practitioners Approach, Roger S.
Pressman, Tata McGraw Hill
https://www.softwaretestingmaterial.com/
https://www.guru99.com/
Websites
2 https://www.softwaretestinghelp.com/
https://www.tutorialspoint.com/