Jeff Offutt SWE 637 Software Testing

Slides:



Advertisements
Similar presentations
Introduction to Software Testing Chapter 1 Model-Driven Test Design Paul Ammann & Jeff Offutt
Advertisements

Introduction to Software Testing Chapter 3.1, 3.2 Logic Coverage Paul Ammann & Jeff Offutt
Introduction to Software Testing Chapter 1 Paul Ammann & Jeff Offutt SUMMARY OF PARTS 1 AND 2 FROM LAST WEEK.
Paul Ammann & Jeff Offutt
Introduction to Software Testing Chapter 2.1, 2.2 Overview Graph Coverage Criteria Paul Ammann & Jeff Offutt
Practical Approach to Teaching Software Testing Sashko Ristov 11th Workshop on “Software Engineering Education and Reverse Engineering” – August 22-27,
Review for Final Exam Fall 2014 Jeff Offutt SWE 632 User Interface Design and Development.
SWE 637: Test Criteria and Definitions Tao Xie Prepared based on Slides by ©Paul Ammann and Jeff Offutt Revised by Tao Xie.
637 – Introduction (Ch 1) Introduction to Software Testing Chapter 1 Jeff Offutt Information & Software Engineering SWE 437 Software Testing
Introduction to Software Testing Chapters 1-5 Coverage Summary Paul Ammann & Jeff Offutt
Introduction to Software Testing Paul Ammann & Jeff Offutt Updated 24-August 2010.
Software Testing and Maintenance Lecture 2.1 Overview Graph Coverage
Introduction to Software Testing Chapter 9.2 Program-based Grammars Paul Ammann & Jeff Offutt
Review for Final – Fall 2015 Jeff Offutt SWE 637 Software Testing
1 Graph Coverage (3). Reading Assignment P. Ammann and J. Offutt “Introduction to Software Testing” ◦ Section 2.2 ◦ Section
Introduction to Software Testing (2nd edition) Chapter 5 Criteria-Based Test Design Paul Ammann & Jeff Offutt
Paul Ammann & Jeff Offutt
Paul Ammann & Jeff Offutt
Course Overview CS 4501 / 6501 Software Testing
Paul Ammann & Jeff Offutt
Introduction to Software Testing Chapter 8.1 Logic Coverage
Paul Ammann & Jeff Offutt
Paul Ammann & Jeff Offutt
Paul Ammann & Jeff Offutt
Paul Ammann & Jeff Offutt
Generating Automated Tests from Behavior Models
Paul Ammann & Jeff Offutt
ISP Coverage Criteria CS 4501 / 6501 Software Testing
Introduction to Software Testing Chapter 9.2 Program-based Grammars
Paul Ammann & Jeff Offutt
Graph Coverage Criteria CS 4501 / 6501 Software Testing
Input Space Partition Testing CS 4501 / 6501 Software Testing
Paul Ammann & Jeff Offutt
Paul Ammann & Jeff Offutt
Coverage-Based Test Design CS 4501 / 6501 Software Testing
Graph: Data Flow Criteria CS 4501 / 6501 Software Testing
Paul Ammann & Jeff Offutt
Introduction to Software Testing Chapter 3.1, 3.2 Logic Coverage
Paul Ammann & Jeff Offutt
Logic Coverage CS 4501 / 6501 Software Testing
Paul Ammann & Jeff Offutt
Introduction to Software Testing Chapter 2 Model-Driven Test Design
Paul Ammann & Jeff Offutt
Paul Ammann & Jeff Offutt
Review for Final Exam Fall 2016
Introduction to Software Testing Chapter 5.2 Program-based Grammars
Logic Coverage CS 4501 / 6501 Software Testing
ISP Coverage Criteria CS 4501 / 6501 Software Testing
Graph: Data Flow Coverage Criteria CS 4501 / 6501 Software Testing
Paul Ammann & Jeff Offutt
Jeff Offutt SWE 637 Software Testing
Graph Coverage Criteria CS 4501 / 6501 Software Testing
Graph Coverage Criteria
Graph Coverage Criteria CS 4501 / 6501 Software Testing
Paul Ammann & Jeff Offutt
Graph Coverage Criteria
Review for Final Exam Spring 2018
Logic Coverage for Source Code CS 4501 / 6501 Software Testing
[Ammann and Offutt, “Introduction to Software Testing,” Ch. 8]
Introduction to Software Testing Chapter 8.1 Logic Coverage
Paul Ammann & Jeff Offutt
Design and Implementation of Software for the Web
Review for Final Exam Fall 2018
Paul Ammann & Jeff Offutt
Review for Final – Spring 2018
Paul Ammann & Jeff Offutt
Review for Final Exam Spring 2019
Review for Final – Spring 2019
Introduction to Software Testing Chapter 3.1, 3.2 Logic Coverage
Presentation transcript:

Jeff Offutt SWE 637 Software Testing www.cs.gmu.edu/~offutt/ Review for Final – Fall 2017 Jeff Offutt SWE 637 Software Testing www.cs.gmu.edu/~offutt/

Parameters 4:30 – 7:15 Same room 18 December, next next Monday 11-December is a reading day No quiz retakes after 12-December Closed book / closed notes / closed neighbor One sheet of definitions allowed Hand-written, not typed, double-sided is okay Comprehensive You may take breaks (not all together) Spread out – separate tables and one table per person 637 - Final Review © Jeff Offutt, 2017

Summary: Part 1—Foundations Why Test Software? (Ch 01) Fault, error, failure, program state Test maturity levels Cost of late testing Model-Driven Test Design (Ch 02) RIPR model Other terms Test Automation (Ch 03) Junit Components of a test case Developer Testing (Ch 04) Agile and TDD Criteria-Based Test Design (Ch 05) Test requirements and criteria 637 - Final Review © Jeff Offutt, 2017

Cost of Late Testing 60 50 40 30 20 10 Assume $1000 unit cost, per fault, 100 faults $250K $360K Fault origin (%) Fault detection (%) Unit cost (X) $20K $100K $13K $6K 28-Oct-2010, at GTAC, added the animation to demonstrate increasing the number of faults found early, thereby decreasing the number of faults found late, and finally saving money. Lots of it! This animation is fairly complicated … must practice first!! Requirements Design Prog / Unit Test Integration Test System Test Post-Deployment Software Engineering Institute; Carnegie Mellon University; Handbook CMU/SEI-96-HB-002 637 - Final Review © Jeff Offutt, 2017

Incorrect Program State RIPR Model Reachability Infection Propagation Revealability Test Final Program State Observed Final Program State Reaches Fault Incorrect Final State Infects Incorrect Program State Propagates The failures can be revealed when the observed final program state has overlap with the incorrect final program state. The question is: should testers check the entire program state? How to observe the incorrect program state in a cost-effective manner. Getting the overlap as big as possible and use the cost as small as possible. Reveals Test Oracles 637 - Final Review © Jeff Offutt, 2017

Model-Driven Test Design–Activities refined requirements / test specs Test Design model / structure test requirements DESIGN ABSTRACTION LEVEL IMPLEMENTATION ABSTRACTION LEVEL software artifact input values Test Automation Test Evaluation pass / fail test results Test Execution test scripts test cases 637 - Final Review © Jeff Offutt, 2017

Criteria Based on Structures Structures : Four ways to model software Input Domain Characterization (sets) A: {0, 1, >1} B: {600, 700, 800} C: {swe, cs, isa, infs} Graphs Logical Expressions (not X or not Y) and A and B if (x > y) z = x - y; else z = 2 * x; Syntactic Structures (grammars) 637 - Final Review © Jeff Offutt, 2017

Summary: Part 2 Coverage Criteria (1 of 4) Input Space Partitioning – Ch 6 Input Domain Modeling (6.1) Combination Strategies Criteria (6.2) Handling Constraints Among Characteristics (6.3) Extended Example: Deriving an IDM from JavaDoc (6.4) Be sure to review the coverage definitions in 6.2 Know how to construct partitions and blocks Know how to choose values 637 - Final Review © Jeff Offutt, 2017

ISP Coverage Criteria Subsumption Each Choice Coverage ECC All Combinations Coverage ACoC T-Wise Coverage TWC Multiple Base Choice Coverage MBCC Pair-Wise Coverage PWC Base Choice Coverage BCC 637 - Final Review © Jeff Offutt, 2017

Summary: Part 2 Coverage Criteria (2 of 4) Graph Coverage – Ch 07 Overview (07.1) Graph Coverage Criteria (07.2) Graph Coverage for Source Code (07.3) Graph Coverage for Design Elements (07.4) Graph Coverage for Specifications (07.5) Graph Coverage for Use Cases (07.6) Be sure to review the definitions in 07.2 Know how to generate graphs for various artifacts and apply the criteria to them Know how to choose values (EC, EPC, PPC, …) We skipped data flow—not on the final 637 - Final Review © Jeff Offutt, 2017

Graph Coverage Criteria Subsumption Simple Round Trip Coverage SRTC Node Coverage NC Edge Coverage EC Edge-Pair Coverage EPC Prime Path Coverage PPC Complete Path Coverage CPC Complete Round Trip Coverage CRTC All-DU-Paths Coverage ADUP All-uses Coverage AUC All-defs Coverage ADC 637 - Final Review © Jeff Offutt, 2017

Summary: Part 2 Coverage Criteria (3 of 4) Logic Coverage – Ch 08 Semantic Logic Coverage Criteria (Active) (08.1) Syntactic Logic Coverage Criteria (Inactive) (08.2) Structural Logic Coverage of Programs (08.3) Specification-based Logic Coverage (08.4) Logic Coverage of FSMs (08.5) Be sure to review the coverage definitions in 08.1 Know how to apply the coverage criteria to programs, specs, and FSMs Know how to choose values (CACC, …) 637 - Final Review © Jeff Offutt, 2017

Logic Criteria Subsumption Clause Coverage CC Predicate Coverage PC Combinatorial Clause Coverage COC Restricted Active Clause Coverage RACC Restricted Inactive Clause Coverage RICC General Active Clause Coverage GACC Correlated Active Clause Coverage CACC General Inactive Clause Coverage GICC 637 - Final Review © Jeff Offutt, 2017

Summary: Part 2 Coverage Criteria (4 of 4) Syntax-based Testing – Ch 09 Syntax-based Coverage Criteria (09.1) Program-based Grammars (09.2) Integration and Object-Oriented Testing (09.3) Concepts, not all the details Specification-based Grammars (09.4) Input Space Grammars (09.5) Understand how to derive tests from BNF Understand mutation analysis and mutation testing 637 - Final Review © Jeff Offutt, 2017

Representing Input Domains goal domain specified domain This region is a rich source of software errors … implemented domain 637 - Final Review © Jeff Offutt, 2017

Preparing & Format Re-read the text and handouts Study the homework assignments Redo the quizzes Try exercises in text Get a good night’s sleep Possibly different kinds of questions Mostly problem solving—similar to quizzes, perhaps bigger Short answer Maybe a few T / F, M / C, single answer questions 637 - Final Review © Jeff Offutt, 2017

Posting Grades I will post on Blackboard: Assignment 12 grades Average quiz grades Average assignment grades Participation grades Final exam score 637 - Final Review © Jeff Offutt, 2017

Final Grades 15% participation, 30% quizzes, 20% assignments, 35% final exam Unbiased grading – compute and sort: >= 98 : A+ – Probably only one A+ per class > 93 : A > 90 : A- > 86 : B+ > 80 : B > 75 : B- > 65 : C I will “slide the line” down to an appropriate “break point” 637 - Final Review © Jeff Offutt, 2017

What I Want You to Take Away You in 5 years Me Forgot everything about testing and high quality software Remember testing, but develop software the “same old way” Use these concepts to hand-design more effective tests for your software Apply automation and criteria when possible Convince your company to develop a quality mindset 637 - Final Review © Jeff Offutt, 2017