Presentation is loading. Please wait.

Presentation is loading. Please wait.

Advanced Technology Center Slide 1 Requirements-Based Testing Dr. Mats P. E. Heimdahl University of Minnesota Software Engineering Center Dr. Steven P.

Similar presentations


Presentation on theme: "Advanced Technology Center Slide 1 Requirements-Based Testing Dr. Mats P. E. Heimdahl University of Minnesota Software Engineering Center Dr. Steven P."— Presentation transcript:

1 Advanced Technology Center Slide 1 Requirements-Based Testing Dr. Mats P. E. Heimdahl University of Minnesota Software Engineering Center Dr. Steven P. Miller Dr. Michael W. Whalen Advanced Computing Systems Rockwell Collins 400 Collins Road NE, MS 108-206 Cedar Rapids, Iowa 52498 spmiller@rockwellcollins.com

2 Advanced Technology Center Slide 2 Outline of Presentation Motivation Validation Testing Conformance Testing What’s Next

3 Advanced Technology Center Slide 3 How We Develop Software SW High-Level Reqs. Development SW Design Description Dev. (SW Low-Level Reqs. & SW Arch. SW Source Code Dev. SW Integration (Executable Code Production) SW Low- Level Testing SW Integration Testing HW/SW Integration Testing

4 Advanced Technology Center Slide 4 How we Will Develop Software (From V to a Y) SW High-Level Reqs. Development Software Model SW Integration (Executable Code Production) SW Integration Testing HW/SW Integration Testing Can we trust the code generator? How do we know our model is correct? Validation Testing Formal Verification Conformance Testing

5 Advanced Technology Center Slide 5 Outline of Presentation Motivation Validation Testing Conformance Testing What’s Next

6 Advanced Technology Center Slide 6 How we Will Develop Software (From V to a Y) SW High-Level Reqs. Development Software Model SW Integration (Executable Code Production) SW Integration Testing HW/SW Integration Testing How do we know our model is correct?

7 Advanced Technology Center Slide 7 Modeling Process SW High-Level Reqs. Development Software Model SW Integration (Executable Code Production) Desired Model Properties High-Level Requirements Low-Level Requirements

8 Advanced Technology Center Slide 8 Problem—Modeling Frenzy SW High-Level Reqs. Development Software Model SW Integration (Executable Code Production) Desired Model Properties Headfirst into modeling How do we know the model is “right”? How do we test the model?

9 Advanced Technology Center Slide 9 One Solution: Redefine Requirements System Reqs. Development Software Model SW Integration (Executable Code Production) SW Integration Testing HW/SW Integration Testing SoftwareDevelopment Processes(DO-178B) SoftwareDevelopment Processes(DO-178B) SystemDevelopment Processes(ARP4754) SystemDevelopment Processes(ARP 4754) The model is the requirements Use Engineering Judgment when Testing

10 Advanced Technology Center Slide 10 One Solution: Redefine Requirements System Reqs. Development Software Model SW Integration (Executable Code Production) SW Integration Testing HW/SW Integration Testing SoftwareDevelopment Processes(DO-178B) SoftwareDevelopment Processes(DO-178B) SystemDevelopment Processes(ARP4754) SystemDevelopment Processes(ARP 4754) The model is the requirements Use Engineering Judgment when Testing My Comment

11 Advanced Technology Center Slide 11 Testing Does not go Away System Reqs. Development Software Model SW Integration (Executable Code Production) SW Integration Testing HW/SW Integration Testing Extensive Testing (MC/DC)

12 Advanced Technology Center Slide 12 It Simply Moves System Reqs. Development Software Model SW Integration (Executable Code Production) SW Integration Testing HW/SW Integration Testing Extensive Testing (MC/DC)

13 Advanced Technology Center Slide 13 Do it Right! SW High-Level Reqs. Development Software Model SW Integration (Executable Code Production) Desired Model Properties Analysis (Model Checking, Theorem Proving) Specification Test – Is the Model Right?

14 Advanced Technology Center Slide 14 How Much to Test? State Coverage Masking MC/DC? Transition Coverage ? Decision Coverage ? Def-Use Coverage ? Somethin g New?? MC/DC Where Do the Tests Come From?

15 Advanced Technology Center Slide 15 Properties are Requirements… Requirements Based Testing SW High-Level Reqs. Development Software Model SW Integration (Executable Code Production) Desired Model Properties Cover the Properties!

16 Advanced Technology Center Slide 16 Properties are Requirements

17 Advanced Technology Center Slide 17 Requirements Based Testing Advantages  Objective Measurement of Model Validation Efforts – Requirements Coverage in Model-based Development – Help Identify Missing Requirements Measure converge of model  Basis for Automated Generation of Requirements-based Tests – Even If Properties Are Not Used for Verification, They Can Be Used for Test Automation How Are Properties “Covered” with Requirements-based Tests?

18 Advanced Technology Center Slide 18 Property Coverage “If the onside FD cues are off, the onside FD cues shall be displayed when the AP is engaged” – G(((!Onside_FD_On & !Is_AP_Engaged) -> X(Is_AP_Engaged -> Onside_FD_On))  Property Automata Coverage – Cover a Synchronous Observer Representing the Requirement (Property)  Structural Property Coverage – Demonstrate Structurally “Interesting” Ways in Which the Requirement (Property) Is Met

19 Advanced Technology Center Slide 19 Property Automata Coverage  Cover Accepting State Machine As Opposed to Structure of Property  Büchi Coverage – State Coverage, Transition Coverage, Lasso Coverage…

20 Advanced Technology Center Slide 20 Alternative Machine  Different synthesis algorithms give different automata – Will affect the test cases required for coverage

21 Advanced Technology Center Slide 21 Structural Property Coverage  Define Structural Coverage Criteria for the Property Specification – Traditional Condition-based Criteria such as MC/DC Prime Candidates  Property Coverage Different than Code Coverage – Coverage of Code and Models Evaluate a decision with a specific combination of truth values in the decision – Coverage of Properties Run an execution scenario that illustrates a specific way a requirement (temporal property) is satisfied

22 Advanced Technology Center Slide 22Example – G(((!Onside_FD_On & !Is_AP_Engaged) -> X(Is_AP_Engaged -> Onside_FD_On))  Demonstrate That Somewhere Along Some Execution Trace Each MC/DC Case Is Met – Only the “positive” MC/DC cases The negative cases should have no traces  In the Case of G(p)—Globally p Holds—we Need to Find a Test Where – in the prefix the requirement p is met – we reach a state of the trace where the requirement p holds because of the specific MC/DC case of interest – let us call this case a – then the requirement p keeps on holding through the remainder of the trace  p U ( a U X(G p)) ppappp

23 Advanced Technology Center Slide 23Summary  Objective Measurement of Model Validation Efforts – Requirements Coverage in Model-based Development – Help Identify Missing Requirements  Basis for Automated Generation of Requirements-based Tests – Even If Properties Are Not Used for Verification, They Can Be Used for Test Automation and Test Measurement  Challenges – How Are Properties Specified? Combination of Observers and Temporal Properties – What Coverage Criteria Are Suitable? – How Is Automation Achieved? – How Do We Eliminate “Obviously” Bad Tests? Should We? – How Do We Generate “Realistic” Test-cases? – Rigorous Empirical Studies Badly Needed

24 Advanced Technology Center Slide 24 Outline of Presentation Motivation Validation Testing Conformance Testing What’s Next

25 Advanced Technology Center Slide 25 How we Will Develop Software (From V to a Y) SW High-Level Reqs. Development Software Model SW Integration (Executable Code Production) SW Integration Testing HW/SW Integration Testing Can we trust the code generator?

26 Advanced Technology Center Slide 26 “Correct” Code Generation—How?  Provably Correct Compilers – Very Hard (and Often Not Convincing)  Proof Carrying Code  Generate Test Suites From Model – Compare Model Behavior With Generated Code – Unit Testing Is Now Not Eliminated, but Largely Automated Specification/Model Implementation Output Specification Based Tests Generate

27 Advanced Technology Center Slide 27 Existing Capabilities  Several Commercial and Research Tools for Test-Case Generation – TVEC Theorem Proving and Constraint Solving techniques – Reactis from Reactive Systems Inc. Random, Heuristic, and Guided Search – University of Minnesota Bounded Model Checking – NASA Langley Bounded Model Checking/Decision Procedures/Constraint Solving  Tools Applicable to Relevant Notations – In Our Case Simulink

28 Advanced Technology Center Slide 28 An Initial Experiment  Used a Model of the Mode Logic of a Flight Guidance System As a Case Example  Fault Seeding – Representative Faults – Generated 100 Faulty Specifications  Generate Test Suites – Selection of Common (and Not So Common) Criteria  Fault Detection – Ran the Test Suites Against the Faulty Specifications – Recorded the Total Number of Faults Detected

29 Advanced Technology Center Slide 29 Fault Finding Results Same Effort

30 Advanced Technology Center Slide 30 Model “Cheats” Test Generator FCS Architecture

31 Advanced Technology Center Slide 31 Effect of Test Set Size

32 Advanced Technology Center Slide 32Summary  Automated Generation of Conformance Tests – Current Technology Largely Allows This Automation  Challenges – Development of Suitable Coverage Criteria – Effect of Test Set Size on Test Set Effectiveness – Effect of Model Structure on Coverage Criteria Effectiveness – Traceability of Tests to Constructs Tested – Empirical Studies of Great Importance

33 Advanced Technology Center Slide 33 Outline of Presentation Motivation Conformance Testing Validation Testing What’s Next

34 Advanced Technology Center Slide 34 New Challenges for Testing  Model Validation – Requirements-based Testing – How Do We Best Formalize the Requirements? – What Coverage Criteria Are Feasible? – Which Coverage Criteria Are Effective (If Any)? – How Do We Generate “Realistic” Tests? – Will This Be a Practical (Tractable) Solution?  Conformance Testing – What Coverage Criteria Are Effective? Detecting Faults From Manual Coding Detecting Faults From Code Generation – Relationship Between Model Structure and Criteria Effectiveness – Traceability From Tests to Model – Relationship Between Model Coverage and Code Coverage Optimizations in Code Generator Will Compromise Coverage

35 Advanced Technology Center Slide 35Discussion

36 Advanced Technology Center Slide 36 Perfection is Not Necessary  Tools and Models Only Need To Be Better Than Manual Processes… – How Do We Demonstrate This? Empirical Studies Are of Great Importance ≥ Missed Faults I Think Many Already Are

37 Advanced Technology Center Slide 37 DO-178B Test Objectives 1.The executable code complies with the high-level requirements. 2.The executable code complies with the specification (low-level requirements). 3.Test coverage of high-level requirements is achieved 4.Test coverage of specification (low-level requirements) is achieved 5.Test coverage of the executable code is achieved Requirements-Based Testing Conformance Testing


Download ppt "Advanced Technology Center Slide 1 Requirements-Based Testing Dr. Mats P. E. Heimdahl University of Minnesota Software Engineering Center Dr. Steven P."

Similar presentations


Ads by Google