The Theory of Software Testing
|
|
|
- Ellen Stokes
- 9 years ago
- Views:
Transcription
1 The Theory of Software Testing Adtha Lawanna Department of Information Technology, Faculty of Science and Technology Assumption University, Bangkok, Thailand Abstract Software testing is the process of testing bugs in lines of code of a program that can be performed by manual or automation testing. The theory of software testing involves problem definitions of testing such as test team, failure after testing, manual testing, uncertainty principle, participation, and incorrect test case selection. This article shows the details of a critical part of software testing, which is how to test the performance of new software and the entire system. The outcome of this article is the whole picture of three phases for software testing as follows: preliminary testing, testing and user acceptance testing. Keywords: Automation testing, verification, validation, user acceptance testing. 1. Introduction Software testing in the Software Development Life Cycle (SDLC) is the process of executing and evaluating a program with the intent of finding faults (Myers 1979). In general, it focuses on any activity aimed at evaluating an attribute or capability of a program or system and finding that it meets its specification requirements (Hetzel 1988). In fact, a software system is not unlike other physical systems where inputs are received and outputs are produced (Pan 1999). However, software does not suffer from physical changes. Generally, it will not change until modifications, upgrades, or user requirement changes take place (Pan 1999). Therefore, once the software is released, the design faults or bugs will be buried in and remain latent until activation (Pan 1999). All the possible values are required to be verified and tested, but perfect testing is impossible to be made (Humphrey 1995). If a testing failure occurs during a preliminary step and the code is released, the program may now work for a test case that it may not have been intended to work for previously (Pan 1999). But its behavior on pre-debugging test cases that it dealt with before can no longer be trusted (Pan 1999). To respond to this possibility, the testing has to be restarted. The expense of this step often tends to be discouraging (Pan 1999). In response to this, verification can be used to test or check items, including code, for consistency and conformance by evaluating the results against pre-specified requirements. Debugging implies that testing should intentionally aim to make things go wrong to find if things occur when they should not or things do not occur when they should. The validation involves the system correctness e.g., it is the process of checking whether the requirement that should be specified is what the user really wants. This means that the validation process checks whether the invented system is what the customer wants and needs to be included in it, while the verification process checks whether that system is invented correctly (Fischer 1977). Therefore, both verification and validation are necessary as distinct elements of any testing activity. This article shows three phases of software testing in order to consider possible requirements which can affect the abilities of the whole system. 2. The Theory of Software Testing 2.1 Problems in Software Testing This article is concerned with five problems found in software testing as follows. The first problem is concerned with the limitations of the testing team. Insufficiency may be the result of limited resources, lack of Review Article 35
2 training of the individual team members, or issues with the leadership. Also, suitable testing means may not be available to the team. The second problem is failure of the test maintenance. This is because the specification changes of the requirements result in abnormally long reverse times. The third problem is with manual testing. The software testing team is busy making manual testing instead of building new test specifications, or modifying old ones to fit a new or changed requirement. The forth problem is about the uncertainty principle. Sometimes, the uncertainty is in the exact testing conditions as well as how to view the condition for replication. The fifth problem is in selecting the right tests. The software testing cannot address some of the essential aspects of the software testing application or system when testing only some part of the required functions or choosing only the expected interactions when executing a fault-tolerant application. 2.2 Processes in Software Testing The processes of verification and validation are discussed below. Briefly, verification makes the product right, but validation makes the right product. Many testers use white-box testing in these processes. It deals with the investigation of internal logic and structure of the code. Some important processes of white-box testing are briefly described. Data Flow Testing is the process that can define and use program variables (Horgan and London 1991). Loop Testing exclusively concerns the validity of loop constructs. Branch Testing tests true and false values given to compound conditions appearing in different branch statements (Jorgensen 2002). Control Flow Testing is a structural testing that applies the program s control flow as a model and selects a set of test paths through the program (Rapps and Weyuker 1985). Basis Path Testing allows the test suite designer to build a logical complexity measure of procedural design and then applies this measure for determining a basic set of execution paths (Clarke et al. 1989). Besides this, some testers use black-box testing instead of white-box testing for the examination of the fundamental aspects of a system with little regard to its internal logical structure (Beizer 1995). There are several typical processes of black-box testing. Equivalence Partitioning can remove the number of test cases and divides a software unit into partitions of data from which test cases can be determined (Spillner et al. 2007). Boundary Value Analysis concerns the testing at boundary values such as minimum, maximum, just inside and outside boundaries, error values and typical values. Cause-Effect Graph creates a relation between the causes and effects (Nursimulu and Probert 1995). Fuzz Testing determines implementation bugs and uses malformed data injection in an automated session (Miller et al. 1990). There are also other processes of black-box testing. Regression Testing reruns some of the selected test cases to ensure that the modified software system still has the functionality as required (Ball 1998). Pattern Testing is a new type of automated testing which can verify the good application for its design or architecture and patterns (Glaser and Strauss 1967). Orthogonal Array Testing is a systematic, statistical way of software testing which can be applied in user interface testing, system testing, regression testing, configuration testing and performance testing. Matrix Testing states the status report of the project. With Manual Testing, a tester defines manual test operations to test software without the aim of test automation. Accordingly, this testing is a laborious activity that uses a tester possessing a certain set of qualities e.g., to be smart, hard working, observant, creative, speculative, innovative, open-minded, resourceful, and skillful. Automated Testing runs the program being tested, using the proper input and evaluating the output against the expectation before testing. Automated Testing needs a test suite which is generated by test case generator, no human intervention is required. Examples of Automated Testing Tools are regression testing, unit testing, automated functional testing and test management. Regression Testing refers to retesting the unchanged parts of the application. In the test suite, test cases could be re-executed in order to check whether new changes have not produced any new bugs and the previous functionality of an application is still preserved. This test can be constructed in a new build when there are significant Review Article 36
3 changes in original functionalities or even a single debugging. This article focuses on three main techniques which are described as follows. Retest-All Testing is one of the techniques for regression testing in which all the tests in the existing functionality or test suite could be re-executed. A drawback of this technique is that it is very expensive as it needs huge resources and time (Smith and Robson 1992). With Regression Test Selection, instead of retesting the entire test suite, it is better to choose some test cases to be run. One of the advantages of this technique is that reusable test cases can be used in succeeding regression cycles. Prioritization of Test Case produces scheduling over test cases in an order that improves the ability of regression testing (Elbaum et al. 2000). On the other hand, for Manual Testing, testers use Unit Testing/ Module Testing instead of Automated Testing. A unit is the smallest testable component in the software system. Unit Testing is introduced to verify that the lowest independent function in the software is working fine. The testable unit is tested to determine whether it works correctly when isolated from the remainding code (Rothermel and Kinneer 2004). In addition, Integration Testing can: provide the intended functionality when modules are built to interact with each other; and validate such modules. While individual classes can be invented and tested correctly, bugs may occur due to their faulty interaction. Unit Testing concerns Integration Testing which involves the consideration of: the states of multiple modules concerned at the same time in an interaction; and the state of a single object of a module (Meyers 1979). The last strategy is grey box testing, it combines the concepts of white-box and black-box testing to test an application having partial knowledge of the internal structure and at the same time having knowledge of fundamental aspects of the system (Barnett et al. 2003) Integration Test Approaches A mixture of the following approaches can be applied to develop the integration test plan. Big-Bang Integration Approach is a type of integration testing in which software elements and hardware elements are combined all at once rather than in stages. In this approach, individual modules of the programs are not integrated until determination of modules is made. This approach is not suitable mostly for inexperienced programmers who rely on running tests (Sage and Palmer 1990). With Bottom-Up Integration Approach, each subclass is invented and tested separately and after this the entire program is tested. A subclass may consist of many modules through well-defined interfaces. The primary objective of this approach is that each subclass needs to test the interfaces among different modules forming the subsystem. The test cases must be carefully selected to exercise the interfaces in all possible manners. Top-Down Integration Approach is an incremental integration testing that begins by testing the top level module. After this, it adds in lower level modules one by one. It uses stubs to simulate lower level modules. A Stub is a special code arrangement that can stimulate the behavior of a welldesigned and existing module which is not yet constructed or developed (Cleve and Zeller 2005). Mixed Integration Approach (sandwiched approach or hybrid approach) combines top-down and bottom-up testing approaches. In this approach, drivers (calling programs) and stubs (called programs) are used by testers wherever the programs are incomplete. 2.4 Efficiency Testing Testers concern performance testing which provides information about their application regarding stability, speed, and scalability to stakeholders. The performance testing will find whether or not their software meets stability, speed, and scalability requirements. Next, they concern recovery testing which is defined as how well the system should recover from system crashes, hardware failures, and other catastrophic problems. Many computer-based systems must recover from bugs and resume operation within a prespecified time. A system can be fault tolerant, which means that processing faults must not cause the overall system function to cease. However, a system failure needs to be corrected within a specified period. The program is verified under test stores of data files in the correct directories. Accordingly, sufficient space is handled and unexpected Review Article 37
4 terminations resulting from lack of storage are avoided. This is external storage as opposed to internal storage. After this, procedure testing is used to provide detailed instructions for executing one or more test cases. The last testing, User Acceptance Testing (UAT) is the formal testing proposed to find whether a software system meets its acceptance criteria. It helps the buyer to find whether to reject the system or not. Moreover, acceptance testing is proposed to find whether software is suitable for use or not. Beside this, it involves the factors related to business environment. Alpha Testing is conducted when any type of new software or version of old software (called alpha version) is released. In addition, alpha versions are tested by some specific groups of users, those who are chosen by the software developer. They test and check whether all the features that are provided work properly or not. Beta Testing is conducted after alpha testing. Versions of the software refer to beta versions that are released to limited groups of people. It can ensure the product has a few bugs or faults. Sometimes, beta versions are produced to the public to increase the feedback area and to increase the number of future users. Unfortunately, software testing is one of the most difficult processes in SDLC. Testers can test software with different testing techniques. Therefore, this article proposes software testing phases as an alternative option for testers. 3. Design of Software Testing Phases This section is the result of studying the theory of software testing. Software testing can be divided into three main phases: preliminary testing, testing and user acceptance testing. 3.1 Preliminary Testing Phase Preliminary testing phase is conducted especially for testers to clarify the specification requirements of the customer. According to this, software testing can fulfill the needs of both testers and customer. Fig. 1 describes the preliminary testing phase as follows. Review Requirements Specification Test Plan Software Tool Environment Test Case Test Automation Tool Determine Acceptance Test Tool Fig.1. Preliminary testing. Review Requirements Specification: This step is important because many customers initially provide insufficient information (e.g., size and cost of the project). Therefore, the basic document that is needed is called a requirements specification. It is a description of what the system should do. Test Plan: This step provides a document describing the resources, schedule of testing activities, scope, and testing approach (e.g., items, features, tasks, environment, skills of tester independence, design techniques criteria, and risks) Software Tool: This step must be set up when the different modules in the product, hardware, and operating system are known. Test Environment: This step identifies production environment elements that must be tested and creates a test environment relevant to these elements (e.g., business applications, administrative tools, computer hardware, databases, services, security system, applications, and network systems). Test Case: This step provides a document that explains an input and an expected response of an application feature. A Review Article 38
5 test case must contain particulars such as name of test case, input data requirements, test case identifier, objective, test setup, steps and expected output. Test Automation Tool: This step provides planning of a test technique on how to automate software testing. For instance, test cases are executed for regression testing. Determine Acceptance Test Tool: This step can provide acceptance test tool for software testing to meet the requirements specification Testing Phase The testing phase is a separate phase which is conducted by a different test team after the implementation is completed. The testing technique is selected based on the perspective of the test team. In this article, the testing phase is divided into three steps as shown in Fig. 2: independent verification, independent validation and testing. Verification Validation Fig. 2. Testing phase. Testing Verification: The verification activities include technical reviews, software inspections, walkthroughs, and efforts to: check the software requirements (e.g., they are traceable to the requirement specifications), check the design components (they are traceable to the software), check conduct requirements, perform unit testing, perform integration testing, perform system testing, check the acceptance testing, and audit. One can say that it is to determine the right thing, which concerns the testing of the implementation of right process, e.g., to determine whether the software is properly made. Validation: It checks whether the developed software adheres to the user requirements. Testing: It is a useful technique for both verification and validation. Obviously, other techniques useful for verification are: static analysis, reviews, inspections and walkthroughs. Other techniques useful for validation are prototyping and early release. 3.3 User Acceptance Testing (UAT) Phase It would be most important to complete the UAT as shown in Fig. 3 to ensure that the system, which is to be implemented, is working correctly. Check Integration Testing Check Test Strategy Document Check Integration Testing Signoff Repair Coordinate Release Fig. 3. User acceptance testing. Check Integration Testing: When placing several units together, one has to conduct integration testing to ensure that the unit integration has not produced any errors. Check Test Strategy Document: This document is prepared at the planning stage when the user requirements are determined. The strategy document is communicated to the test team for testing the software release. Check Integration Testing Signoff: This step covers the acceptance for the whole of the system testing. An agreement for the defects is reached. This is a form, signed by the project manager, which indicates that the documentation, system testing, and training materials have satisfied all tests within acceptable margins. Repair: This step is conducted to have stable performance based on technical and functional specifications. Coordinate Release: This step is the last step before the release of new software to the market. The three phases are designed to describe all activities when dealing with software Review Article 39
6 testing. According to this, software testers can take the benefit of the design to implement the ideas of software testing and address the critical problems described in Section Conclusion In summary, software testing is not only the process of a team tester to: determine the bugs and report the bugs to software developers; and fix the bugs to develop new quality software. The critical problems of testing must also be considered, including the structure of source codes and the whole system. However, there is no one to guarantee the use of best methods in software testing. Therefore, many researchers are still working on it. In future research, the focus will be on software maintenance. This is because software testing may result in high costs before feeding into the maintenance system. 5. References Ball, T On the limit of control flow analysis for regression test selection. Proc. ACM SIGSOFT Int. Symp. on Software Testing and Analysis (ISSTA), Clearwater Beach, FL, USA, 2-5 March 1998, pp Barnett, M.; Grieskamp, W.; Kerer, C.; Schulte, W.; Szyperski, C.; Tilmann, N.; and Watson, A Serious specification for composing components. Proc. 6 th ICSE Workshop on Component-based Software Engineering: Automated Reasoning and Prediction, Portland, OR, USA, 3-4 May pages. Clarke, L.A.; Podgurski, A.; Richardson, D.J.; and Zeil, S.J A formal evaluation of data flow path selection criteria. IEEE Trans. Software Eng. 15(11): 1, Cleve, H.; and Zeller, A Locating causes of program failures. Proc. 27th ACM Int. Conf. Software Eng. (ICSE), St. Louis, MO, USA, May 2005, pp Elbaum, S.; Malishevsky, A.G.; and Rothermel, G Prioritizing test cases for regression testing. Proc. ACM SIGSOFT Int. Symp. on Software Testing and Analysis (ISSTA), Portland, OR, USA, August 2000, pp Fischer, K.F A test case selection method for the validation of software maintenance modifications. Proc. IEEE Int. Computer Software and Application Conference (COMPSAC), Chicago, IL, USA, 8-11 November 1977, pp Glaser, B.G.; and Strauss A.L The Discovery of Grounded Theory: Strategies for Qualitative Research. Aldine, Chicago, IL, USA. Hetzel, W.C The Complete Guide to Software Testing. 2nd ed. QED Information Sciences, Inc., Wellesley, MA, USA. Horgan, J.R.; and London, S Data flow coverage and the C language. Proc. 4th ACM Symp. on Testing, Analysis, and Verification (TAV 4), Victoria, BC, Canada, 8-9 October 1991, pp Humphrey, W. S A Discipline for Software Engineering. Addison Wesley, New York, NY, USA. Jorgensen, P.C Software Testing: A Craftsman s Approach. 2nd ed. CRC Press, New York, NY, USA. Chapter 6. Miller, B.P.; Fredriksen, L.; and Bryan, S An empirical study of the reliability of UNIX utilities. Commun. ACM, 33(12): Myers, G.J The Art of Software Testing. John Wiley & Sons, New York, NY, USA. Nursimulu, K.; and Probert, R.L Causeeffect graphing analysis and validation of requirements. Proc. Conf. of the Centre for Advanced Studies on Collaborative Research (CASCON), IBM Press, Toronto, Ontario, Canada, 7-9 November p. 46. Pan, J Software testing. Student Report. Available:< man/des_s99/sw_testing>. Rapps, S.; and Weyuker, E.J Selecting software test data using data flow information. IEEE Trans. Software Eng. 11(4): Sage, A.P.; and Palmer, J.D Software Systems Engineering. John Wiley & Sons, New York, NY, USA. Spillner, A.; Linz T.; and Schaefer, H Software Testing Foundations. A Study Guide for the Certified Tester Exam. Foundation Level, ISTQB compliant. Rocky Nook Inc., Santa Barbara, CA, USA. Review Article 40
Basic Testing Concepts and Terminology
T-76.5613 Software Testing and Quality Assurance Lecture 2, 13.9.2006 Basic Testing Concepts and Terminology Juha Itkonen SoberIT Contents Realities and principles of Testing terminology and basic concepts
Regression Testing Based on Comparing Fault Detection by multi criteria before prioritization and after prioritization
Regression Testing Based on Comparing Fault Detection by multi criteria before prioritization and after prioritization KanwalpreetKaur #, Satwinder Singh * #Research Scholar, Dept of Computer Science and
Software testing. Objectives
Software testing cmsc435-1 Objectives To discuss the distinctions between validation testing and defect testing To describe the principles of system and component testing To describe strategies for generating
CSTE Mock Test - Part III Questions Along with Answers
Note: This material is for Evaluators reference only. Caters to answers of CSTE Mock Test - Part III paper. 1. Independence is important in testing is mostly due to the fact that (Ans: C) a. Developers
CS 451 Software Engineering Winter 2009
CS 451 Software Engineering Winter 2009 Yuanfang Cai Room 104, University Crossings 215.895.0298 [email protected] 1 Testing Process Testing Testing only reveals the presence of defects Does not identify
Software Testing. Knowledge Base. Rajat Kumar Bal. Introduction
Software Testing Rajat Kumar Bal Introduction In India itself, Software industry growth has been phenomenal. IT field has enormously grown in the past 50 years. IT industry in India is expected to touch
Module 10. Coding and Testing. Version 2 CSE IIT, Kharagpur
Module 10 Coding and Testing Lesson 26 Debugging, Integration and System Testing Specific Instructional Objectives At the end of this lesson the student would be able to: Explain why debugging is needed.
Software Engineering. How does software fail? Terminology CS / COE 1530
Software Engineering CS / COE 1530 Testing How does software fail? Wrong requirement: not what the customer wants Missing requirement Requirement impossible to implement Faulty design Faulty code Improperly
Chapter 8 Software Testing
Chapter 8 Software Testing Summary 1 Topics covered Development testing Test-driven development Release testing User testing 2 Program testing Testing is intended to show that a program does what it is
Software Testing Interview Questions
Software Testing Interview Questions 1. What s the Software Testing? A set of activities conducted with the intent of finding errors in software. 2.What is Acceptance Testing? Testing conducted to enable
An Analysis on Objectives, Importance and Types of Software Testing
Available Online at www.ijcsmc.com International Journal of Computer Science and Mobile Computing A Monthly Journal of Computer Science and Information Technology IJCSMC, Vol. 2, Issue. 9, September 2013,
Presentation: 1.1 Introduction to Software Testing
Software Testing M1: Introduction to Software Testing 1.1 What is Software Testing? 1.2 Need for Software Testing 1.3 Testing Fundamentals M2: Introduction to Testing Techniques 2.1 Static Testing 2.2
Formal Software Testing. Terri Grenda, CSTE IV&V Testing Solutions, LLC www.ivvts.com
Formal Software Testing Terri Grenda, CSTE IV&V Testing Solutions, LLC www.ivvts.com Scope of Testing Find defects early Remove defects prior to production Identify Risks Unbiased opinion When Should Testing
Oracle Insurance Policy Administration System Quality Assurance Testing Methodology. An Oracle White Paper August 2008
Oracle Insurance Policy Administration System Quality Assurance Testing Methodology An Oracle White Paper August 2008 Oracle Insurance Policy Administration System Quality Assurance Testing Methodology
Chapter 11, Testing, Part 2: Integration and System Testing
Object-Oriented Software Engineering Using UML, Patterns, and Java Chapter 11, Testing, Part 2: Integration and System Testing Overview Integration testing Big bang Bottom up Top down Sandwich System testing
Introduction to Automated Testing
Introduction to Automated Testing What is Software testing? Examination of a software unit, several integrated software units or an entire software package by running it. execution based on test cases
Advancements in the V-Model
Advancements in the V-Model Sonali Mathur Asst. Professor, CSE Dept. ABES Institute of Technology Ghaziabad, U.P-201009 Shaily Malik Lecturer, CSE Dept. Maharaja Surajmal Institute of Tech. Janakpuri,
Quality Management. Lecture 12 Software quality management
Quality Management Lecture 12 Software quality management doc.dr.sc. Marko Jurčević prof.dr.sc. Roman Malarić University of Zagreb Faculty of Electrical Engineering and Computing Department of Fundamentals
Outline. 1 Denitions. 2 Principles. 4 Implementation and Evaluation. 5 Debugging. 6 References
Outline Computer Science 331 Introduction to Testing of Programs Mike Jacobson Department of Computer Science University of Calgary Lecture #3-4 1 Denitions 2 3 4 Implementation and Evaluation 5 Debugging
Testing and Inspecting to Ensure High Quality
Testing and Inspecting to Ensure High Quality Basic definitions A failure is an unacceptable behaviour exhibited by a system The frequency of failures measures the reliability An important design objective
Testing Introduction. IEEE Definitions
Testing Introduction IEEE Definitions Software testing is the process of analyzing a software item to detect the differences between existing and required conditions (that is, bugs) and to evaluate the
Web Application Regression Testing: A Session Based Test Case Prioritization Approach
Web Application Regression Testing: A Session Based Test Case Prioritization Approach Mojtaba Raeisi Nejad Dobuneh 1, Dayang Norhayati Abang Jawawi 2, Mohammad V. Malakooti 3 Faculty and Head of Department
Levels of Software Testing. Functional Testing
Levels of Software Testing There are different levels during the process of Testing. In this chapter a brief description is provided about these levels. Levels of testing include the different methodologies
Standard for Software Component Testing
Standard for Software Component Testing Working Draft 3.4 Date: 27 April 2001 produced by the British Computer Society Specialist Interest Group in Software Testing (BCS SIGIST) Copyright Notice This document
The V-model. Validation and Verification. Inspections [24.3] Testing overview [8, 15.2] - system testing. How much V&V is enough?
Validation and Verification Inspections [24.3] Testing overview [8, 15.2] - system testing Requirements Design The V-model V & V Plans Implementation Unit tests System tests Integration tests Operation,
Software Engineering. Software Testing. Based on Software Engineering, 7 th Edition by Ian Sommerville
Software Engineering Software Testing Based on Software Engineering, 7 th Edition by Ian Sommerville Objectives To discuss the distinctions between validation testing and defect t testing To describe the
Advanced Testing Techniques
9 March, 2010 ISSN 1866-5705 www.testingexperience.com free digital version print version 8,00 printed in Germany Advanced Testing Techniques Conferences Special istockphoto.com/nwphotoguy istockphoto.com/esemelwe
Standard Glossary of Terms Used in Software Testing. Version 3.01
Standard Glossary of Terms Used in Software Testing Version 3.01 Terms Used in the Foundation Level Syllabus International Software Testing Qualifications Board Copyright International Software Testing
Software Engineering I: Software Technology WS 2008/09. Integration Testing and System Testing
Software Engineering I: Software Technology WS 2008/09 Integration Testing and System Testing Bernd Bruegge Applied Software Engineering Technische Universitaet Muenchen 1 Overview Integration testing
Chapter 17 Software Testing Strategies Slide Set to accompany Software Engineering: A Practitioner s Approach, 7/e by Roger S. Pressman Slides copyright 1996, 2001, 2005, 2009 by Roger S. Pressman For
Software Testing. Definition: Testing is a process of executing a program with data, with the sole intention of finding errors in the program.
Software Testing Definition: Testing is a process of executing a program with data, with the sole intention of finding errors in the program. Testing can only reveal the presence of errors and not the
APPROACHES TO SOFTWARE TESTING PROGRAM VERIFICATION AND VALIDATION
1 APPROACHES TO SOFTWARE TESTING PROGRAM VERIFICATION AND VALIDATION Validation: Are we building the right product? Does program meet expectations of user? Verification: Are we building the product right?
Verification and Validation of Software Components and Component Based Software Systems
Chapter 5 29 Verification and Validation of Software Components and Component Based Christina Wallin Industrial Information Technology Software Engineering Processes ABB Corporate Research [email protected]
Metrics in Software Test Planning and Test Design Processes
Master Thesis Software Engineering Thesis no: MSE-2007:02 January 2007 Metrics in Software Test Planning and Test Design Processes Wasif Afzal School of Engineering Blekinge Institute of Technology Box
Software Testing Strategies and Techniques
Software Testing Strategies and Techniques Sheetal Thakare 1, Savita Chavan 2, Prof. P. M. Chawan 3 1,2 MTech, Computer Engineering VJTI, Mumbai 3 Associate Professor, Computer Technology Department, VJTI,
Standard Glossary of Terms Used in Software Testing. Version 3.01
Standard Glossary of Terms Used in Software Testing Version 3.01 Terms Used in the Advanced Level - Technical Test Analyst Syllabus International Software Testing Qualifications Board Copyright International
Software Testing Tutorial
Software Testing Tutorial SOFTWARE TESTING TUTORIAL Simply Easy Learning by tutorialspoint.com tutorialspoint.com i C O P Y R I G H T & D I S C L A I M E R N O T I C E All the content and graphics on this
Iterative Design and Testing within the Software Development Life Cycle
Software Quality Journal, 6(4), December 1997, 295-309 Iterative Design and Testing within the Software Development Life Cycle Bor-Yuan Tsai *, Simon Stobart, Norman Parrington and Barrie Thompson School
Comparing Agile Software Processes Based on the Software Development Project Requirements
CIMCA 2008, IAWTIC 2008, and ISE 2008 Comparing Agile Software Processes Based on the Software Development Project Requirements Malik Qasaimeh, Hossein Mehrfard, Abdelwahab Hamou-Lhadj Department of Electrical
Certified Software Quality Engineer (CSQE) Body of Knowledge
Certified Software Quality Engineer (CSQE) Body of Knowledge The topics in this Body of Knowledge include additional detail in the form of subtext explanations and the cognitive level at which the questions
TIBCO Spotfire and S+ Product Family
TIBCO Spotfire and S+ Product Family Compliance with 21 CFR Part 11, GxP and Related Software Validation Issues The Code of Federal Regulations Title 21 Part 11 is a significant regulatory requirement
Latest Research and Development on Software Testing Techniques and Tools
General Article International Journal of Current Engineering and Technology E-ISSN 2277 4106, P-ISSN 2347-5161 2014 INPRESSCO, All Rights Reserved Available at http://inpressco.com/category/ijcet Rasneet
Example Software Development Process.
Example Software Development Process. The example software development process is shown in Figure A. The boxes represent the software development process kernels. The Software Unit Testing, Software Component
Custom Web Development Guidelines
Introduction Custom Web Development Guidelines Unlike shrink wrap software, custom software development involves a partnership between the architect/programmer/developer (SonicSpider) and the owner/testers/users
Karunya University Dept. of Information Technology
PART A Questions 1. Mention any two software process models. 2. Define risk management. 3. What is a module? 4. What do you mean by requirement process? 5. Define integration testing. 6. State the main
Outline. Definitions. Course schedule
SENG480A/CSC576A Topics in Software Engineering Software Development, Architecture & Evolution Lectures, Sep 17, 20, 2001 Hausi A. Müller University of Victoria Outline Assignment 1 due Sep 27 Last week
Software Engineering Compiled By: Roshani Ghimire Page 1
Unit 7: Metric for Process and Product 7.1 Software Measurement Measurement is the process by which numbers or symbols are assigned to the attributes of entities in the real world in such a way as to define
Automated Module Testing of Embedded Software Systems
Automated Module Testing of Embedded Software Systems Master s Thesis Fredrik Olsson Henrik Lundberg Supervisors Thomas Thelin, LTH Michael Rosenberg, EMP Nicklas Olofsson, EMP II Abstract When designing
Software Quality Assurance in Agile, XP, Waterfall and Spiral A Comparative Study
Software Quality Assurance in Agile, XP, Waterfall and Spiral A Comparative Study S. Vijayakumar [email protected] School of Computer and Information Science University of South Australia,
ISTQB Certified Tester. Foundation Level. Sample Exam 1
ISTQB Certified Tester Foundation Level Version 2015 American Copyright Notice This document may be copied in its entirety, or extracts made, if the source is acknowledged. #1 When test cases are designed
SOFTWARE TESTING - QUICK GUIDE SOFTWARE TESTING - OVERVIEW
http://www.tutorialspoint.com/software_testing/software_testing_quick_guide.htm What is Testing? SOFTWARE TESTING - QUICK GUIDE SOFTWARE TESTING - OVERVIEW Copyright tutorialspoint.com Testing is the process
National University of Ireland, Maynooth MAYNOOTH, CO. KILDARE, IRELAND. Testing Guidelines for Student Projects
National University of Ireland, Maynooth MAYNOOTH, CO. KILDARE, IRELAND. DEPARTMENT OF COMPUTER SCIENCE, TECHNICAL REPORT SERIES Testing Guidelines for Student Projects Stephen Brown and Rosemary Monahan
Module 10. Coding and Testing. Version 2 CSE IIT, Kharagpur
Module 10 Coding and Testing Lesson 23 Code Review Specific Instructional Objectives At the end of this lesson the student would be able to: Identify the necessity of coding standards. Differentiate between
Software Testing. Quality & Testing. Software Testing
Software Testing Software Testing Error: mistake made by the programmer/developer Fault: a incorrect piece of code/document (i.e., bug) Failure: result of a fault Goal of software testing: Cause failures
TESSY Automated dynamic module/unit and. CTE Classification Tree Editor. integration testing of embedded applications. for test case specifications
TESSY Automated dynamic module/unit and integration testing of embedded applications CTE Classification Tree Editor for test case specifications Automated module/unit testing and debugging at its best
SOFTWARE DEVELOPMENT METHODOLOGIES, TRENDS, AND IMPLICATIONS
SOFTWARE DEVELOPMENT METHODOLOGIES, TRENDS, AND IMPLICATIONS Xihui Zhang University of North Alabama [email protected] Hua Dai University of Wisconsin-La Crosse [email protected] Tao Hu King College [email protected]
Name of chapter & details
Course Title Course Code Software Testing IT905 (Elective-IV) Theory : 03 Course Credit Practical : 01 Tutorial : 00 Course Learning Outcomes Credits : 04 On the completion of the course, students will
CUT COSTS, NOT PROJECTS
CUT COSTS, NOT PROJECTS Understanding and Managing Software Development Costs A WEBINAR for State of Washington Agencies Critical Logic, Inc. July 9 2009 Starting at 3pm, Pacific Daylight Time Critical
Test Data Management Best Practice
Test Data Management Best Practice, Inc. 5210 Belfort Parkway, Suite 400 Author: Stephanie Chace Quality Practice Lead [email protected], Inc. 2011 www.meridiantechnologies.net Table of
An Agent-Based Concept for Problem Management Systems to Enhance Reliability
An Agent-Based Concept for Problem Management Systems to Enhance Reliability H. Wang, N. Jazdi, P. Goehner A defective component in an industrial automation system affects only a limited number of sub
A Survey of Software Development Process Models in Software Engineering
, pp. 55-70 http://dx.doi.org/10.14257/ijseia.2015.9.11.05 A Survey of Software Development Process Models in Software Engineering Iqbal H. Sarker 1, Faisal Faruque 1, Ujjal Hossen 2 and Atikur Rahman
Keywords: Regression testing, database applications, and impact analysis. Abstract. 1 Introduction
Regression Testing of Database Applications Bassel Daou, Ramzi A. Haraty, Nash at Mansour Lebanese American University P.O. Box 13-5053 Beirut, Lebanon Email: rharaty, [email protected] Keywords: Regression
Sample Exam. 2011 Syllabus
ISTQ Foundation Level 2011 Syllabus Version 2.3 Qualifications oard Release ate: 13 June 2015 ertified Tester Foundation Level Qualifications oard opyright 2015 Qualifications oard (hereinafter called
CS314: Course Summary
CS314: Course Summary Prof. Robert B. France Dept. of Computer Science Colorado State University Robert B. France 1 1 Software Development Issues Explored - 1 Software engineering basics Why do we need
How To Write Software
1 Medical Device Software - Software Life Cycle Processes IEC 62304 2 Credits John F. Murray Software Compliance Expert U.S. Food and Drug Administration Marcie R. Williams Medical Device Fellow Ph.D.
UML-based Test Generation and Execution
UML-based Test Generation and Execution Jean Hartmann, Marlon Vieira, Herb Foster, Axel Ruder Siemens Corporate Research, Inc. 755 College Road East Princeton NJ 08540, USA [email protected] ABSTRACT
Proposed C.E.M (Cost Estimation Metrics): Estimation of Cost of Quality in Software Testing
International Journal of Computer Science and Telecommunications [Volume 6, Issue 2, February 2015] 10 ISSN 2047-3338 Proposed C.E.M (Cost Estimation Metrics): Estimation of Cost of Quality in Software
Software Engineering. Software Development Process Models. Lecturer: Giuseppe Santucci
Software Engineering Software Development Process Models Lecturer: Giuseppe Santucci Summary Modeling the Software Process Generic Software Process Models Waterfall model Process Iteration Incremental
Software Test Plan (STP) Template
(STP) Template Items that are intended to stay in as part of your document are in bold; explanatory comments are in italic text. Plain text is used where you might insert wording about your project. This
What is a life cycle model?
What is a life cycle model? Framework under which a software product is going to be developed. Defines the phases that the product under development will go through. Identifies activities involved in each
Software Engineering/Courses Description Introduction to Software Engineering Credit Hours: 3 Prerequisite: 0306211(Computer Programming 2).
0305203 0305280 0305301 0305302 Software Engineering/Courses Description Introduction to Software Engineering Prerequisite: 0306211(Computer Programming 2). This course introduces students to the problems
JOURNAL OF OBJECT TECHNOLOGY
JOURNAL OF OBJECT TECHNOLOGY Online at www.jot.fm. Published by ETH Zurich, Chair of Software Engineering JOT, 2006 Vol. 5. No. 8, November-December 2006 Requirements Engineering Tasks Donald Firesmith,
Your Software Quality is Our Business. INDEPENDENT VERIFICATION AND VALIDATION (IV&V) WHITE PAPER Prepared by Adnet, Inc.
INDEPENDENT VERIFICATION AND VALIDATION (IV&V) WHITE PAPER Prepared by Adnet, Inc. February 2013 1 Executive Summary Adnet is pleased to provide this white paper, describing our approach to performing
SOFTWARE ENGINEERING INTERVIEW QUESTIONS
SOFTWARE ENGINEERING INTERVIEW QUESTIONS http://www.tutorialspoint.com/software_engineering/software_engineering_interview_questions.htm Copyright tutorialspoint.com Dear readers, these Software Engineering
Software Development Life Cycle (SDLC)
Software Development Life Cycle (SDLC) Supriyo Bhattacharjee MOF Capability Maturity Model (CMM) A bench-mark for measuring the maturity of an organization s software process CMM defines 5 levels of process
Manual Testing Online Training Concepts : Software Testing Manual Module 1: Testing fundamentals. Introduction:
Manual Testing Online Training Concepts : Software Testing Manual Module 1: Testing fundamentals Introduction: Why explicitly the s/w companies are recruited the test engineers: Who can do this Testing:
A system is a set of integrated components interacting with each other to serve a common purpose.
SYSTEM DEVELOPMENT AND THE WATERFALL MODEL What is a System? (Ch. 18) A system is a set of integrated components interacting with each other to serve a common purpose. A computer-based system is a system
A Change Impact Analysis Tool for Software Development Phase
, pp. 245-256 http://dx.doi.org/10.14257/ijseia.2015.9.9.21 A Change Impact Analysis Tool for Software Development Phase Sufyan Basri, Nazri Kama, Roslina Ibrahim and Saiful Adli Ismail Advanced Informatics
White Papers: Unit Testing. www.dcmtech.com. Unit Testing
Unit Testing Table of Contents TESTING, VERIFICATION AND VALIDATION...1 UNIT TESTING PROCEDURES...3 C1 100% COVERAGE...3 QUERY GENERATION...4 TESTING, VERIFICATION and VALIDATION Black Box Testing White
R214 SPECIFIC REQUIREMENTS: INFORMATION TECHNOLOGY TESTING LABORATORY ACCREDITATION PROGRAM
The American Association for Laboratory Accreditation Document Revised: R214: Specific Requirements: Information Technology Testing Laboratory Accreditation July 13, 2010 Program Page 1 of 26 R214 SPECIFIC
Component-based Development Process and Component Lifecycle Ivica Crnkovic 1, Stig Larsson 2, Michel Chaudron 3
Component-based Development Process and Component Lifecycle Ivica Crnkovic 1, Stig Larsson 2, Michel Chaudron 3 1 Mälardalen University, Västerås, Sweden, [email protected] 2 ABB Corporate Research,
Using TechExcel s DevSuite to Achieve FDA Software Validation Compliance For Medical Software Device Development
Using TechExcel s DevSuite to Achieve FDA Software Validation Compliance For Medical Software Device Development The FDA requires medical software development teams to comply with its standards for software
Standard Glossary of Terms Used in Software Testing. Version 3.01
Standard Glossary of Terms Used in Software Testing Version 3.01 Terms Used in the Advanced Level - Test Manager Syllabus International Software Testing Qualifications Board Copyright International Software
Finding Execution Faults in Dynamic Web Application
International Journal of Information and Computation Technology. ISSN 0974-2239 Volume 4, Number 5 (2014), pp. 445-452 International Research Publications House http://www. irphouse.com /ijict.htm Finding
How To Improve Software Quality
Software Qualities Quality Assurance Maintainer Go Documentation Readable Ce Go Design Functionality Ease of use Ease of learning User Reliability Correctness Efficiency Low Cost Portability Increased
1 White-Box Testing by Stubs and Drivers
White-box testing is a verification technique software engineers can use to examine if their code works as expected. In this chapter, we will explain the following: a method for writing a set of white-box
Testing is the process of evaluating a system or its component(s) with the intent to find whether it satisfies the specified requirements or not.
About the Tutorial Testing is the process of evaluating a system or its component(s) with the intent to find whether it satisfies the specified requirements or not. Testing is executing a system in order
JOURNAL OF OBJECT TECHNOLOGY
JOURNAL OF OBJECT TECHNOLOGY Online at http://www.jot.fm. Published by ETH Zurich, Chair of Software Engineering JOT, 2006 Vol. 5, No. 6, July - August 2006 On Assuring Software Quality and Curbing Software
