ebook img

Software Testing PDF

652 Pages·2012·18.12 MB·English
by  SinghYogesh
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Software Testing

SOFTWARE TESTING Yogesh Singh CAMBRIDGE UNIVERSITY PRESS Cambridge,NewYork,Melbourne,Madrid,CapeTown, Singapore,SãoPaulo,Delhi,Tokyo,MexicoCity CambridgeUniversityPress 4381/4,AnsariRoad,Daryaganj,Delhi 110002, India Published in the UnitedStates of America by CambridgeUniversityPress,NewYork www.cambridge.org Information on this title: www.cambridge.org/9781107012967 ©YogeshSingh2012 This publication is in copyright. Subject to statutory exception and to the provisions of relevant collective licensing agreements, no reproduction of any part may take place without the written permission of CambridgeUniversityPress. First published 2012 Printed in India at........... A catalogue record for this publication is available from the British Library Library of Congress Cataloguing in Publication data Singh,Yogesh, 1966- Software testing / YogeshSingh. p. cm. Includes bibliographical references. Summary: “Discusses the concept of SoftwareTesting with real-life case studies and solved examples”--Provided by publisher. ISBN 978-1-107-01296-7 (hardback) 1.Computer software--Testing. 2. Computer software--Quality control. I.Title QA76.76.T48S56 2011 005.1'4--dc22 2011012053 ISBN 978-1-107-01296-7 Hardback CambridgeUniversityPress has no responsibility for the persistence or accuracy of URLs for external or third-party internet websites referred to in this publication, and does not guarantee that any content on such websites is, or will remain, accurate or appropriate. Contents List of Figures xi List of Tables xv Preface xxi Acknowledgements xxiii 1. Introduction 1 1.1 SomeSoftware Failures 1 1.1.1 TheExplosion of the Ariane 5 Rocket 1 1.1.2 TheY2KProblem 2 1.1.3 TheUSAStar-Wars Program 3 1.1.4 Failure of London AmbulanceSystem 3 1.1.5 USSYorktownIncident 3 1.1.6 AccountingSoftware Failures 3 1.1.7 Experience of Windows XP 4 1.2 TestingProcess 4 1.2.1 What is SoftwareTesting? 5 1.2.2 WhyShould We Test? 14 1.2.3 WhoShould We Do the Testing? 15 1.2.4 WhatShould We Test? 16 1.3 SomeTerminologies 19 1.3.1 Program and Software 19 1.3.2 Verification and Validation 20 1.3.3 Fault,Error, Bug and Failure 21 1.3.4 Test,TestCase and TestSuite 21 1.3.5 Deliverables and Milestones 22 1.3.6 Alpha,Beta and AcceptanceTesting 22 1.3.7 Quality and Reliability 23 iv Contents 1.3.8 Testing, Quality Assurance and Quality Control 23 1.3.9 Static and DynamicTesting 23 1.3.10 Testing and Debugging 24 1.4 Limitations of Testing 24 1.4.1 Errors in the SoftwareRequirement and SpecificationDocument 24 1.4.2 LogicalBugs 24 1.4.3 Difficult to Measure the Progress of Testing 26 1.5 TheVShapedSoftware Life CycleModel 26 1.5.1 GraphicalRepresentation 27 1.5.2 Relationship of Development and TestingParts 27 Multiple Choice Questions 28 Exercises 34 Further Reading 35 2. Functional Testing 37 2.1 BoundaryValueAnalysis 38 2.1.1 RobustnessTesting 43 2.1.2 Worst-CaseTesting 44 2.1.3 Robust Worst-CaseTesting 46 2.1.4 Applicability 48 2.2 EquivalenceClassTesting 63 2.2.1 Creation of Equivalence Classes 63 2.2.2 Applicability 65 2.3 DecisionTableBasedTesting 81 2.3.1 Parts of the DecisionTable 81 2.3.2 LimitedEntry and ExtendedEntryDecisionTables 82 2.3.3 ‘DoNotCare’ Conditions and RuleCount 82 2.3.4 ImpossibleConditions 83 2.3.5 Applicability 83 2.4 Cause-Effect GraphingTechnique 96 2.4.1 Identification of Causes and Effects 97 2.4.2 Design of Cause-Effect Graph 97 2.4.3 Use of Constraints in Cause-Effect Graph 97 2.4.4 Design of Limited EntryDecisionTable 99 2.4.5 Writing of TestCases 99 2.4.6 Applicability 99 Multiple Choice Questions 102 Exercises 105 Further Reading 108 3. Essentials of Graph Theory 110 3.1 What is a Graph? 110 3.1.1 Degree of a Node 112 3.1.2 RegularGraph 113 Contents v 3.2 MatrixRepresentation of Graphs 113 3.2.1 IncidenceMatrix 114 3.2.2 AdjacencyMatrix 114 3.3 Paths and IndependentPaths 116 3.3.1 Cycles 117 3.3.2 Connectedness of a Graph 117 3.4 Generation of a Graph from Program 123 3.4.1 ProgramGraphs 124 3.4.2 DDPathGraphs 127 3.5 Identification of IndependentPaths 144 3.5.1 CyclomaticComplexity 144 3.5.2 GraphMatrices 150 Multiple Choice Questions 159 Exercises 161 Further Reading 163 4. Structural Testing 165 4.1 Control Flow Testing 165 4.1.1 StatementCoverage 166 4.1.2 BranchCoverage 167 4.1.3 ConditionCoverage 167 4.1.4 PathCoverage 167 4.2 Data Flow Testing 173 4.2.1 Define/ReferenceAnomalies 174 4.2.2 Definitions 174 4.2.3 Identification of du and dc Paths 175 4.2.4 TestingStrategiesUsing du-Paths 175 4.2.5 Generation of TestCases 176 4.3 SliceBasedTesting 197 4.3.1 Guidelines for Slicing 197 4.3.2 Creation of ProgramSlices 198 4.3.3 Generation of TestCases 202 4.4 MutationTesting 212 4.4.1 Mutation and Mutants 212 4.4.2 Mutation Operators 216 4.4.3 MutationScore 216 Multiple Choice Questions 223 Exercises 226 Further Reading 228 5. 0 5.1 VerificationMethods 230 5.1.1 PeerReviews 231 vi Contents 5.1.2 Walkthroughs 231 5.1.3 Inspections 231 5.1.4 Applications 232 5.2 SoftwareRequirementsSpecification (SRS)Document Verification 233 5.2.1 Nature of the SRSDocument 233 5.2.2 Characteristics and Organization of the SRSDocument 233 5.2.3 SRSDocumentChecklist 235 5.3 SoftwareDesignDescription (SDD)DocumentVerification 238 5.3.1 Organization of the SDDDocument 239 5.3.2 TheSDDDocumentChecklist 239 5.4 SourceCodeReviews 241 5.4.1 IssuesRelated to SourceCodeReviews 241 5.4.2 Checklist of SourceCodeReviews 242 5.5 UserDocumentationVerification 243 5.5.1 ReviewProcessIssues 244 5.5.2 UserDocumentationChecklist 244 5.6 SoftwareProjectAudit 245 5.6.1 RelevanceScale 246 5.6.2 Theory and PracticeScale 246 5.6.3 ProjectAudit and ReviewChecklist 246 5.7 CaseStudy 257 Multiple Choice Questions 279 Exercises 282 Further Reading 283 6. Creating Test Cases from Requirements and Use Cases 285 6.1 UseCaseDiagram and UseCases 285 6.1.1 Identification of Actors 286 6.1.2 Identification of UseCases 287 6.1.3 Drawing of UseCaseDiagram 288 6.1.4 Writing of UseCaseDescription 290 6.2 Generation of TestCases from UseCases 292 6.2.1 Generation of Scenario Diagrams 293 6.2.2 Creation of UseCaseScenarioMatrix 294 6.2.3 Identification of Variables in a UseCase 295 6.2.4 Identification of Different InputStates of a Variable 296 6.2.5 Design of TestCaseMatrix 296 6.2.6 AssigningActualValues to Variables 296 6.3 Guidelines for generating validity checks 316 6.3.1 DataType 316 6.3.2 DataRange 316 6.3.3 SpecialDataConditions 316 6.3.4 MandatoryDataInputs 316 6.3.5 DomainSpecificChecks 316 6.4 Strategies for DataValidity 317 6.4.1 Accept Only Known ValidData 317 Contents vii 6.4.2 Reject Known BadData 322 6.4.3 SanitizeAllData 322 6.5 DatabaseTesting 326 Multiple Choice Questions 331 Exercises 333 Further Reading 334 7. Selection, Minimization and Prioritization of Test Cases for Regression Testing 335 7.1 What is RegressionTesting? 335 7.1.1 RegressionTestingProcess 336 7.1.2 Selection of TestCases 337 7.2 RegressionTestCasesSelection 339 7.2.1 SelectAllTestCases 339 7.2.2 SelectTestCasesRandomly 339 7.2.3 SelectModificationTraversingTestCases 339 7.3 Reducing the Number of TestCases 340 7.3.1 Minimization of TestCases 340 7.3.2 Prioritization of TestCases 341 7.4 RiskAnalysis 342 7.4.1 What is Risk? 342 7.4.2 RiskMatrix 343 7.5 CodeCoveragePrioritization Technique 346 7.5.1 TestCasesSelectionCriteria 347 7.5.2 ModificationAlgorithm 347 7.5.3 DeletionAlgorithm 352 Multiple Choice Questions 363 Exercises 364 Further Reading 365 8. Software Testing Activities 368 8.1 Levels of Testing 368 8.1.1 UnitTesting 369 8.1.2 IntegrationTesting 370 8.1.3 SystemTesting 373 8.1.4 AcceptanceTesting 373 8.2 Debugging 374 8.2.1 WhyDebugging is so Difficult? 374 8.2.2 DebuggingProcess 375 8.2.3 DebuggingApproaches 377 8.2.4 DebuggingTools 378 8.3 SoftwareTestingTools 379 8.3.1 StaticSoftwareTestingTools 379 viii Contents 8.3.2 DynamicSoftwareTestingTools 381 8.3.3 ProcessManagementTools 382 8.4 SoftwareTestPlan 382 Multiple Choice Questions 383 Exercises 386 Further Reading 387 9. Object Oriented Testing 389 9.1 What is Object Orientation? 389 9.1.1 Classes and Objects 390 9.1.2 Inheritance 391 9.1.3 Messages,Methods,Responsibility, Abstraction 393 9.1.4 Polymorphism 394 9.1.5 Encapsulation 394 9.2 What is Object Oriented Testing? 395 9.2.1 What is a Unit? 395 9.2.2 Levels of Testing 395 9.3 PathTesting 396 9.3.1 ActivityDiagram 396 9.3.2 Calculation of Cyclomatic Complexity 400 9.3.3 Generation of TestCases 401 9.4 StateBasedTesting 404 9.4.1 What is a StateMachine? 404 9.4.2 StateChartDiagram 406 9.4.3 StateTransitionTables 407 9.4.4 Generation of TestCases 408 9.5 ClassTesting 411 9.5.1 HowShould We Test a Class? 412 9.5.2 IssuesRelated to ClassTesting 412 9.5.3 GeneratingTestCases 412 Multiple Choice Questions 415 Exercises 417 Further Reading 418 10. Metrics and Models in Software Testing 420 10.1 SoftwareMetrics 420 10.1.1 Measure,Measurement and Metrics 420 10.1.2 Applications 421 10.2 Categories of Metrics 422 10.2.1 ProductMetrics for Testing 422 10.2.2 ProcessMetrics for Testing 423 10.3 Object Oriented MetricsUsed in Testing 423

Description:
5.3 Software Design Description (SDD) Document Verification Testing is a very expensive process and consumes one-third to one-half of the cost 'Software Engineering' by K.K. Aggarwal and Yogesh Singh, New Age Publishing. (b). House, 2nd Ed. IEEE Recommended Practice for Software
See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.