Debugging Smart Contract’s Business Logic Using Symbolic Model Checking
- 作者: Shishkin E.1
- 
							隶属关系: 
							- InfoTeCS, Advanced Research Department
 
- 期: 卷 45, 编号 8 (2019)
- 页面: 590-599
- 栏目: Article
- URL: https://journals.rcsi.science/0361-7688/article/view/177059
- DOI: https://doi.org/10.1134/S0361768819080164
- ID: 177059
如何引用文章
详细
Smart contracts are a special type of programs running inside a blockchain. Immutable and transparent, they provide means to implement fault-tolerant and censorship-resistant services. Unfortunately, its immutability causes a serious challenge of ensuring that a business logic and implementation is correct upfront, before publishing in a blockchain. Several big accidents have indeed shown that users of this technology need special tools to verify smart contract correctness. Existing automated checkers are able to detect only well known implementation bugs, leaving the question of business logic correctness far aside. In this work, we present a symbolic model-checking technique along with a formal specification method for a subset of Solidity programming language that is able to express both state properties and trace properties; the latter constitutes a weak analogy of temporal properties. We evaluate the proposed technique on the MiniDAO smart contract, a young brother of notorious TheDAO. Our Proof-of-Concept was able to detect a non-trivial error in the business logic of this smart contract in a few seconds.
作者简介
E. Shishkin
InfoTeCS, Advanced Research Department
							编辑信件的主要联系方式.
							Email: evgeny.shishkin@infotecs.ru
				                					                																			                												                	俄罗斯联邦, 							Moscow						
补充文件
 
				
			 
						 
						 
					 
						 
						 
				 
  
  
  
  
  电邮这篇文章
			电邮这篇文章  开放存取
		                                开放存取 ##reader.subscriptionAccessGranted##
						##reader.subscriptionAccessGranted## 订阅存取
		                                		                                        订阅存取
		                                					