Roger S Pressman SOFTWARE sixth edition ENGINEERING A Practitioner'sApproach Software Engineering APPROACH PRACTITIONER'S A GIFT OF THE ASIA FOUNDATION NOT FOR RE-SALE QUÅ TÅNG CUA CHAU Å KHONGmroc BÅNLAI Software Engineering A PRACTITIONER'S APPROACH slXTH EDITION Roger S Pressman, Ph.D 07 00303 GrawHigher Education Hill Boston Burr Ridge, IL Dubuque, IA Madison,WI New York San Francisco St Louis Bangkok Bogotå Caracas Kuala Lumpur Lisbon London Madrid MexicoCity Milan Montreal NewDelhi Santiago Seoul Singapore Sydney Taipei Toronto CONTENTS AT A GLANCE CHAPTER PART ONE PARTTWO The Software Process 19 CHAPTER CHAPTER Process:A Generic View 20 PrescriptiveProcessModels 45 CHAPTER Agile Development 71 Software Engineering Practice 95 CHAPTER CHAPTER CHAPTER CHAPTER CHAPTER CHAPTER CHAPTER CHAPTER CHAPTER PART FOUR Practice:A GenericView 96 System Engineering 122 Requirements Engineering 142 Analysis N'odeling 175 Design Engineering 226 ArchitecturalDesign 254 Il 12 13 CHAPTER 14 CHAPTER 15 PART THREE Eng•neerrg Software and Component-levelDesign 292 User InterfaceDesign 324 Software Testing Strategies 354 SoftwareTestingTechniques 388 ProductMetrics for Software 429 Applying Web Engineering 467 CHAPTER 16 Web Engineering 468 CHAPTER 17 CHAPTER 18 Formulationand Planning 482 CHAPTER 19 Analysis Modeling for Web Applications 507 Design NAodeling for Web Applications 527 CHAPTER 20 TestingWeb Applications 562 Managing Software Proiects 595 CHAPTER 21 Projecth&magementConcepts 596 CHAPTER 22 CHAPTER 23 CHAPTER 24 CHAPTER 25 Process and ProjectMetrics 617 Estimationfor Software Proiects 642 SoftwareProjectScheduling 673 RiskManagement 694 viii CONTENTSAT A GLANCE CHAPTER 26 712 Management 27 Change Management 739 CHAPTER PART FIVE Advanced Topics in Software Engineering 769 CHAPTER 28 CHAPTER 29 CHAPTER 30 CHAPTER CỈAPTER 32 Formal Methods 770 Cecnroorn Sof#nare Engineering 796 Component-BasedSoftvvareEngineering 815 ineerin 837 The Road Ahead 860 TABLE OF CONTENTS Preface xxv Walkthrough xxix SOFTWARE AND SOFTWARE ENGINEERING CHAPTER 1 The Evolving Role of Software 12 Software 1.3 The Changing Nature of Software legacy Software 10 4.2 1.6 The Quality of Legacy Software 11 SofbwareEvolution I I Software Myths How It All Starts 15 Summary 16 REFERENCES 17 PROBLEMSAND POINTSTO PONDER 17 FURTHERREADINGS AND INFORMATIONSOURCES PART ONE—THE SOFTWARE CHAPTER 2.1 2.2 2.3 2.4 2.5 2.6 PROCESS 18 19 PROCESS: A GENERIC VIEW 20 Software Engineering—A Layered Technology A Process Framework 22 The Capability Maturity Model Integration (CMMI) Process Patterns ProcessAssessment 34 Personaland TeamProcessModels 36 Personal Software Process (PSP) 30 2.6 I Team Software Process (TSP) 38 26.2 ProcessTechnology 39 Productand Process 40 Summary 2.7 2.8 2.9 REFERENCES 42 PROBLEMSAND POINTS TO PONDER 43 FURTHERREADINGSAND INFORMATIONSOURCES 43 CHAPTER PRESCRIPTIVEPROCESS MODELS 3.1 3.2 PrescriptiveModels 46 The Waterfall Model 47 3.3 Incremental Process Models 48 The incrementalModel 48 3.3 I 3.3.2 3.4 45 The RAD Model 49 EvolutionaryProcess Models 3.4 I Prototyping The Spiral Model 54 ix or coy-tNTS x Developmen'Model 56 on Evolutionary mocesses 57 r 59 Deve!opment • Model 60 Software Development 61 Process Fi%'ses work Products 66 69 SOURCES70 CHAPTER 4.2 71 AGILE DEVELOPMENT VVhct Is Agility? 73 What Is an Agile Process? 74 The Politicsof Agile Development 75 HumanFactors 76 Agile ProcessModels 77 42.2 4.3 4.3 I 43.2 43.3 Z.3.4 Extreme Programming (XP) 78 Adaptive SofN•vareDevelopment (ASD) 82 Dynamic Systems Development Method (DSDM) Scrum 85 4.3.5 4.3.6 crystal 87 43.7 Agile Modeling (ABA) 89 Feature Driven Development (FDD) 88 4.4 Summary 91 REFERENCES 92 PROBLEMSAND POINTSTO PONDER 93 FURTHERREADINGSAND INFORMATIONSOURCES 94 PART TWO—SOFTWARE ENGINEERING PRACTICE CHAPTER 5.1 95 PRACTICE: A GENERIC VIEW Software Engineering Practice 97 The Essenceof Practice 97 Core Principles 99 Communication Practices 101 Planning Practices 104 Modeling Practices 107 5.1.] 1.2 5.2 5.3 5.4 5.4 I 54.2 5.5 5.6 Analysis Modeling Principles 108 Design Modeling Principles 109 Construction Practice 12 5.5 I Coding Principles and Concepts 5.5.2 Testing Principles 14 Deployment 16 Summary 18 13 96 84 TABLEOF CONTENTS xi REFERENCES 19 PROBLEMS AND POINTSTO PONDER 120 FURTHERREADINGS AND INFORMATION SOURCES CHAPTER 6.2 6.3 6.4 6.5 20 SYSTEM ENGINEERING Computer-Based Systems 123 The System Engineering Hierarchy 125 System Modeling 126 6.2 6.2.2 System Simulation 128 Business Process Engineering: An Overview ProductEngineering: An Overview 130 SystemModeling 132 122 129 HatleyPirbhaiModeling 133 6.5 I 6.5.2 System Modeling with UML 135 6.6 Summary 39 REFERENCES140 PROBLEMSAND POINTSTO PONDER 140 FURTHERREADINGS AND INFORMATIONSOURCES CHAPTER m 7.2 141 REQUIREMENTS ENGINEERING A Bridge to Design and Construction 143 RequirementsEngineeringTasks 144 7.2 inception 144 7.2.2 Elicitation I '45 Elaboration 145 7.2.3 7.24 Negotiation 146 7.2.5 Specification 147 7.26 Validation 147 Requirements Management 148 Initiatingthe RequirementsEngineering Process 7.2.7 7.3 7.3 I 7.4 7.5 7.6 7.7 7.8 7.9 49 Identifying the Stakeholders 150 Recognizing MultipleViewpoints 150 7.3.2 Working toward Collaboration 15 7.3.3 7.3.4 Asking the FirstQuestions 15 Eliciting Requirements 152 7.4.] Collaborative RequirementsGathering 153 7.42 Quality FunctionDeployment 156 7.4.3 User Scenarios 157 ,7.4.4 ElicitationWork Products 158 Developing Use-Cases 159 Building the Analysis Model 164 7.6 I Elementsof the Analysis Model 164 7.6.2 Analysis Patterns 168 Negotiating Requirements 109 Validating Requirements 17 Summary 172 REFERENCES 72 PROBLEMSAND POINTS TO PONDER 173 FURTHERREADINGS AND AFOPMAIION SOURCES 174 142 TABLE OF CONTENTS CHAPTER Requirements Ana!ysis .2 8.2 8.3 175 ANALYSIS MODELING 176 Overcll O$ective and Philosophy 177 AnalysisRues cf Thumb 178 Domain Analysis 178 1.3 Analysis Modeling Approaches 179 Data Modeling Concepts 18 Data Obiects 18 8.3 Data Attributes 82 8.3.2 Relationships 82 Cardinality and Mvodality' 183 ObiectOriented Analysis 185 Scenario-Based Modeling 186 Writing UseCases 186 8.5 I Developing an Activity Diagram 19 8.5.2 SwirnlaneDiagrams 192 8.5.3 F10#Oriented Modeling 8.6 I Creating a Data Flow Model 194 Creating a Control Flow Model 197 8.6.2 The Control Specification 198 8.6.3 8.6.4 The Process Specification 200 8.3.,4 8.4 8.5 8.6 8.7 Class8ased Modeling 201 I 8.7 8.7.2 8.7.3 8.7.4 8.7.5 8.76 8.8 Creatinga 8.8 I 8.8.2 Summary 8.9 REFERENCES222 Identifying Analysis Classes 201 Specifying Attributes 204 Defining Operations 205 Class-ResponsibiliVCollaborator(CRC) Modeling 208 Associationsand Dependencies '4 Analysis Packages 15 BehavioralModel 216 Identifying Events with the Use-Case State Representations 18 22 PROBLEMSAND POINTS10 PONDER 223 FURTHERREADINGSAND INFORMATIONSOURCES 224 CHAPTER DESIGN ENGINEERING 226 9.1 9.2 Design within the Context of Software Engineering Design Process and Design Quality 229 9.3 DesignConcepts 233 9.3, I Abstraction 233 Architecture 233 9.3.2 9.3.3 Patterns 234 9.3.4 Modularity 235 9.3.5 Information Hiding 236 9.36 9.4 F unctionol Independence 236 Refinement 237 Refactoring 238 Design Classes 239 The Design Model 242 9.4 Data Design Elements 243 9.3.7 9.3.8 9.3.9 227 TABLE OF CONTENTS ArchitecturalDesign Elements 243 InterfaceDesign Elements 244 Component-levelDesign Elements 246 9.,4.5 Design Elements 247 Deployment-level 9.5 Pattern-BasedSoftware Design 248 9.5 Describing a Design Pattern 248 I Using Patternsin Design 249 9.5.2 9.5.3 Frameworks 249 9.6 Summary 250 REFERENCES251 9.42 9.4.3 PROBLEMSAND POINTS TO PONDER 25 FURTHERREADINGS AND INFORMATIONSOURCES CHAPTER IOA 10.2 10.3 10 10.5 10.6 10.7 DESIGN 254 Software Architecture 255 What Is Architecture? 255 10 I Why Is ArchitectureImportant? 256 O.I Data Design 257 Data Design at the Architectural Level 257 10.2 I Data Design at the ComponentLevel 258 10.2.2 Architectural Styles and Patterns 259 10.3 I A Brief Taxonomy of Architectural Styles 10.3.2 10.4 ARCHITECTURAL 252 260 Architectural Patterns 264 Organizationand Refinement 265 10.3.3 ArchitecturalDesign 266 10.4 I Representing the System in Context 266 10.4.2 10.4.3 DefiningArchetypes 268 10.5.2 Architectural Complexity 274 Refining the Architecture into Components 269 10.4.4 Describing Instantiationsof the System 271 Assessing AlternativeArchitectural Designs 272 10.5.1 An ArchitectureTrade-Off Analysis Method 272 10.5.3 ArchitecturalDescriptionLanguages 274 Mapping Data Flow intoa Sofhuare Architecture 275 TransformFlow 276 10.6 I TransactionFlow 276 10.6.2 TransformMapping 277 10.6.3 10.6.4 Transaction,Mapping 284 Refiningthe ArchitecturalDesign 288 10.6.5 Summary 288 289 REFERENCES PROBLEMSAND POINTSTO PONDER 290 FURTHERREADINGSAND INFORMATIONSOURCES 291 CHAPTER i1 11.1 COMPONENT-LEVEL DESIGN 292 What Is a Component? 293 An Object-OrientedView 294 The ConventionalView 295 View 298 A Process-Related 1 I Designing Class-Based Components 298 Basic Design Principles 299 I I I xiv TABLEor CONTENTS 1.2.2 2.3 302 Component-levelDesign Guidelines Cohesion 303 Coup'ing 305 Design 307 ConductingComponent-levei 115 116 Object ConstraintLanguage 3 Designing Conventional Components 15 Graphical Design Notation 16 1.5.1 TabularDesign Notation 17 Program Design Language 18 5.4 Comparison of Design Notation 320 Summary 32 322 POINTSTO PONDER 322 SOURCES 323 INFORMAT)ON READINGS CHAPTER 12.1 12.2 12.3 12.4 12.5 12.6 12 324 USER INTERFACE DESIGN The Go'den Rules 325 Place theUser in Control 325 ReducetheUser'sMemoryLoad 327 12 .2 Make the InterfaceConsistent 328 12.1 User InterfaceAnalysis and Design 329 InterfaceAna'ysis and Design Models 330 12.2 I 12.2.2 The Process 33 InterfaceAnalysis 333 12.3 n User Analysis 333 12.3.2 Task Analysis and Modeling 335 Analysis of Display Content 340 12.33 12.3.4 Analysis of the Work Environment 341 InterfaceDesign Steps 341 12.4 I Applying interfaceDesign Steps 342 124.2 User interfaceDesign Patterns 343 12.43 Design Issues 345 Design Evaluation 349 Summary 35 REFERENCES 35 PROBIEMSAND POINTSto PONDER 352 FURTHERREADINGSAND INFORMATIONSOURCES 353 CHAPTER 13 SOFTWARE TESTING STRATEGIES 13.1 A Strategic Approach to Software Testing 355 13 I 13.1.3 13.1.4 13.1.5 13.2 13.3 13.4 Verificationand Validation 356 Organizing for SoftwareTesting 356 A SoftwareTesting Strategy for Conventional Architectures 358 A Soft*'areTesting Strategy for Obiect-Oriented Architectures 359 Criteria for Completion of Testing 360 StrategicIssues 361 TestStrategies for Conventional Software 362 13.3 I Unit Testing 362 130.2 Integration Testing 365 Test Strategies for Object-C)riented Software 13.4 I 13.4.2 354 372 UnitTestingin theOO Context 372 integrationTestingin the 00 Context 373 TABLE OF CONTENTS 13.5 Validation Testing 374 Validation Test Criteria 13.5.1 374 ConfigurationReview 374 13.6 13.5.2 13.5.3 Alpha and Beta Testing 374 SystemTesting 376 13.6 I Recovery Testing 377 SecurityTesting 377 13.7 13.6.2 Stress Testing 377 13.6.3 13.6.4 PerformanceTesting 378 The Art of Debugging 379 The Debugging Process 379 13.7 13.7.2 PsychologicalConsiderations 381 Debugging Strategies 382 13.7.3 13.7.4 Correcting the Error 384 Summary 384 13.8 REFERENCES385 PROBLEMSAND POINTSTO PONDER 385 FURTHERREADINGSAND INFORMATIONSOURCES CHAPTER 14.1 14.2 14.3 14.4 14 SOFTWARE 386 TESTING TECHNIQUES 388 Software Testing Fundamentals 389 Black-Box and White-Box Testing 391 White-Box Testing 392 Basis PathTesting 393 Flow Graph Notation 393 Independent Program Paths 394 14.4.3 14.5 14.5 14.6 14.7 DerivingTestCases 396 Graph Matrices 399 Control StructureTesting 400 ConditionTesting 400 Data Flow Testing 400 14.5.2 loop Testing 401 14.5.3 Black-Box Testing 402 Graph-BasedTestingMethods 403 14.6 I 14.6.2 EquivalencePartitioning 405 14.6.3 BoundaryValueAnalysis 406 14.6.4 Orthogonal Array Testing 407 ObiectOriented TestingMethods 10 14.7 I The TestCase Design Implicationsof 00 Concepts 410 147.2 Applicability of ConventionalTestCase Design Methods 41 14.7.3 Fault-Based Testing 41 147.4 TestCases and Class Hierarchy 412 14.7.5 Scenario-based Testing 12 14.7.6 TestingSurface Structureand Deep Structure 14 14.8 TestingMethods Applicable at the Class Level 415 14.8 I Random Testing for 00 Classes 415 14.8.2 PartitionTestingat theClass level 410 14.9 InterClassTestCase Design 417 14.9 I MultipleClass Testing 17 14.9.2 Tests Derived from Behavior Models 18 14 10 Testingfor Specialized Environments,Architectures,and Applications 420 14.10.1 TestingGUIs 420 TABLE OF CONTENTS 10 Testingof Cheng/Server Architectures d20 Te?ing Documentationand Help Facilities 42 Tes\ing Real-TimeSystems 422 Ratterns u 2.4 70 Z27 SOURCES428 -S CHAPTER 15 PRODUCT METRICS FOR SOFTWARE 429 SoftwareGuaiity 430 McCall's S Factors 43 ISO 91 26 QualityFactors 432 The Transition to a Quantitative View 433 15 I A Frameworkfor ProductMetrics '134 Measures, Metrics, and Indicators 434 15.2 15.22 The Challenge of ProductMetrics 434 5.2.3 Measurement Principles 435 GoalOriented Software Measurement 436 The Attributesof Effective SofNvare Metrics 437 15.26 The ProductMetrics Landscape 438 Metrics for the Analysis Model 440 Function-Bosed Metrics 440 15.3 I 15.3.2 Metricsfor SpecificationQuality 444 Metrics for the Design Model 445 154.1 ArchitecturalDesign Metrics 445 Metrics for Obiect-Oriented Design 448 154.2 15.40 Ciass-OrientedMetrics—TheCK MetricsSuite 449 15.44 ClassOriented Metrics—TheMOOD Metrics Suite 452 15.2.4 15.2.5 15.3 154 00 MetricsProposedby Lorenzand Kidd 453 15.4.6 15.47 Component-levelDesign Metrics 454 Operation-OrientedMetrics 456 User Interface Design Metrics 457 15.5 MetricsforSourceCode 458 15.6 Metrics for Testing 459 156 I Halstead Metrics Applied to Testing 459 15.6.2 Metricsfor ObiectOriented Testing 459 15.7 Metricsfor Maintenance 460 15.8 Summary 461 REFERENCES 462 PROBIEIWAND POINTS10 PONDER 464 FURTHERREADINGSAND INFORMATIONSOURCES 465 PART THREE—APPLYING WEB ENGINEERING CHAPTER 16 I 16.2 16 467 WEB ENGINEERING 468 Attributesof WebBased Systems and Applications 469 WebApp EngineeringLayers 472 16.2 I Process 472 10.2.2 Methods 473 16.2.3 Tools and Technology 474 TABLEOF CONTENTS 16.3 TheWeb EngineeringProcess 474 Defining the Framework 475 16.3 16.3.2 Refiningthe Framework 477 Web EngineeringBestPractices 478 16.4 16.5 Summary 479 REFERENCES 480 PROBLEMS AND POINTSTO PONDER 480 FURTHERREADINGSAND INFORMATIONSOURCES 48 CHAPTER 17 17.1 FORMULATION AND PLANNING FOR WEB ENGINEERING 482 Formulating Web-Based Systems 483 Formulation Questions 483 17.1 RequirementsGathering for WebApps 485 17.4 The Bridge to Analysis Modeling 489 Planning for Web Engineering Proiects 490 The Web EngineeringTeam 491 The Players 491 17.3.2 Building theTeam 492 ProjectManagementissuesfor Web Engineering 493 17.5 17.4 WebApp Planning—Outsourcing494 17.4.2 WebApp Planning—in-House Web Engineering 498 Metricsfor Web Engineeringand WebApps 500 17.6 17.7 17.5 I Metrics for Web Engineering Effort 501 17.5.2 MetricsforAssessing BusinessValue 502 "Worst Practices" for WebApp Projects 502 Summary 504 17.2 17.3 REFERENCES 504 PROBLEMSAND POINTS TO PONDER 505 FURTHERREADINGSAND INFORMATIONSOURCES 500 CHAPTER 18 18.2 18.3 RequirementsAnalysis for WebApps 508 18.1.1 The User Hierarchy 509 18.1.2 Developing Use-Cases 10 Refiningthe Use-Case Model 12 The Analysis Model for WebApps 13 The ContentModel 13 18.3 I DefiningContentObjects 14 18.3.2 ContentRelationshipsand Hierarchy 514 18.3.3 18.4 18.5 18.6 18.7 18.8 ANALYSIS MODELING FOR WEB APPLICATIONS 507 AnalysisClassesforWebApps 515 The InteractionModel 16 The FunctionalModel 19 The Configuration Model 52 RelationshipNavigationAnalysis 521 RelationshipAnalysis—Key Questions 522 18.7.2 Navigation Analysis 523 Summary 524 REFERENCES 525 PROBLEMSAND TO PONDER 525 FURTHERREADINGS AND 'NFORMAIION SOURCES 526 TABLE or CONTENTS CHAPTER 19 DESIGN MODELING FOR WEB APPLICATIONS Destgn Issuesfor Web Engineering 528 Design and WebApp Gualihy 528 Design Goals 53 19.1 The WebE Design Pyramid 532 19.3 19.5 19.6 19.7 VVebApp interface Design 533 19.3.1 InterfaceDesign Principles and Guidelines 19.3.2 InterfaceControl Mechanisms 539 19.3.3 InterfaceDesign Workflow 539 Aesthetic Design 541 19.4 I Layout Issues 542 19.4.2 Graphic Design Issues 542 Content Design 543 19.5 I ContentObjects 543 19.5.2 Content Design Issues 544 534 ArchitectureDesign 545 19.6 I Content Architecture 545 19.6.2 WebAppArchitecture547 Navigation Design 549 19.7 NavigationSemantics 549 19.7.2 Navigation Syntax 551 19.8 Component Level Design 552 19.9 Hypermedia Design Patterns 552 19.10 Object-Oriented Hypermedia Design Method (OOHDM) 19 I O I Conceptual Design for OOHDM 19.10.2 NavigationalDesignforOOHDM 555 554 554 19.10.3 AbstractInterfaceDesign and implementation 556 19.11 Design Metricsfor WebApps 556 Summary557 REFERENCES 558 PROBLEMSAND POINTSTO PONDER 560 FURTHERREADINGSAND INFORMATIONSOURCES 561 CHAPTER 20 I 20 TESTING WEB APPLICATIONS Testing Concepts for WebApps 563 20.1.1 Dimensionsof Quality 563 Errorswithina WebApp Environment 564 Testing Strategy 565 20 I Test Planning 566 The TestingProcess—AnOverview 566 Content Testing 569 20 .2 20.1.3 20.2 20.3 20.3 I 200.2 20.4 Database Testing 571 User Interface Testing 573 20.4 204.2 InterfaceTestingStrategy 573 Testing Interface Mechanisms 574 Testing Interface Semantics 576 204.4 Usability Tests 576 20.45 Compatibility Tests 578 Component-levelTesting 579 20.4.3 20.5 ContentTestingObjectives 569 562 527 TABLEOF CONTENTS 20.6 20.7 Navigation Testing 58 TestingNavigation Syntax 58 20.6 I 20.6.2 TestingNavigation Semantics 582 ConfigurationTesting 583 20.7 I 20.7.2 Server-SideIssues 584 Chent-Side Issues 584 20.8 SecurityTesting 585 20.9 Performance Testing 587 20.9 PerformanceTestingObjectives 20.9.2 load Testing 588 StressTesting 588 209.3 Summary 590 20.10 REFERENCES591 PROBLEMSAND POINTS TO PONDER 592 FURTHERREADINGS AND INFOWIATION SOURCES SOFTWARE PROJECTS 595 PART FOUR—MANAGING CHAPTER 21 21.1 593 PROJECT MANAGEMENT CONCEPTS 596 The ManagementSpectrum 597 The People 597 21.1 The Product 598 The Process 598 The Project 598 The People 599 The Stakeholders 599 21.2.] 21.1.4 21 Team Leaders 600 The Software Team 601 21 2.4 Agile Teams 604 Coordinationand CommunicationIssues 605 21 2.5 The Product 606 2.2 21.2.3 21 21.3.1 21 21 21 218 SoftwareScope 606 Problem Decomposition 607 21 3.2 The Process 608 Melding the Product and the Process 608 21 I Process Decomposition 609 21 4.2 The 610 TheW SHH Principle 612 Critical Practices 12 Summary 13 614 PROBLEMSAND POINTS TO PONDER 614 FURTHERREADINGSAND INFORIVATIONSOURCES 615 CHAPTER 22 PROCESS AND PROJECT METRICS 617 22 A Metrics in the Process and Proiect Domains 18 Process Metrics and Software Process Improvement 618 22.1.1 22.1.2 Project hvletrics 62 22.2 SoftwareMeasurement 622 Size-Oriented Metrics 623 22.2 222.2 FunctionOriented Båetrics 024 TABLE or CONTENTS 22 2.3 22 2.4 22.2.5 Reconciling IOC and FP Metrics 62m ObjectOriented Metrics 626 UseCase OrientedMetrics 627 Web Engineering ProiectMetrics 627 Metrics for Software Qualify 629 22 2.6 22 22.,4 22.5 22.6 630 22.3 n Measuring 22.3 Defect Removal Efficiency 63 Integrating Metrics within the Software Process 632 22 I Argumentsfor SoftwareMetrics 633 22.42 Establishinga Baseline 633 22.4.3 MetricsCollection, Computation, and Evaluation 634 Metrics for Small Organizations 634 Establishing a Software Metrics Program 636 22.7 Summary 638 REFERENCES 638 PROBIE,MS AND POINTSTO PONDER 639 FURTHERREADINGS AND INFORMATIONSOURCES CHAPTER 23 640 ESTIMATION FOR SOFTWARE PROJECTS 23 n 23.2 23.3 Observations on Estimation 643 The Project Planning Process Software Scope and Feasibility 645 23.4 Resources645 23.5 23.6 23.4 I 23.4.2 Human Resources 646 Reusable Software Resources 23.43 Environmental Resources647 646 Software Proiect Estimation 648 Decomposition Techniques 23.6 I 23.6.2 23.6.3 23.64 236.5 236.6 23.6.7 236.8 236.9 649 Softw•are Sizing 649 Problem-BasedEstimation 650 An Exampleof IOC-Based Estimation 651 An Example of fP-Based Estimation 653 Process-Based Estimation 654 An Example of Process-Based Estimation 655 Estimation withUseCases 656 An Example of UseCase Based Estimation 657 Reconciling Estimates 658 23.7 EmpiricalEstirnation Models 659 23.7 I The Structureof EstimationModels 660 237.2 TheCOCOMO Il Model 600 23.7.3 The Sofrware Equation 662 23.8 23.9 Estimation for Obiect-Oriented Projects 663 Speciahzed Estimation Techniques 664 23.9 I Estimation for Agile Development 664 23.9.2 Estimationfor Web Engineering Projects 065 23 I O The Make/ Buy Decision 660 23.10 I Creatinga DecisionTree 667 23.10,2 Outsourcing 068 23 I I Summary669 070 REFERENCES PROBLEMSANO POINTSTO PONDER 071 FURTHERREADINGS AND INFORMATIONSOURCES 671 642 TABLE OF CONTENTS CHAPTER 24 SOFTWARE PROJECT SCHEDULING 24.1 Basic Concepts 674 24.2 ProjectScheduling 676 24.2 I Basic Principles 677 24.2.2 The RelationshipBetween People and Effort 678 EffortDistribution 680 24.2.3 24.3 Defining a Task Set for the Software Project 68 24.4 A TaskSet Example 682 24.3 Refinementof Major Tasks 682 24.3.2 Defininga Task Network 683 Scheduling 684 24.5 TimelineCharts 685 TrackingtheSchedule 686 24.5.2 245.3 Tracking Progress for an OO Project 688 24.6 Earned ValueAnalysis 690 24.7 Summary 691 REFERENCES691 24.5 PROBLEMSAND POINTSTO PONDER 692 SOURCES 693 FURTHERREADINGSAND INFORJ%'ATION CHAPTER 25 RISK MANAGEMENT 694 25 Reactive vs Proactive Risk Strategies 695 25.2 25.3 SofrwareRisks 696 Risk Identification 697 AssessingOverall ProjectRisk 698 25.3 25.3.2 RiskComponentsand Drivers 699 Projection 700 Risk Developing a RiskTable 701 25.4 Assessing RiskImpact 703 25.4.2 Risk Refinement 705 Risk Mitigation,Monitoring,and Management 705 Plan 708 The Summary 709 25.4 25.5 25.6 25.7 25.8 710 REFERENCES AND POINTSTO PONDER 710 PROBLEMS FURTHERREADINYXGSAND INFOPVMATONSOURCES CHAPTER 26 26 26.2 26.4 QUALITY MANAGEMENT 712 Quality Concepts 71 26.1.1 Quality 714 26 I 26 I Qualify Control 714 QualityAssurance 715 26.1.4 cost of 715 Software Quality Assurance 716 Background Issues 717 26.2 I 26.2.2 26,3 71 GA Activities717 SoftwareReviews 719 26.3 I Cost Impactof SoftwareDefects 720 DefectAmplificationand Removal 720 26.3.2 FormalTechnicalReviews 722 The ReviewMeeting 722 26.4 I Review Reportingand Record Keeping 723 26.4.2 673 xxii TABLEor CONTENTS Review Guidelines 724 Reviews 725 26.4 20 Formal Approaches to SCA 727 SoftwareQuo!iti Assurance 727 26.0 266.2 267 A Generic Example 728 Six Sigma forSofNvareEngineering 729 So.+wore Reliability 26.7 I 267.2 730 Measuresof Reliabilityand Availability 731 Software safeb/ 731 26.8 TheiSO 9000 QualityStandards 733 Plan 734 26 The 26.10 Summary 735 736 PROBLEMSAND POINTSTO PONDER 737 FURTHERREADINGSAND INFORMATIONSOURCES 737 CHAPTER 27 27 CHANGE MANAGEMENT Sofrware Configuration Management 739 740 A SCM Scenario 741 27.2 27.3 27.1 n Elements of a Configuration Management System 742 27 .2 27.1.3 Baselines 743 27.1.4 Software Configuration Items 743 The SCM Repository 745 27.2 I The Role of the Repository 745 27.2.2 GeneralFeaturesand Content 746 27.2.3 SCM Features747 The SCM Process 748 Identificationof Objects in the Software Configuration 749 27.3 27.32 27.3.3 27.34 27.3.5 27.4 27.5 VersionControl 750 Change Control 752 Configuration Audit 755 StatusReporting 756 Configuration Management for Web Engineering 756 27.4.I Configuration tv%nagementIssuesfor WebApps 27.42 WebApp ConfigurationObjects 758 27 u 27.4.4 27.4.5 27.4.6 Summary Content Management 758 Change Management 761 VersionControl 763 Auditingand Reporting 764 765 766 REFERENCES PROBLEMSAND POINTSTO PONDER 767 FURTHERREADINGSAND INFORMATIONSOURCES 768 PART FIVE—ADVANCED TOPICS IN SOFTWARE ENGINEERING 769 CHAPTER 28 FORMAL METHODS 770 28 I Basic Concepts 771 28 I I Deficiencies Of Less Formal Approaches 772 28 I Mathematics in Software Development 773 28 I Formalb,/ethodsConcepts 773 757 TABLE OF CONTENTS 28.2 MathematicalPreliminaries 776 Sets and ConstructiveSpecification 776 28.2.1 2822 28.2.3 28.2 Set Operators 778 Logic Operators 780 Sequences780 781 28.3 Applying Mathematical Notation for Formal Specification 28.4 28.5 FormalSpecificationlanguages 783 Object ConstraintLanguage (OCL) 784 A BriefOverview of OCI Syntax and Semantics 784 28.5 I 28.6 The Z SpecificationLanguage 788 28.6 A BriefOverview of Z Syntax and Semantics 788 28.6.2 An ExampleUsingZ 788 The Ten Commandmentsof FormalMethods 791 FormalMethods—TheRoad Ahead 792 Summary 793 28.5.2 28.7 An ExampleUsingOCI 786 28.8 28.9 REFERENCES 793 PROBLEMSAND POINTSTO PONDER 794 FURTHERREADINGSAND INFOR,VATIONSOURCES 795 CHAPTER29 29 I 29.2 29.3 29.4 29.5 CLEANROOM SOFTWAREENGINEERING 796 The CleanroomApproach 797 29.1 I The Cleanroom Strategy 798 29 I What Makes Cleanroom Different? 800 FunctionalSpecification 801 29.2 I Black-Box Specification 802 29.2.2 State-BoxSpecification 803 29.2.3 Clear-BoxSpecification 803 Cleanroom Design 804 29.3 I Design Refinementand Verification 804 29.3.2 Advantages of Design Verification 808 Clean room Testing 809 29.4 I StatisticalUse Testing 810 29.4.2 Certification Summary 12 11 REFERENCES 812 PROBLEMSAND POINTS TO PONDER 81 FURTHERREADINGSAND INFORAWION SOURCES 814 CHAPTER 30 30 I 30.2 30.3 30.4 COMPONENT-BASED SOFTWARE ENGINEERING 815 Engineering of Component-BasedSystems The CBSE Process 818 Domain Engineering 19 30.3 I The Domain Analysis Process 19 CharacterizationFunctions 820 30.3.2 StructuralModeling and StructurePoints 82 30.3.3 Component-BasedDevelopment 822 30.4 I ComponentQualification,Adaptation, and Composition 822 30.4.2 ComponentEngineering 825 30.4.3 Analysis and Design for Reuse 826 xxiv TABLE OF CONTENTS 30.5 30.6 827 Classifying and Retrieving Components Components Describing Reusable I 30.5 Reuse Environment 829 The 30.5.2 827 Economicsof CBSE 830 Cost 830 Impacton Quality, Productivity,and 30.6 30.6.2 Cost Analysis Using Structure Points 83 30.7 Summary 832 833 REFERENCES AND POINTSTO PONDER 834 iNFOR,VATiONSOURCES 835 READNGS CHAPTER 31 Business Process Reengineering 31.2 31.3 31.5 838 31.1 n BusinessProcesses 839 31.1.2 ABPR Model 839 Software Reengineering 841 SoftwareMaintenance 841 31 ProcessModel 842 A SoftvvareReengineering 1.2.2 ReverseEngineering 846 31.3 n 31 3.2 31.4 837 REENGINEERING ReverseEngineeringto UnderstandData 848 Reverse Engineering to Understand Processing 848 Reverse Engineering User Interfaces 849 1.3.3 Restructuring 850 Code Restructuring 850 1.4 I Data Restructuring 85 31 4.2 Forward Engineering 852 Forward Engineering for Client/Server Architectures 853 31.5.1 Forward Engineering for Object-Oriented Architectures 854 5.2 31.5.3 Forward Engineering User Interfaces 855 The Economicsof Reengineering 855 31.6 31.7 Summary 856 857 REFERENCES PROBIEMSAND POINTSTO PONDER 858 FURTHERREADINGSAND INFORMATIONSOURCES CHAPTER 32 859 THE ROAD AHEAD 860 32.1 The Importance of Sofhware—Revisited 32.2 32.3 32.4 32.5 The Scope of Change 861 People and the Way They Build Systems 863 The "New" Software Engineering Process 864 New Modes for RepresentingInformation 865 861 32.6 Technologyas a Driver 867 32.7 The Software Engineer'sResponsibility 868 32.8 A ConcludingComment 870 REFERENCES871 PROBLEMSAND POINTS10 PONDER 871 FURTHERREADINGS INFORMATIONSOURCES Index 873 871 .. .Software Engineering APPROACH PRACTITIONER'S A GIFT OF THE ASIA FOUNDATION NOT FOR RE-SALE QUÅ TÅNG CUA CHAU Å KHONGmroc BÅNLAI Software Engineering A PRACTITIONER'S APPROACH slXTH... CONTENTSAT A GLANCE CHAPTER 26 712 Management 27 Change Management 739 CHAPTER PART FIVE Advanced Topics in Software Engineering 769 CHAPTER 28 CHAPTER 29 CHAPTER 30 CHAPTER CỈAPTER 32 Formal Methods... Role of Software 12 Software 1.3 The Changing Nature of Software legacy Software 10 4.2 1.6 The Quality of Legacy Software 11 SofbwareEvolution I I Software Myths How It All Starts 15 Summary 16