NEO智能合约调试流程说明

naoye 5月前 272

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

 

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

第一步、编译智能合约

安装neondebug

Git 抓取编译

https://github.com/NewEconoLab/neondebug

 

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

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

 

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

 



 

为什么要安装neondebug

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

 

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

 

比如生成



 

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

检查编译结果



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



 

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

查看一次即可。文件会被copyneondebuggui的目录中

开源智能合约



 

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


 

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

第二步、产生一个交易

安装neo-gui-nel

Git抓取编译

https://github.com/NewEconoLab/neo-gui-nel

 

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

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

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

发布合约


 

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

第三步、调试

调用合约


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

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

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


 

调试试运行合约


 

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


 

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

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

 

使用NEONDEBUGGUIDebug Transaction 选项卡

LoadFromFile button,打开这个0x00文件


 

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

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

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

调试交易


 

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


 

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

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

 

第四步、更多更方便

1. 只要有人upload过一次的智能合约,所有人随时都能调试时看到源码

2. 我们有一个爬虫,随时将testnet的合约的log文件上传到服务器


 

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

 

3. 未来我们将开发纯网页版的调试工具

4. 未来我们也将同步主网的数据也上传服务器


作者:李剑英


最后于 4月前 被naoye编辑 ,原因:
最新回复 (0)
全部楼主
返回