Scenario-Based and Value-Based Specification Mining: Better Together
Specification mining takes execution traces as input and extracts likely program invariants, which can be used for comprehension, verification, and evolution related tasks. In this work we integrate scenario-based specification mining, which uses a data-mining algorithm to suggest ordering constraints in the form of live sequence charts, an inter-object, visual, modal, scenario-based specification language, with mining of value-based invariants, which detects likely invariants holding at specific program points. The key to the integration is a technique we call scenario-based slicing, running on top of the mining algorithms to distinguish the scenario-specific invariants from the general ones. The resulting suggested specifications are rich, consisting of modal scenarios annotated with scenario-specific value-based invariants, referring to event parameters and participating object properties. We have implemented the mining algorithm and the visual presentation of the mined scenarios within a standard development environment. An evaluation of our work over a number of case studies shows promising results in extracting expressive specifications from real programs, which could not be extracted previously. The more expressive the mined specifications, the higher their potential to support program comprehension and testing.
Specification mining, Dynamic analysis, Live sequence charts, Value-based invariants
Automated Software Engineering
LO, David and MAOZ, Shahar.
Scenario-Based and Value-Based Specification Mining: Better Together. (2012). Automated Software Engineering. 19, (4), 423-458. Research Collection School Of Information Systems.
Available at: http://ink.library.smu.edu.sg/sis_research/1558