Projects per year
Abstract
Circus combines constructs to define complex data operations and interactions; it integrates Z and CSP, and, distinctively, it is a language for refinement that can describe programs as well as specification and design models. The semantics is based on the unifying theories of programming (UTP). Most importantly, Circus is representative of a class of refinement-oriented languages that combines facilities to specify abstract data types in a model-based style and patterns of interaction. What we present here is the Circus testing theory; this work is relevant as a foundation for sound test-generation techniques for a plethora of state-rich reactive languages. To cater for data operations, we define symbolic tests and exhaustive test sets. They are the basis for test-generation techniques that can combine coverage criteria for data and transition models. The notion of correctness is Circus refinement, a UTP-based generalisation of failures-divergences refinement that considers data modelling. Proof of exhaustivity exploits the correspondence between the operational and denotational semantics.
Original language | English |
---|---|
Pages (from-to) | 97-147 |
Number of pages | 51 |
Journal | Acta Informatica |
Volume | 48 |
Issue number | 2 |
DOIs | |
Publication status | Published - 1 Apr 2011 |
Keywords
- unifying theories of programming
- formal testing
- symbolic testing
- process algebra
- CSP
- Z
Projects
- 1 Finished
-
ProCLaws: Programming from Control Laws
1/07/07 → 30/09/11
Project: Research project (funded) › Research