TL;DR
This paper introduces a mutation testing approach for Solidity smart contracts, enhancing fault detection and preventing costly errors on blockchain platforms like Ethereum.
Contribution
It proposes 10 mutation operators tailored for Solidity, extending the Universal Mutator tool to improve smart contract testing effectiveness.
Findings
Successfully detected 10 of 15 known faulty smart contracts
Mutation operators generated mutants for real-world bugs
Enhanced testing tool for Solidity smart contracts
Abstract
Smart contracts are immutable, verifiable, and autonomous pieces of code that can be deployed and ran on blockchain networks like Ethereum. Due to the immutability nature of blockchain, no change is possible on a deployed smart contract or a verified transaction. On the other hand, there are millions of dollars carried by smart contracts in Ethereum blockchain, and hence, a faulty smart contract can lead to a huge monetary loss. Therefore, it is important for smart contract developers to fully test and check the correctness of their code before deploying it on the blockchain. In this paper, we propose a testing mechanism for smart contracts in Solidity language, based on mutation testing. We analyzed a comprehensive list of known bugs in Solidity smart contracts, and designed 10 classes of mutation operators inspired by the real faults. Our experimental results show that our proposed…
Peer Reviews
No public reviews on file for this paper yet. If you reviewed it on a platform where reviews are public (OpenReview, ICLR, NeurIPS, ICML), you can paste yours below so the community can read it here.
Code & Models
Videos
No videos yet. Explain this paper in a talk, walkthrough, or lecture? Add one.
