QA/Contribute/QA 101/Testing Terminology

From MozillaWiki
< QA‎ | Contribute‎ | QA 101
Revision as of 17:49, 2 July 2014 by Kthiessen (talk | contribs) (Created page with "= Methodologies (Black box vs. white box) = ; BLACK BOX TESTING : Testing without knowledge of the internal workings of the item being tested. Tests are usually functional. ...")
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

Methodologies (Black box vs. white box)

BLACK BOX TESTING
Testing without knowledge of the internal workings of the item being tested. Tests are usually functional.
WHITE BOX TESTING
Testing based on an analysis of internal workings and structure of a piece of software. Includes techniques such as Branch Testing and Path Testing. Also known as Structural Testing and Glass Box Testing.

Small-scale testing (Unit tests vs. functional tests vs. regression tests)

UNIT TESTING
Functional and reliability testing in an Engineering environment. Producing tests for the behavior of components of a product to ensure their correct behavior prior to system integration.
FUNCTIONAL TESTING
Validating that software conforms to its specifications and correctly performs all its required functions. This entails a series of tests which perform a feature by feature validation of behavior, using a wide range of normal and erroneous input data. This can involve testing of the software's user interface, APIs, database management, security, installation, networking, etc. Functional testing can be performed on an automated or manual basis using black box or white box methodologies.
REGRESSION TESTING
Similar in scope to a functional test, a regression test allows a consistent, repeatable validation of each new release of software. Such testing ensures reported defects have been corrected for each new release and that no new quality problems were introduced in the maintenance process. Though regression testing can be performed manually an automated test suite is often used to reduce the time and resources needed to perform the required testing.


Larger-scale testing (Integration and system-level tests)

INTEGRATION TESTING
Testing in which modules are combined and tested as a group. Modules are typically code modules, individual applications, client and server applications on a network, etc. Integration Testing follows unit testing and precedes system testing.
SYSTEM TESTING
Testing conducted on a complete, integrated system to evaluate the system's compliance with its specified requirements. System testing generaly uses black box testing methodologies, and as such, should require no knowledge of the inner design of the code or logic.
COMPATIBILITY TESTING
Testing to ensure compatibility of software with different browsers, OSes, and hardware platforms. Compatibility testing can be performed manually or can be driven by an automated functional or regression test suite.
ACCEPTANCE TESTING
Testing to verify a product meets customer specified requirements. A customer usually does this type of testing on a product that is developed externally. This is distinguished from CONFORMANCE TESTING in that the requirements are specified by the customer rather than by a widely-published standard.
SMOKE TESTING
A quick-and-dirty test that the major functions of a piece of software work without testing finer details. Originated in the hardware testing practice of turning on a new piece of hardware for the first time and considering it a success if it does not catch on fire. Technically, this is a subset of SYSTEM TESTING.
CONFORMANCE TESTING
Verifying implementation conformance to one or more industry standards. Producing tests for the behavior of an implementation to be sure it provides the portability, interoperability, and/or compatibility a standard defines. Distinguished from ACCEPTANCE TESTING.


Load tests, performance tests, and stress tests

LOAD TESTING
Load testing generally includes performance testing and stress testing.
PERFORMANCE TESTING
Performance testing can be applied to understand your application or web site's scalability, or to benchmark the performance in an environment of third party products such as servers and middleware for potential purchase. This sort of testing is particularly useful to identify performance bottlenecks in high use applications. Performance testing generally involves an automated test suite as this allows easy simulation of a variety of normal, peak, and exceptional load conditions.
STRESS TESTING
Testing conducted to evaluate a system or component at or beyond the limits of its specified requirements to determine the load under which it fails and how. A graceful degradation under load leading to non-catastrophic failure is the desired result. Often Stress Testing is performed using the same process as Performance Testing but employing a very high level of simulated load.


Commonly used abbreviations

STR
Steps to reproduce
WFM
Works for me
LGTM
Looks good to me