Authors
Ahmet Celik, Karl Palmskog, Milos Gligoric
Publication date
2017/10/30
Conference
2017 32nd IEEE/ACM International Conference on Automated Software Engineering (ASE)
Pages
171-182
Publisher
IEEE
Description
Proof assistants such as Coq are used to construct and check formal proofs in many large-scale verification projects. As proofs grow in number and size, the need for tool support to quickly find failing proofs after revising a project increases. We present a technique for large-scale regression proof selection, suitable for use in continuous integration services, e.g., Travis CI. We instantiate the technique in a tool dubbed ICOQ. ICOQ tracks fine-grained dependencies between Coq definitions, propositions, and proofs, and only checks those proofs affected by changes between two revisions. ICOQ additionally saves time by ignoring changes with no impact on semantics. We applied ICOQ to track dependencies across many revisions in several large Coq projects and measured the time savings compared to proof checking from scratch and when using Coq's timestamp-based toolchain for incremental checking. Our …
Total citations
201820192020202120222023343325
Scholar articles
A Celik, K Palmskog, M Gligoric - 2017 32nd IEEE/ACM International Conference on …, 2017