330 likes | 340 Views
Software testing is the process of finding errors in software to ensure that it functions according to end users' requirements. It involves verification and validation procedures to prevent and validate the defects before they occur. This article explores the role of software testing, its principles, and the different phases of testing in the software development lifecycle.
E N D
Definition -The process of finding errors in s/w so that it works according to the end users requirements. It is not way of ensuring quality To detect defects in s/w product Other methods are employed to achieve same functions Software Testing
Ideas of catching defects before testing phase. Verification– Are we build the product right? Procedures carried out to prevent the defects before they take the shape. (Proactive) Validation – Are we build the right product? Procedures carried out to validate whether the product is built as per specification (Reactive) Includes Unit testing, Integration testing and system testing Verification and validation
Reveals defects in s/w • Finds weak points in s/w • Detects Inconsistent behavior of s/w • Checks whether s/w work as expected • Needs a very good skill of s/w development and testing • Should work with the developers • Should have correct ratio with industry and project personnel • Work with requirement Engineer to meet requirements as testable Tester’s Role
Programming • Test principles • Process • Measurement’s • Plans • Tools and methods and how to apply to testing tasks Tester’s should have Knowledge of
The s/w development is similar to Engineering Activity, as it; • Designed • Implemented • Evaluated • And maintained • S/w development must be in consistent and predictable manner. • Testing is a quality testing process. It follows Engg principles. Role of process in s/w quality
Errors – Mistake / misunderstanding of the s/w by developer Defects – Irregularity in the S/w leads to behave incorrectly Failures – Inability of s/w or component to perform required functions. Testcases – Involve: 1) A set of inputs 2) Execution conditions, 3} Expected outputs Test – A group of related test cases and test procedures Testoracle– Document/piece of s/w that allows test to determine whether a test is passed or failed Basic definitions
7. Testbed – An environment containing H/W and S/W needed to test s/w component or system. S/W quality– Degree to which a system, component or process meets specified requirements. Metric (Quantitative measure) - The degree to which a system , component or process has a given attribute. Quality metric (Qualitative measure) - The degree to which an item posses a given quality attribute. These are correctness, reliability, usability, Integrity, portability, Maintainability and Inter-operability Basic definitions cont..
Depends on the process and associated stakeholders of the projects. Following professionals does testing with their capacities: • Software Tester • Software Developer • Project Lead/Manager • End User Who does Testing?
When to Start Testing? An early start reduces the cost and time to rework and produce error-free software. In SDLC, testing can be started from the Requirements gathering and continued till the deployment of the s/w. It also depends on the SDLC model that is being used. i.e. In Waterfall model, formal testing is conducted in the testing phase; In incremental model, testing is performed at the end of every iteration and whole application is tested at the end. Testing is done in different forms at every phase of SDLC.
When to stop Testing? • Difficult to determine when to stop testing, as testing is a never-ending process and no one can claim that a S/W is 100% tested. • Aspects for stopping the testing process: • Testing Deadlines • Completion of test case execution • Completion of functional and code coverage to a certain point • Bug rate falls below a certain level or no high-priority bugs are identified
Phases of testing for different development phases as below; V-model Business Requirement Acceptance testing S/W Requirement System testing High Level Design Integration testing Low Level Design Component testing Coding Unit Testing Testing
V-model • Splits testing into two parts as design and execution • Test design is done earlier and execution is done at the end • Different types of tests for each phase • Execution of tests can’t be done until product is built • Requires skill sets for designing of each type of test • Presents excellent advantages for verification and validation
with design of tests and execution V-model Business Requirement Acceptance test design Acceptance test execution S/W Requirement System test design System test execution Integration test execution High Level Design Integration test design Component test execution Low Level Design Component testi design Coding Unit Test design Unit Test execution
Exhausting testing is not possible • Defect clustering • Pesticide paradox • Testing shows presence of defects • Absences of errors • Early testing • Testing is context dependent Software testing principles
S/W engineers work very hard to produce high-quality s/w with a low number of defects. Origins of Defects
Education: The s/w engineer did not have the proper educational background to prepare the software artifact. • Communication: The s/w engineer was not informed about something by a colleague. • Oversight: The s/w engineer omitted to do something. • Transcription: The s/w engineer knows what to do, but makes a mistake in doing it. • Process: The process used misdirect the actions.
A tester develops hypotheses and then design Test cases. The hypotheses are: • Design test cases. • Design test procedures. • Assemble test sets. • Select the testing levels suitable for the tests. • Evaluate the results of the tests. hypotheses
S/W orgs need to create a defect database. It supports storage and retrieval of defect data from all projects in a centrally accessible location. • Defects can be classified in many ways.. • Some defects will fit into more than one class or category. • The defect types and frequency of occurrence should be used in test planning, and test design. The four classes of defects are as follows, • Requirements and specifications defects, • Design defects, • Code defects, • Testing defects Defect Repository
Defects are injected in early phases can be very difficult to remove in later phases. Many requirement documents are written using a natural language, they may become • Ambiguous, • Contradictory, • Unclear, • Redundant, • Imprecise 1. Requirements and Specifications Defects
1. Functional Description Defects Description of what the product does, and how it should behave (inputs/outputs), is incorrect, ambiguous, and/or incomplete. 2. Feature Defects Due to feature descriptions are missing, incorrect, incomplete, or unnecessary. 3. Feature Interaction Defects Due to incorrect description of how the features should interact with each other. 4. Interface Description Defects Occur in the description of how the target software is to interface with external software, hardware, and users.
Occurs when the following are incorrectly designs of: • System components, • Interactions between system components, • Interactions between the components and outside software/hardware, or users • Algorithms, control, logic, data elements, module interface descriptions, and external software/hardware/user interface descriptions. 2. Design Defects
1. Algorithmic and Processing Defects Processing steps in the algorithm as described by the pseudo code are incorrect. 2. Control, Logic, and Sequence Defects Logic flow in the pseudo code is not correct. 3. Data Defects Associated with incorrect design of data structures. 4. Module Interface Description Defects Incorrect or inconsistent usage of parameter types, incorrect number of parameters or incorrect ordering of parameters. 5. Functional Description Defects Include incorrect, missing, or unclear design elements. 6. External Interface Description Defects Derived from incorrect design descriptions for interfaces components, external software systems, databases, and hardware devices.
Derived from errors in implementing the code. Some coding defects come from a failure to understand programming language constructs, and miscommunication with the designers. 1. Algorithmic and Processing Defects Unchecked overflow and underflow conditions, Comparing inappropriate data types, Converting one data type to another, Incorrect ordering of arithmetic operators, Misuse or omission of parentheses, Precision loss, Incorrect use of signs. 2. Control, Logic and Sequence Defects Include incorrect expression of case statements, incorrect iteration of loops, and missing paths. 3. Typographical Defects Syntax errors, incorrect spelling of a variable name that are usually detected by a compiler or self-reviews, or peer reviews. 4. Initialization Defects Initialization statements are omitted or are incorrect. Because of misunderstandings or lack of communication between programmers, and designer`s, carelessness, or misunderstanding of the programming environment. 5. Data-Flow Defects Data-Flow defects occur when the code does not follow the necessary data-flow conditions. 3. Coding Defects
6. Data Defects Indicated by incorrect implementation of data structures. 7. Module Interface Defects Occurs because of using incorrect or inconsistent parameter types, an incorrect number of parameters, or improper ordering of the parameters. 8. Code Documentation Defects Code documentation does not describe what the program actually does, or is incomplete or ambiguous, it is called a code documentation defect. 9. External Hardware, Software Interfaces Defects Occurs because of problems related to: System calls, links to databases, Input/output sequences, Memory usage, Resource usage, Interrupts and exception handling, Data exchanges with hardware, Protocols, Formats, Interfaces with build files, Timing sequences.
Test plans, test cases, test harnesses, and test procedures can also contain defects. Defects in test plans are best detected using review techniques. 1. Test Harness Defects At the unit and integration levels, auxiliary code must be developed. This is called the test harness or scaffolding code. The test harness code should be carefully designed, implemented, and tested since it is a work product and this code can be reused when new releases of the software are developed. 2. Test Case Design and Test Procedure Defects Consists of incorrect, incomplete, missing, inappropriate test cases, and test procedures. 4. Testing Defects
Specification for the program calculate_coin_value This program calculates the total rupees value for a set of coins. The user inputs the amount of 25p, 50p and 1rs coins. There are size different denominations of coins. The program outputs the total rupees and paise value of the coins to the user Input : number_of_coins is an integer Output : number_of_rupees is an integer number_of_paise is an integer Defect Example: The Coin Problem
This simple example shows • Requirements/specification defects, • Functional description defects, • Interface description defects. • The functional description defects arise because the functional description is ambiguous and incomplete. • It does not state that the input and the output should be zero or greater and cannot accept negative values. • Because of these ambiguities and specification incompleteness, a checking routine may be omitted from the design. • A more formally stated set of preconditions and post conditions is needed with the specification. • A precondition is a condition that must be true in order for a software component to operate properly. • A post condition is a condition that must be true when a software component completes its operation properly.
2. Design Description for the Coin Problem Design Description for Program calculate_coin_valuesProgram calculate_coin_valuesnumber_of_coins is integertotal_coin_value is integernumber_of_rupees is integernumber_of_paise is integercoin_values is array of six integers representingeach coin value in paiseinitialized to: 25,25,100 begininitialize total_coin_value to zeroinitialize loop_counter to onewhile loop_counter is less than sixbeginoutput “enter number of coins”read (number_of_coins )total_coin_value = total_coin_value +number_of_coins * coin_value[loop_counter]increment loop_counterendnumber_rupees = total_coin_value/100number_of_paise = total_coin_value – 100 * number_of_rupeesoutput (number_of_rupees, number_of_paise)end
Control, logic, and sequencing defects. The defect in this subclass arises from an incorrect “while” loop condition (should be less than or equal to six) Algorithmic, and processing defects. These arise from the lack of error checks for incorrect and/or invalid inputs, lack of a path where users can correct erroneous inputs, lack of a path for recovery from input errors. Data defects. This defect relates to an incorrect value for one of the elements of the integer array, coin_values, which should be 25, 50, 100. External interface description defects. These are defects arising from the absence of input messages or prompts that introduce the program to the user and request inputs. 3. Coding Defects in the Coin Problem Control, logic, and sequence defects. These include the loop variable increment step which is out of the scope of the loop. Note that incorrect loop condition (i<6) is carried over from design and should be counted as a design defect. Algorithmic and processing defects. The division operator may cause problems if negative values are divided, although this problem could be eliminated with an input check. Design Defects in the Coin Problem
Software engineers and test specialists should follow the examples of engineers in other disciplines who make use of defect data. A requirement for repository development should be a part of testing and/or debugging policy statements. Forms and templates should be designed to collect the data. Each defect and frequency of occurrence must be recorded after testing. Defect monitoring should be done for each on-going project. The distribution of defects will change when changes are made to the process Developer/Tester Support for Developing a Defect Repository
The defect data is useful for test planning.. It helps a tester to select applicable testing techniques, design the test cases, and allocate the amount of resources needed to detect and remove defects. This allows tester to estimate testing schedules and costs. The defect data can support debugging activities also. A defect repository can help in implementing several TMM maturity goals including : • Controlling and monitoring of test, • Software quality evaluation and control, • Test measurement, • Test process improvement.