NEO智能合约调试流程说明

Neo智能合约调试比较麻烦,我们NEL在开发NNS的过程中,发现现存的工具根本无法支撑我们开发如此复杂的智能合约。

所以我们搞了一整套自己的智能合约调试工具

第一步、编译智能合约

安装neondebug

Git 抓取编译:https://github.com/NewEconoLa...

你将得到一个崭新的neon.exe

用他替换掉你原来用的那个neon.exe

怎么替换呢,请参照如下步骤移除你原来neon.exe 的path,换上neondebug的

NEO智能合约调试流程说明_第1张图片
NEO智能合约调试流程说明_第2张图片
NEO智能合约调试流程说明_第3张图片
NEO智能合约调试流程说明_第4张图片

为什么要安装neondebug

Neondebug 多导出了一个map.json文件,实现avm到源码的映射。

同时按照hash 将 avm abi cs map.json 整理到一起

比如生成

NEO智能合约调试流程说明_第5张图片
NEO智能合约调试流程说明_第6张图片

就会直接用scripthash整理相关文件

检查编译结果

NEO智能合约调试流程说明_第7张图片

用neondebuggui “ load avm from file “ 按钮,加载刚生成的avm文件

可以进行查看,查看以后,就可以用NEONDEBUGGUI的调试交易工具调试使用此脚本的交易。

查看一次即可。文件会被copy到neondebuggui的目录中

开源智能合约

NEO智能合约调试流程说明_第8张图片

使用upload this to server 按钮,可以将智能合约代码上传到服务器,则任何人可以获取到此合约信息

NEO智能合约调试流程说明_第9张图片

使用 load from server 按钮,可以根据scripthash查看服务器上的合约信息。

第二步、产生一个交易

安装neo-gui-nel

Git抓取编译:https://github.com/NewEconoLa...

你将得到一个NEL定制版本的NEO-GUI

这个定制版本乍看没有什么东西,但是来发布一下刚才的智能合约你就会发现一点不同

请注意neo-gui-nel 默认配置在testnet上面。

发布合约

NEO智能合约调试流程说明_第10张图片

NEL定制版本NEO-GUI已经率先支持了发布NEP4( dyncall)合约

第三步、调试

调用合约

NEO智能合约调试流程说明_第11张图片

调用合约NEOGUI定制版也可以添加一个Array

试想这个智能合约Main(string,object[] args),其中args[0] 是 一个 string[]

这就需要array里面嵌套array,现在的neogui 是没有办法调用这样的合约的

NEO智能合约调试流程说明_第12张图片

调试试运行合约

NEO智能合约调试流程说明_第13张图片

当你点击试运行以后就已经可以调试了

NEO智能合约调试流程说明_第14张图片

按照Neo-gui-nel默认的配置,你点击试运行之后,就会在这个目录得到一个0x00文件

使用它就可以完成NEO智能合约调试了。

NEO智能合约调试流程说明_第15张图片

使用NEONDEBUGGUI的Debug Transaction 选项卡

LoadFromFile button,打开这个0x00文件

NEO智能合约调试流程说明_第16张图片

你就得到了一个拥有智能合约详细执行的每一步的工具。

并且可以对应到源码,可以观察执行栈细节,可以观察每一个数据的细节的工具。

让你可以完全了解到这次test是怎么运行的

调试交易

NEO智能合约调试流程说明_第17张图片

发送一笔交易,等一会儿,等这笔交易被确认

NEO智能合约调试流程说明_第18张图片

你就可以在fulllog目录找到这笔交易对应的文件

打开它,就能够调试这笔交易在链上的实际运行细节。

第四步、更多更方便

  1. 只要有人upload过一次的智能合约,所有人随时都能调试时看到源码
  2. 我们有一个爬虫,随时将testnet的合约的log文件上传到服务器

NEO智能合约调试流程说明_第19张图片

即使你没有安装NEO-GUI-NEL,你使用loadformserver按钮也可以调试,只要你知道交易id就行。

  1. 未来我们将开发纯网页版的调试工具
  2. 未来我们也将同步主网的数据也上传服务器

原文转自:https://mp.weixin.qq.com/s/sZ...

你可能感兴趣的:(NEO智能合约调试流程说明)