Presentation on theme: "Software Testing Testing principles. Testing Testing involves operation of a system or application under controlled conditions & evaluating the results."— Presentation transcript:
Testing Testing involves operation of a system or application under controlled conditions & evaluating the results. The controlled conditions should include both normal & abnormal conditions. Testing should intentionally attempt to make things go wrong to determine if things happen when they shouldn’t or things don’t happen when they should.
What is a Bug ? A flaw in a system or system component that causes the system or component to fail to perform its required function. Most are simple, subtle failures, with many being so small that it’s not always clear which ones are true failures, and which ones aren’t.
Fault, failure & defect : Tend to imply a condition that’s really severe, may be even dangerous. It doesn’t sound right to call an incorrectly colored icon a fault. These words also tend to imply blame: “ it’s his fault that the s/w failed.”
Anomaly, incident & variance Don’t sound quite so negative and infer more unintended operation than an all-out failure. “ the president stated that it was a software anomaly that caused the missile to go off course.”
Problem, error & bug : Probably the most generic terms used. “ A bug’s a bug’s a bug.”
…but in SDLC these terms differs like: Design deviation – Error Coding deviation – Bug Testing – Issue/Bug Maintenance – Defect At Client -- Failure
Why does software have bug’s ? Miscommunication or no communication (requirement’s) Software complexity Programming errors Changing requirements Time pressures Poorly documented code Software development tools Egos
Fig: Bug’s are caused for numerous reasons, but the main cause can be traced to the specification.
The Cost of Bug’s Fig:The cost to fix bug’s increases dramatically over time
What is Verification ? Verification ensures the product is designed to deliver all functionality to the customer. Typically involves reviews and meetings to evaluate documents, plans, code, requirements, and specifications.
Verification This can be done with checklists, issues lists, walkthroughs, and inspection meetings. Verification takes place before validation.
What is Validation ? Validation typically involves actual testing and evaluates the product itself. The process of executing something to see how it behaves. The output of validation is a nearly perfect, actual product.
What kind of testing should be considered ? Black Box Testing White Box Testing Unit Testing Incremental Integration Testing Integration Testing Functional Testing System Testing End-to-End Testing Sanity or Smoke Testing Regression Testing Acceptance Testing Load Testing Stress Testing Performance Testing Usability Testing Install / Uninstall Testing
Black Box Testing Not based on any knowledge of internal design or code. Tests are based on requirements and functionality. It will not test hidden functions & errors associated with them will not be found in black box testing.
White Box Testing Based on knowledge of the internal logic of an application’s code. Test’s are based on coverage of code statements, branches, paths, conditions. It will not detect missing function.
Unit Testing Process of testing the individual component of a program. Discover discrepancies between the module’s interface specification & its actual behavior. Verify the control flow and data flow. Requires the knowledge of the code hence done by the developers.
Incremental Integration Testing Done by programmers or by Testers. Continuous testing of an application as new functionality is added. Requires that various aspects of an application’s functionality be independent enough to work separately before all parts of the program are completed.
Integration Testing Testing of combined parts of an application to determine if they function together correctly. To discover errors in the interface between the components, verify communication between units. Done by developers / QA teams.
Functional Testing Black box type testing. Detect discrepancies between a program’s functional specification and actual behavior. Verifies that the software provides expected services. Done by tester’s.
System Testing Black box type testing. Attempting to demonstrate that a program Or system does not meet its original requirements & objectives, as stated in the requirements specification. Done by testing group before the product is made available to customer.
Usability Testing Testing for “ user-friendliness.” User interviews, surveys, video recording of user sessions, & other techniques can be used. Identify discrepancies between the user interface.
Performance Testing Evaluate the compliance of a system or components with specified performance requirements. Often used interchangeably with ‘stress’ and ‘load’ testing. Ideally performance testing is defined in requirements documentation.
Load Testing Testing an application under heavy loads, such as testing of a website under a range of loads to determine at what point the system’s response time degrades or fails.
Stress Testing Used interchangeably with ‘load’ & ‘performance’ testing. Testing conducted to evaluate a system or component at or beyond the limits of its specified requirements. System functional testing while under unusually heavy loads, heavy repetition of certain actions or inputs, etc..
Configuration Testing To determine whether the program operates properly when the software or hardware is configured in a required manner
Compatibility Testing To determine whether the compatibility objectives of the program have been met. Testing how well application performs in a particular hardware / software / operating system / network etc environment.
Installability Testing Testing of full, partial, or upgrade install / uninstall processes. To identify the ways in which the installation procedures lead to incorrect results installation option New Upgrade Customized / Complete Under normal & abnormal conditions
Recovery Testing Testing how well a system recovers from crashes, hardware failures, or other catastrophic problems. Typically used interchangeably with “fail-over testing.”
Regression Testing Re-testing after fixes or modifications of the software or its environment. Verify that changes fixes have not introduced new problems. It can be difficult to determine how much re-testing is needed, especially near the end of development cycle.
Acceptance Testing Final testing based on specifications of the end-user or customer, or based on use by end-user / customer over some limited period of time. Determine whether the software is ready for final deployment. Done after the testing group has satisfactorily completed usability, function, & testing.
Contd… Organizations can arrange for alternative forms of acceptance testing: ALPHA BETA
ALPHA & BETA Both involve running & operating the s/w in production mode for a pre- specified period. The ALPHA test is usually performed by end users inside the development org. The BETA test is usually performed by a selected subset of actual customers outside the company, before the s/w is made available to all customers.