-
There are numerous types of system testing that can be done as part of the system testing and deliver process. Below is a list of test types identified by Guru 99. This is probably the most comprehensive set of tests when planning your quality assurance activities. Naturally, the team selects that group of tests that make the most sense in the circumstances.
- Acceptance Testing:Formal testing conducted to determine whether or not a system satisfies its acceptance criteria and to enable the customer to determine whether or not to accept the system. This testing process is usually performed by customer representatives.
- Accessibility Testing:Type of testing which determines the usability of a product to the people having disabilities (deaf, blind, mentally disabled, etc.). The evaluation process should be conducted by persons with disabilities.
- Active Testing:Type of testing consisting in introducing test data and analyzing the execution results. This testing process is usually conducted by the testing teams.
- Agile Testing:A software testing practice that follows the principles of the agile manifesto, emphasizing testing from the perspective of customers who will utilize the system. This type of testing is usually performed by QA teams.
- Age Testing:Type of testing which evaluates a system’s ability to perform in the future. The evaluation process is conducted by testing teams.
- Ad-hoc Testing:Testing performed without planning and documentation – the tester tries to ‘break’ the system by randomly trying the system’s functionality. This testing process is performed by testing teams.
- Alpha Testing:Type of testing a software product or system conducted at the developer’s site. This testing process is usually performed by the end user.
- Assertion Testing:Type of testing consisting in verifying if the conditions confirm the product requirements. This type of testing is performed by the testing teams.
- API Testing:Testing technique similar to unit testing in that it targets the code level. API testing differs from unit testing in that it is typically a QA task and not a developer task.
- All-pairs Testing:Combinatorial testing method that tests all possible discrete combinations of input parameters. This testing process is usually performed by the testing teams.
- Automated Testing:Testing technique that uses automation testing tools to control the environment set-up, test execution and results reporting. This testing process is performed by a computer and is used inside the testing teams.
- Basis Path Testing:A testing mechanism which derives a logical complexity measure of a procedural design and is used this as a guide for defining a basic set of execution paths. This testing process is normally used by testing teams when defining test cases.
- Backward Compatibility Testing:A testing method which verifies the behavior of the developed software with older versions of the test environment. This testing process is performed by testing teams.
- Beta Testing:Final testing before releasing application for commercial purpose. This testing process is typically done by end-users or others.
- Benchmark Testing:Testing technique that uses representative sets of programs and data designed to evaluate the performance of computer hardware and software in a given configuration. This testing process is performed by testing teams.
- Big Bang Integration Testing:A testing technique which integrates individual program modules only when everything is ready. This testing process is performed by the testing teams.
- Binary Portability Testing:Technique that tests an executable application for portability across system platforms and environments, usually for conformation to an ABI specification. This testing process is performed by the testing teams.
- Boundary Value Testing:Software testing technique in which tests are designed to include representatives of boundary values. It is performed by the QA testing teams.
- Bottom Up Integration Testing:In bottom up integration testing, module at the lowest level are developed first and other modules which go towards the ‘main’ program are integrated and tested one at a time. This testing process is usually performed by the testing teams.
- Branch Testing:Testing technique in which all branches in the program source code are tested at least once. This is done by the developer.
- Breadth Testing:A test suite that exercises the full functionality of a product but does not test features in detail. This testing process is performed by testing teams.
- Black box Testing:A method of software testing that verifies the functionality of an application without having specific knowledge of the application’s code/internal structure. Tests are based on requirements and functionality. This testing process is performed by QA teams.
- Code-driven Testing:Testing technique that uses testing frameworks (such as x Unit) that allow the execution of unit tests to determine whether various sections of the code are acting as expected under various circumstances. This testing process is performed by the development teams.
- Compatibility Testing:Testing technique that validates how well a software performs in a particular hardware/software/operating system/network environment. This testing process is performed by the testing teams.
- Comparison Testing:Testing technique which compares the product strengths and weaknesses with previous versions or other similar products. Can be performed by tester, developers, product managers or product owners.
- Component Testing:Testing technique similar to unit testing but with a higher level of integration – testing is done in the context of the application instead of just directly testing a specific method. Can be performed by testing or development teams.
- Configuration Testing:A testing technique which determines minimal and optimal configuration of hardware and software, and the effect of adding or modifying resources such as memory, disk drives and CPU. This testing process is performed by the performance testing engineers.
- Condition Coverage Testing:Type of software testing where each condition is executed by making it true and false, in each of the ways at least once. This testing process is typically made by the automation testing teams.
- Compliance Testing:Type of testing which checks whether the system was developed in accordance with standards, procedures and guidelines. This testing process is usually performed by external companies which offer “Certified OGC Compliant” brand.
- Concurrency Testing:Multi-user testing geared towards determining the effects of accessing the same application code, module or database records. This testing process is usually done by performance engineers.
- Conformance Testing:The process of testing that an implementation conforms to the specification on which it is based. This testing process is usually performed by testing teams.
- Context Driven Testing:An Agile Testing technique that advocates continuous and creative evaluation of testing opportunities in light of the potential information revealed and the value of that information to the organization at a specific moment. This testing process is usually performed by Agile testing teams.
- Conversion Testing:Testing of programs or procedures used to convert data from existing systems for use in replacement systems. This testing process is usually performed by the QA teams.
- Decision Coverage Testing:Type of software testing where each condition/decision is executed by setting it on true/false. This testing process is typically made by the automation testing teams.
- Destructive Testing:Type of testing in which the tests are carried out to the specimen’s failure, in order to understand a specimen’s structural performance or material behavior under different loads. This testing process is usually performed by QA teams.
- Dependency Testing:Testing type which examines an application’s requirements for pre-existing software, initial states and configuration in order to maintain proper functionality. It is usually performed by testing teams.
- Dynamic Testing:Term used in software engineering to describe the testing of the dynamic behavior of code. This testing process is typically performed by testing teams.
- Domain Testing:White box testing technique which contains checks that the program accepts only valid input. This testing process is usually done by software development teams and occasionally by automation testing teams.
- Error-Handling Testing:Software testing type which determines the ability of the system to properly process erroneous transactions. This testing process is usually performed by the testing teams.
- End-to-end Testing:Similar to system testing, involves testing of a complete application environment in a situation that mimics real-world use, such as interacting with a database, using network communications, or interacting with other hardware, applications, or systems if appropriate. This testing process is performed by QA teams.
- Endurance Testing:Type of testing which checks for memory leaks or other problems that may occur with prolonged execution. This testing process is usually performed by performance engineers.
- Exploratory Testing:Black box testing technique performed without planning and documentation. This testing process is usually performed by manual testers.
- Equivalence Partitioning Testing:Software testing technique that divides the input data of a software unit into partitions of data from which test cases can be derived. This testing process is usually performed by the QA teams.
- Fault injection Testing:Element of a comprehensive test strategy that enables the tester to concentrate on the manner in which the application under test is able to handle exceptions. This testing process is performed by QA teams.
- Formal verification Testing:The act of proving or disproving the correctness of intended algorithms underlying a system with respect to a certain formal specification or property, using formal methods of mathematics. This testing process is usually performed by QA teams.
- Functional Testing:Type of black box testing that bases its test cases on the specifications of the software component under test. This testing process is performed by testing teams.
- Fuzz Testing:Software testing technique that provides invalid, unexpected, or random data to the inputs of a program – a special area of mutation testing. Fuzz testing is performed by testing teams.
- Gorilla Testing:Software testing technique which focuses on heavily testing of one particular module. This testing process is performed by quality assurance teams, usually when running full testing.
- Gray Box Testing:A combination of Black Box and White Box testing methodologies: testing a piece of software against its specification but using some knowledge of its internal workings. This testing process can be performed by either development or testing teams.
- Glass box Testing:Similar to white box testing, based on knowledge of the internal logic of an application’s code. This testing process is performed by development teams.
- GUI software Testing:The process of testing a product that uses a graphical user interface, to ensure it meets its written specifications. This is normally done by the testing teams.
- Globalization Testing:Testing method that checks proper functionality of the product with any of the culture/locale settings using every type of international input possible. This testing process is performed by the testing team.
- Hybrid Integration Testing:Testing technique which combines top-down and bottom-up integration techniques in order leverage benefits of these kind of testing. This testing process is usually performed by the testing teams.
- Integration Testing:The phase in software testing in which individual software modules are combined and tested as a group. This testing process is usually conducted by testing teams.
- Interface Testing:Testing conducted to evaluate whether systems or components pass data and control correctly to one another. This testing process is usually performed by both testing and development teams.
- Install/uninstall Testing:Quality assurance work that focuses on what customers will need to do to install and set up the new software successfully. It may involve full, partial or upgrades install/uninstall processes and is typically done by a software testing engineer in conjunction with the configuration manager.
- Internationalization Testing:The process which ensures that product’s functionality is not broken and all the messages are properly externalized when used in different languages and locale. This testing process is usually performed by the testing teams.
- Inter-Systems Testing:Testing technique that focuses on testing the application to ensure that interconnection between application functions correctly. This testing process is usually done by the testing teams.
- Keyword-driven Testing:Also known as table-driven testing or action-word testing, is a software testing methodology for automated testing that separates the test creation process into two distinct stages: a Planning Stage and an Implementation Stage. It can be used by either manual or automation testing teams.
- Load Testing:Testing technique that puts demand on a system or device and measures its response. It is usually conducted by the performance engineers.
- Localization Testing:Part of software testing process focused on adapting a globalized application to a particular culture/locale. This testing process is normally done by the testing teams.
- Loop Testing:A white box testing technique that exercises program loops. This testing process is performed by the development teams.
- Manual Scripted Testing:Testing method in which the test cases are designed and reviewed by the team before executing it. It is done by manual testing teams.
- Manual-Support Testing:Testing technique that involves testing of all the functions performed by the people while preparing the data and using these data from automated system. This testing process is conducted by testing teams.
- Model-Based Testing:The application of Model based design for designing and executing the necessary artifacts to perform software testing. This testing process is usually performed by testing teams.
- Mutation Testing:Method of software testing which involves modifying programs’ source code or byte code in small ways in order to test sections of the code that are seldom or never accessed during normal tests execution. This testing process is normally conducted by testers.
- Modularity-driven Testing:A software testing technique which requires the creation of small, independent scripts that represent modules, sections, and functions of the application under test. This testing process is usually performed by the testing team.
- Non-functional Testing:Testing technique which focuses on testing of a software application for its non-functional requirements. Can be conducted by the performance engineers or by manual testing teams.
- Negative Testing:Also known as “test to fail” – testing method where the tests’ aim is showing that a component or system does not work. This testing process is performed by manual or automation testers.
- Operational Testing:Testing technique conducted to evaluate a system or component in its operational environment. This testing process is performed by testing teams.
- Orthogonal array Testing:Systematic, statistical way of testing which can be applied in user interface testing, system testing, regression testing, configuration testing and performance testing. This testing process is performed by the testing team.
- Pair Testing:Software development technique in which two team members work together at one keyboard to test the software application. One does the testing and the other analyzes or reviews the testing. This can be done between one Tester and Developer or Business Analyst or between two testers with both participants taking turns at driving the keyboard.
- Passive Testing:Testing technique consisting in monitoring the results of a running system without introducing any special test data. This testing process is performed by the testing team.
- Parallel Testing:A testing technique which has the purpose to ensure that a new application which has replaced its older version has been installed and is running correctly. This testing process is conducted by the testing team.
- Path Testing:Typical white box testing which has the goal to satisfy coverage criteria for each logical path through the program. This testing process is usually performed by the development team.
- Penetration Testing:A testing method which evaluates the security of a computer system or network by simulating an attack from a malicious source. This testing process is conducted by specialized penetration testing companies.
- Performance Testing:Functional testing conducted to evaluate the compliance of a system or component with specified performance requirements. This testing process is usually conducted by the performance engineer.
- Qualification Testing:Testing against the specifications of the previous release, usually conducted by the developer for the consumer, to demonstrate that the software meets its specified requirements.
- Ramp Testing:Type of testing consisting in raising an input signal continuously until the system breaks down. This testing process may be conducted by the testing team or the performance engineer.
- Regression Testing:Type of software testing that seeks to uncover software errors after changes to the program (e.g., bug fixes or new functionality) have been made, by retesting the program. This testing process is performed by the testing teams.
- Recovery Testing:Testing technique which evaluates how well a system recovers from crashes, hardware failures, or other catastrophic problems. This testing process is performed by the testing teams.
- Requirements Testing:Testing technique which validates that the requirements are correct, complete, unambiguous, and logically consistent and allows designing a necessary and sufficient set of test cases from those requirements. This testing process is performed by QA teams.
- Security Testing:A process to determine that an information system protects data and maintains functionality as intended. It can be performed by testing teams or by specialized security-testing companies.
- Sanity Testing:A testing technique which determines if a new software version is performing well enough to accept it for a major testing effort. This testing process is performed by the testing teams.
- Scenario Testing:Testing activity that uses scenarios based on a hypothetical story to help a person think through a complex problem or system for a testing environment. This testing process is performed by the testing teams.
- Scalability Testing:Part of the battery of non-functional tests which tests a software application for measuring its capability to scale up – be it the user load supported, the number of transactions, the data volume, etc. This testing process is conducted by the performance engineer.
- Statement Testing:A white box testing which satisfies the criterion that each statement in a program is executed at least once during program testing. It is usually performed by the development team.
- Static Testing:A form of software testing where the software isn’t actually used it checks mainly for the sanity of the code, algorithm, or document. It is used by the developer who wrote the code.
- Stability Testing:Testing technique which attempts to determine if an application will crash. This testing process is usually conducted by the performance engineer.
- Smoke Testing:Testing technique which examines all the basic components of a software system to ensure that they work properly. Typically, smoke testing is conducted by the testing team, immediately after a software build is made.
- Storage Testing:Testing type that verifies the program under test stores data files in the correct directories and that it reserves sufficient space to prevent unexpected termination resulting from lack of space. This testing process is usually performed by the testing team.
- Stress Testing:A testing technique which evaluates a system or component at or beyond the limits of its specified requirements. This testing process is usually conducted by the performance engineer.
- Structural Testing:White box testing technique which takes into account the internal structure of a system or component and ensures that each program statement performs its intended function. This testing process is usually performed by the software developers.
- System Testing:The process of testing an integrated hardware and software system to verify that the system meets its specified requirements. This testing process is conducted by the testing teams in both development and target environment.
- System integration Testing:Testing process that exercises a software system’s coexistence with others. This testing process is usually performed by the testing teams.
- Top Down Integration Testing:Testing technique that involves starting at the stop of a system hierarchy at the user interface and using stubs to test from the top down until the entire system has been implemented. This testing process is conducted by the testing teams.
- Thread Testing:A variation of top-down testing technique where the progressive integration of components follows the implementation of subsets of the requirements. This testing process is usually performed by the testing teams.
- Upgrade Testing:Testing technique that verifies if assets created with older versions can be used properly and that user’s learning is not challenged. This testing process is performed by the testing teams.
- Unit Testing:Software verification and validation method in which a programmer tests if individual units of source code are fit for use. This testing process is usually conducted by the development team.
- User Interface Testing: A type of testing which is performed to check how user-friendly the application is. This testing process is performed by testing teams.
- Usability Testing: Testing technique which verifies the ease with which a user can learn to operate, prepare inputs for, and interpret outputs of a system or component. This testing process is usually performed by end users.
- Volume Testing: Testing which confirms that any values that may become large over time (such as accumulated counts, logs, and data files), can be accommodated by the program and will not cause the program to stop working or degrade its operation in any manner. This testing process is usually conducted by the performance engineer.
- Vulnerability Testing: A type of testing which regards application security and has the purpose to prevent problems which may affect the application integrity and stability. This testing process can be performed by the internal testing teams or outsourced to specialized companies.
- White box Testing: Testing technique based on knowledge of the internal logic of an application’s code and includes tests like coverage of code statements, branches, paths, conditions. This testing process is performed by software developers.
- Workflow Testing: A scripted end-to-end testing technique which duplicates specific workflows which are expected to be utilized by the end-user. This testing process is usually conducted by testing teams.
Factors to consider when testing IT software systems;
1. Objectivity
An objective test measures a variable independent of the people conducting the test and the circumstances of the test. Objective selection methods guarantee unbiased measures of the system capability.
2. Validity
A test is valid if it measures a specified ability.
3. Reliability
A test is reliable if it accurately measures a quality and is repeatable.
4. Economy
A test is economical if its overall costs are manageable for the program. Those costs could be money but also include time involved, necessary equipment, and personnel.
5. Legality
The system testing procedure must comply with regulatory, licensing, contractual and health and safety requirements.
Author: Neftaly Malatjie
114066 LG 1.10 TYPES OF TESTING PROCEDURES & SELECTION FACTORS
114066 LG 1.9 Basic Purpose of System Testing is to:
- Ensure that a system or application meets its specification and any non-functional requirements (such as stability and throughput) also meets the requirements with its users.
- Comprise a different tests series to fully exercise the computer-based system.
- Confirm an application’s or system accuracy and completeness in performing the designed functions.
-
System testing means testing of the entire software. The main purpose of system testing is to detect whether the software meets its requirements or not.
114066 LG 1.8 When is the System Tested?
Testing is normally done in two stages.
- The first phase of testing is done by the designers and engineers who created the system, usually before the system is delivered to the customer.
The test data that is used in this first phase is similar to data that would be used by the actual customer.
- The second phase of testing is done after the system has been delivered and installed with the customer.
The data used in the second phase is usually ‘live’ data – data that is actually part of the customer’s business / organisation.
- The first phase of testing is done by the designers and engineers who created the system, usually before the system is delivered to the customer.
114066 LG 1.7 INTRODUCTION
Once the system has been created, it needs to be thoroughly tested.
A test plan is usually written whilst the system is being developed. The test plan will contain details of every single thing that needs to be tested.
For example:
- Does the system open and close properly?
- Can data be entered?
- Can data be saved?
- Can reports be printed?
- When you do something wrong, does an error message appear?
- Is invalid data rejected? E.g. if you are not allowed to enter an amount above 1,000 on the system then a value of 1,001 should not be accepted (i.e. does the validation work?)
Test plans are very detailed, and contain many tests. Each test is specified very precisely.
A typical test would contain:
- Details of what is being tested
- The test data to use
- What is expected to happen when the test is performed
114066 LG 1.6 SESSION 1: SELECTING AN APPROPRIATE TEST PROCEDURE
On completion of this section you will be able to monitor the performance of a multi-user networked operating system
- The selection clarifies the purpose of the test and the data required from it.
- The selection identifies any factors that may affect the choice of the test procedure.
- The selection identifies the resources available for the test procedure.
- The selection complies with all relevant regulatory, licensing, contractual and health and safety requirements.