• 微课视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
微课江湖
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 微课视频
  • 安全教程
  • 安全设置
  • 杀毒防毒
  • 病毒查杀
  • 脚本攻防
  • 入侵防御
  • 工具使用
  • 业界动态
  • Exploit
  • 漏洞分析
  • 加密解密
  • 手机安全
  • 区块链
您的位置:首页 > 网络安全 >区块链 > 如何编写以太坊ERC-20智能合约的单元测试

如何编写以太坊ERC-20智能合约的单元测试

作者:区块网 字体:[增加 减小] 来源:互联网 时间:2018-11-03

区块网向大家分享了如何编写以太坊ERC-20智能合约的单元测试,其中包含以太坊ERC-20,智能合约等知识点,遇到此问题的同学们可以参考下

为您的智能合约编写单元测试非常重要,就像为任何开发项目编写代码一样。然而,基于区块链的解决方案中的单装置测试常常被低估和忽视。去年,我对大部分为以太坊以及Neo、Eos、Tron和比特币区块链撰写的智能合约进行了200多次审计。根据我的观察,这些项目中有将近一半没有编写装置测试。这种监督常常导致合同执行情况不佳,以及审计过程中发现的各种安全问题。



必备的测试

每个智能合约都有一些共同的部分,比如构造函数、总供应、用于来回传输的函数、用于审批的函数,有时还有用于燃烧额外代币的函数。因此,检查您的智能合约是否正确初始化所有参数,以及当您溢出总供应或其他装置值时是否能及时返回,都是非常重要的。您还需要检查修饰符和正确的权限使用。

在这里,我们将以以太坊为例,但这也适用于其他平台,因为合约往往具有相同的结构。首先,让我们测试适当的代币初始化和对某个地址的正确传输。

正确初始化的测试很简单。您只需要创建一个示例合约并检查所有必须初始化的值的正确性即可。

检查传递函数是非常重要的,因为可能会有一些问题会导致不正确的传递。您必须确保接收方和发送方的平衡,试图得到恢复以防被错误的函数参数所影响,例如,发送数量超过发送方的平衡,合同地址或无效的地址进行了发送等等情况都有可能发生。最后, 您必须检查从传输事件获得正确的日志。

transferFrom函数非常类似于transfer,但是这里您还需要测试spender是否有足够经过批准的余额来发送。以下是在支出比所需资金少的情况下进行的测试。

approve函数是ERC20标准中最简单的函数。不需要检查零地址,只要检查津贴数组是否正确填充就足够了。另外,如果您没有增加审批或减少审批功能,approve将覆盖所有先前的值。因此,我们建议使用这些函数来防止不必要的覆盖。当然,检查从审批事件中获得正确日志是很重要的。

大多数智能合约都包含了一个函数,用于燃烧主销售后遗留的代币。它们中的许多都有一个特殊的代币持有者帐户,有时是所有者帐户。因此,对于燃烧未售出的代币,最好的解决方案是:获取持有者地址上的代币数量,然后从总供应中减去这个数量,并将代币数量设置为零。这将确保您不会烧掉所有的代币,因此在白纸上列出代币燃烧策略是很重要的。

结论

在将智能合约部署到主网络之前,测试它是非常重要的,以防止将来出现问题。当您编写了装置测试时,它们将保证您的白皮书和智能合约之间不会有任何差异,并且您的智能合约不会被调用功能所攻击。

一段时间以来,我听到的最佳编程访谈引语是:“在装置测试完成之前,代码不会先完成。——@brianrivard

这不仅仅是只关于智能合约,你需要为你的所有应用和代码进行装置测试,因为它向你展示了你的应用可能如何失败的所有方式。


更多区块链信息:www.qukuaiwang.com.cn/news

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 如何编写以太坊ERC-20智能合约的单元测试

相关文章

  • 2018-11-03什么是私钥到底长啥样?
  • 2018-11-03SegWit2x 客户端安装教程
  • 2018-11-03EMONT Frenzy一EMONT联盟的区块链游戏
  • 2018-11-03什么是比特币驱动链
  • 2018-11-03ERC-20 Token合约详解
  • 2018-11-03智能合约攻击:我们都应该从DAO中吸取经验
  • 2018-11-03从PoS到dBFT:浅析共识协议
  • 2018-11-03基于以太坊的联盟链?Quorum机制初探(中)
  • 2018-11-03DECENT网络播种机制说明
  • 2018-11-03某乎上面对于区块链的理解(一)

文章分类

  • 安全教程
  • 安全设置
  • 杀毒防毒
  • 病毒查杀
  • 脚本攻防
  • 入侵防御
  • 工具使用
  • 业界动态
  • Exploit
  • 漏洞分析
  • 加密解密
  • 手机安全
  • 区块链

最近更新的内容

    • 熊市学技术—《挖矿=POW=工作量证明》
    • 升级您的以太坊智能合约的最佳实践
    • 蚂蚁矿机S9固件升级教程
    • 数字货币实际上是如何工作的?
    • 比特币的主心骨:网络节点 (nodes)
    • 比原链(Bytom)合约交易构造流程
    • 为什么去中心化和分布式存储对一个更好的互联网至关重要?
    • 加密算法之椭圆曲线密码学(ECC)启蒙
    • 如何审核智能合约
    • 区块链技术在信任经济中的思路解读

关于我们 - 联系我们 - 免责声明 - 网站地图

©2015-2018 All Rights Reserved. 微课江湖 版权所有