Abstract
We implement extraction of Coq programs to functional languages based on MetaCoq's certified erasure. As part of this, we implement an optimisation pass removing unused arguments. We prove the pass correct wrt. a conventional call-by-value operational semantics of functional languages. We apply this to two functional smart contract languages, Liquidity and Midlang, and to the functional language Elm. Our development is done in the context of the ConCert framework that enables smart contract verification. We contribute a verified boardroom voting smart contract featuring maximum voter privacy such that each vote is kept private except under collusion of all other parties. We also integrate property-based testing into ConCert using QuickChick and our development is the first to support testing properties of interacting smart contracts. We test several complex contracts such as a DAO-like contract, an escrow contract, an implementation of a Decentralized Finance (DeFi) contract which includes a custom token standard (Tezos FA2), and more. In total, this gives us a way to write dependent programs in Coq, test them semi-automatically, verify, and then extract to functional smart contract languages, while retaining a small trusted computing base of only MetaCoq and the pretty-printers into these languages.
Original language | English |
---|---|
Title of host publication | CPP 2021 - Proceedings of the 10th ACM SIGPLAN International Conference on Certified Programs and Proofs, co-located with POPL 2021 |
Editors | Catalin Hritcu, Andrei Popescu |
Number of pages | 17 |
Publisher | Association for Computing Machinery |
Publication date | Jan 2021 |
Pages | 105-121 |
ISBN (Electronic) | 9781450382991 |
DOIs | |
Publication status | Published - Jan 2021 |
Event | 10th ACM SIGPLAN International Conference on Certified Programs and Proofs, CPP 2021, co-located with POPL 2021 - Virtual, Online, Denmark Duration: 17 Jan 2021 → 19 Jan 2021 |
Conference
Conference | 10th ACM SIGPLAN International Conference on Certified Programs and Proofs, CPP 2021, co-located with POPL 2021 |
---|---|
Country/Territory | Denmark |
City | Virtual, Online |
Period | 17/01/2021 → 19/01/2021 |
Keywords
- Blockchain
- Certified programming
- Code extraction
- Coq
- Formal verification
- Proof assistants
- Property-based testing
- Smart contracts
- Software correctness