[go: up one dir, main page]
More Web Proxy on the site http://driver.im/ skip to main content
10.1145/1984708.1984721acmconferencesArticle/Chapter ViewAbstractPublication PagesicseConference Proceedingsconference-collections
research-article

Contractor.NET: inferring typestate properties to enrich code contracts

Published: 28 May 2011 Publication History

Abstract

In this work we present Contractor.NET, a Visual Studio extension that supports the construction of contract specifications with typestate information which can be used for verification of client code. Contractor.NET uses and extends Code Contracts to provide stronger contract specifications. It features a two step process. First, a class source code is analyzed to extract a finite state behavior model (in the form of a typestate) that is amenable to human-in-the-loop validation and refinement. The second step is to augment the original contract specification for the input class with the inferred typestate information, therefore enabling the verification of client code. The inferred typestates are enabledness preserving: a level of abstraction that has been successfully used to validate software artifacts, assisting in the detection of a number of concerns in various case studies including specifications of Microsoft Server protocols.

References

[1]
T. Ball and S. Rajamani. The SLAM project: debugging system software via static analysis. In POPL '02, pages 1--3, 2002.
[2]
E. Bodden, P. Lam, and L. Hendren. Finding programming errors earlier by evaluating runtime monitors ahead-of-time. In FSE '08, pages 36--47, 2008.
[3]
G. de Caso, V. Braberman, D. Garbervetsky, and S. Uchitel. Program abstractions for behaviour validation. In ICSE 2011 (to be published), 2011.
[4]
R. DeLine and M. Fahndrich. Typestates for objects. ECOOP'04 (LNCS), pages 465--490, 2004.
[5]
M. Fähndrich, M. Barnett, and F. Logozzo. Embedded contract languages. In SAC'10, pages 2103--2110, 2010.
[6]
T. A. Henzinger, R. Jhala, and R. Majumdar. Permissive interfaces. In FSE '05, pages 31--40, 2005.
[7]
T. Kim, K. Bierhoff, J. Aldrich, and S. Kang. Typestate protocol specification in JML. In SAVCBS '09, pages 11--18. ACM, 2009.

Cited By

View all
  • (2015)From Test Purposes to Formal JPF PropertiesACM SIGSOFT Software Engineering Notes10.1145/2693208.269324140:1(1-5)Online publication date: 6-Feb-2015
  • (2015)On the Testability of Properties PatternsSoftware Engineering and Formal Methods10.1007/978-3-319-22969-0_11(148-155)Online publication date: 21-Aug-2015
  • (2014)Case studies and tools for contract specificationsProceedings of the 36th International Conference on Software Engineering10.1145/2568225.2568285(596-607)Online publication date: 31-May-2014
  • Show More Cited By

Recommendations

Comments

Please enable JavaScript to view thecomments powered by Disqus.

Information & Contributors

Information

Published In

cover image ACM Conferences
TOPI '11: Proceedings of the 1st Workshop on Developing Tools as Plug-ins
May 2011
70 pages
ISBN:9781450305990
DOI:10.1145/1984708
Permission to make digital or hard copies of all or part of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation on the first page. Copyrights for components of this work owned by others than ACM must be honored. Abstracting with credit is permitted. To copy otherwise, or republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. Request permissions from [email protected]

Sponsors

Publisher

Association for Computing Machinery

New York, NY, United States

Publication History

Published: 28 May 2011

Permissions

Request permissions for this article.

Check for updates

Author Tags

  1. contract strengthening
  2. enabledness abstractions
  3. typestate inference

Qualifiers

  • Research-article

Conference

ICSE11
Sponsor:
ICSE11: International Conference on Software Engineering
May 28, 2011
HI, Waikiki, Honolulu, USA

Upcoming Conference

ICSE 2025

Contributors

Other Metrics

Bibliometrics & Citations

Bibliometrics

Article Metrics

  • Downloads (Last 12 months)1
  • Downloads (Last 6 weeks)0
Reflects downloads up to 06 Jan 2025

Other Metrics

Citations

Cited By

View all
  • (2015)From Test Purposes to Formal JPF PropertiesACM SIGSOFT Software Engineering Notes10.1145/2693208.269324140:1(1-5)Online publication date: 6-Feb-2015
  • (2015)On the Testability of Properties PatternsSoftware Engineering and Formal Methods10.1007/978-3-319-22969-0_11(148-155)Online publication date: 21-Aug-2015
  • (2014)Case studies and tools for contract specificationsProceedings of the 36th International Conference on Software Engineering10.1145/2568225.2568285(596-607)Online publication date: 31-May-2014
  • (2013)Enabledness-based program abstractions for behavior validationACM Transactions on Software Engineering and Methodology10.1145/2491509.249151922:3(1-46)Online publication date: 30-Jul-2013
  • (2013)Supporting incremental behaviour model elaborationComputer Science - Research and Development10.1007/s00450-012-0233-128:4(279-293)Online publication date: 1-Nov-2013

View Options

Login options

View options

PDF

View or Download as a PDF file.

PDF

eReader

View online with eReader.

eReader

Media

Figures

Other

Tables

Share

Share

Share this Publication link

Share on social media