Abstract
Experience with lightweight formal methods suggests that programmers are willing to write specification if it brings tangible benefits to their usual development activities. This paper considers stronger specifications and studies whether they can be deployed as an incremental practice that brings additional benefits without being unacceptably expensive. We introduce a methodology that extends Design by Contract to write strong specifications of functional properties in the form of preconditions, postconditions, and invariants. The methodology aims at being palatable to developers who are not fluent in formal techniques but are comfortable with writing simple specifications. We evaluate the cost and the benefits of using strong specifications by applying the methodology to testing data structure implementations written in Eiffel and C#. In our extensive experiments, testing against strong specifications detects twice as many bugs as standard contracts, with a reasonable overhead in terms of annotation burden and run-time performance while testing. In the wide spectrum of formal techniques for software quality, testing against strong specifications lies in a 'sweet spot' with a favorable benefit to effort ratio.
Original language | English |
---|---|
Title of host publication | 2013 35th International Conference on Software Engineering, ICSE 2013 - Proceedings |
Pages | 262-271 |
Number of pages | 10 |
DOIs | |
Publication status | Published - 30 Oct 2013 |
Externally published | Yes |
Event | 2013 35th International Conference on Software Engineering, ICSE 2013 - San Francisco, CA, United States Duration: 18 May 2013 → 26 May 2013 |
Conference
Conference | 2013 35th International Conference on Software Engineering, ICSE 2013 |
---|---|
Country/Territory | United States |
City | San Francisco, CA |
Period | 18/05/13 → 26/05/13 |
ASJC Scopus subject areas
- Software