1. Model-Based Software Design and Testing in Blockchain Smart Contracts: A Systematic Literature Review
- Author
-
Nicolás Sánchez-Gómez, María José Escalona, Jesus Torres-Valderrama, J. A. García-García, and Javier J. Gutiérrez
- Subjects
blockchain ,Blockchain ,General Computer Science ,Smart contract ,Computer science ,Vulnerability ,Domain (software engineering) ,Intermediary ,Software ,software development life cycle ,General Materials Science ,computer.programming_language ,Functional specification ,Software engineering ,business.industry ,General Engineering ,model-based software engineering ,software testing ,SPARK (programming language) ,Systems development life cycle ,Software design ,lcsh:Electrical engineering. Electronics. Nuclear engineering ,business ,smart contract ,computer ,lcsh:TK1-9971 - Abstract
Blockchain technology promises to spark a real revolution. One of most important concepts associated with this technology is smart contracts, which enable the automatic execution of agreements and augur a world without intermediaries. The conditions and rules of “contracts” are established in a computer codes and trust is enforced by consensus among the participants. One relevant feature associated with smart contract is the immutability property, which establishes the non-alteration of blockchain network data after the clauses of the contract are been approved by all parties or entities involved. For this reason, smart contract development requires more effort and care than the development of other common programs. They require systematic mechanisms to collect requirements and functional specifications. In addition, it is necessary to verify and validate the agreed functionality and the implemented code before they are deployed in the blockchain platform. This article presents a systematic literature review of primary studies in the field of Software Development Life Cycle, focusing on model-based software design and testing in the blockchain domain of smart contracts. This research aims to identify gaps and/or opportunities for further research. After carried out this review, it was observed that no clear methodology exists for evaluating and validating the quality either of this software or the overall development process. This means that software developers may implement smart contract code in which bugs and serious security vulnerabilities appear when the software is delivered to their customers.
- Published
- 2020