OpenZeppelin Upgrades 教程 : 在 Hardhat 下如何进行合约升级

译文出自:登链翻译计划

译者:翻译小组

校对:Tiny熊

使用OpenZeppelinUpgrades插件部署的智能合约可以被升级,可以在保留其地址、状态和余额下,修改其合约代码,同时。这允许你迭代地将新功能添加到项目中,或修复你在生产中可能发现的任何错误。

在本教程中,我们将展示使用OpenZeppelinHardhatUpgrades和GnosisSafe多签钱包,进行合约创建、测试和部署,以及使用GnosisSafe多签升级,教程包含以下内容:

创建一个可升级的合约

在本地测试该合约

将合约部署到公共网络上

将升级的控制权转移到Gnosis多签账号中

创建新的实现版本

在本地测试升级

部署新的实现

升级合约

设置环境

我们将首先创建一个新的npm项目。

mkdirmycontract&&cdmycontractnpminit-y

我们将安装Hardhat。运行Hardhat时,选择创建一个空的hardhat

//Readsthelaststoredvaluefunctionretrieve()publicviewreturns(uint256){returnvalue;}}

在本地测试合约

记得应该始终适当地测试我们编写的合约。为了测试可升级的合约,我们应该为实现合约创建单元测试,同时创建更高级别的测试,以测试通过代理的交互。

我们在测试中使用chaiexpect,所以也需要安装以下:

npminstall--save-devchai

我们将为实现合约创建单元测试。在项目根目录下创建一个test目录,然后在test目录下创建Box

);//Testcaseit('retrievereturnsavaluepreviouslystored',asyncfunction(){//Storeavalueawaitbox

);});

我们还可以创建通过代理进行交互的测试。注意:我们不需要在这里重复我们的单元测试,这是为了测试代理交互和测试升级。

在你的test目录下使用以下JavaScript创建Box

);//Testcaseit('retrievereturnsavaluepreviouslyinitialized',asyncfunction(){//Testifthereturnedvalueisthesameone//Notethatweneedtousestringstocomparethe256bitintegersexpect((awaitbox

);});

然后我们可以运行测试:

$npxhardhattestDownloadingcompiler0

main()

);

我们通常会先将合约部署到本地测试,然后手动与之交互。为了节省时间,将跳过直接部署到公共测试网络。

去中心化社交协议Follow正式发布:据官方消息,2021年9月22日,为Web3.0设计的去中心化社交协议Follow正式发布。同时,基于Follow协议专注NFT社交的Follow.top正式上线。Follow是一个基于区块链的去中心化社交协议,通过提供完整的基础开发工具和标准的智能合约接口,任何个人或组织都可以基于协议构建应用,基于Follow构建的任何应用,用户既可以完全拥有自己的社交身份和数据,也可以像构建DeFi乐高一样将各种应用进行互通和组合,形成一个去中心化的、混合分层的、具有自治经济系统的SocialFi网络。

Follow是聚焦于NFT的去中心化社交平台,也是基于Follow协议的首款社交产品,目标是构建元宇宙中数字艺术创作平台和分享平台。[2021/9/22 16:57:07]

在本教程中,将部署到Rinkeby网络。如果你在配置方面需要帮助,请参阅连接到公共测试网络和Hardhat:部署到真实网络。注意:任何如助记符或AlchemyAPI密钥都不应提交到版本控制中。

我们将使用以下hardhat

main()

);

我们可以在Rinkeby网络上运行转移:

$npxhardhatrun--networkrinkebyscripts/transfer_ownership

//Readsthelaststoredvaluefunctionretrieve()publicviewreturns(uint256){returnvalue;}//Incrementsthestoredvalueby1functionincrement()public{value=value1;emitValueChanged(value);}}

声音 | 金丘区块链研究院院长:区块链的价值是其在去中心化需求下的唯一可用性:今日,某互联网资讯博主在微博发布一聊天记录,聊天记录中,金丘区块链研究院院长洪蜀宁表示,区块链是一种非常糟糕的技术,但在去中心化需求下,它是目前唯一可用的,这才是区块链的价值。 ????中本聪是为了实现去中心化的货币,才发明了区块链技术。不是为了使用区块链,才要发明比特币的。[2018/9/27]

在本地测试升级

为了测试我们的升级,我们应该为新的实现合约创建单元测试,同时创建更高级别的测试,以测试通过代理进行的交互,检查状态是否在不同版本的升级中得到维护......

我们将为新的实现合约创建单元测试。我们可以添加到我们已经创建的单元测试中,以确保高覆盖率。在你的test目录下使用以下JavaScript创建BoxV2

);//Testcaseit('retrievereturnsavaluepreviouslystored',asyncfunction(){//StoreavalueawaitboxV2

);//Testcaseit('retrievereturnsavaluepreviouslyincremented',asyncfunction(){//IncrementawaitboxV2

);});

还可以创建升级后通过代理进行交互的测试。注意:我们不需要在这里重复单元测试,仅测试代理交互和测试升级后的状态。

在你的test目录下创建BoxV2

);//Testcaseit('retrievereturnsavaluepreviouslyincremented',asyncfunction(){//IncrementawaitboxV2

);});

然后我们可以运行我们的测试。

$npxhardhattestCompiling1filewith0

main()

);

我们可以在Rinkeby网络上运行迁移,部署新的实现:

$npxhardhatrun--networkrinkebyscripts/prepare_upgrade.jsPreparingupgrade...BoxV2at:0xE8f000B7ef04B7BfEa0a84e696f1b792aC526700

升级合约

为了在GnosisSafe中管理升级,使用OpenZeppelin应用。

首先,我们需要代理的地址和新实现的地址。我们可以从我们运行deploy.js和prepare_upgrade.js脚本时的输出中得到这些。

在Apps标签中,选择OpenZeppelin应用程序,在合约地址栏中粘贴代理的地址,并在新实现地址栏中粘贴新实现的地址。

该应用程序应该显示合约是EIP1967兼容的。

GnosisSafeOpenZeppelinUpgrade

仔细检查这些地址,然后按下升级按钮。我们将看到一个确认对话框,提交交易。

GnosisSafeOpenZeppelinUpgradeConfirm

然后,需要在MetaMask中签署该交易。

现在可以与升级后的合约进行交互。需要使用代理的地址与BoxV2交互。注意:BoxV2.attach(PROXYADDRESS)获取我们代理合约的地址。

然后,我们可以调用新的increment函数,可以观察到整个升级过程中状态保持了一致:

$npxhardhatconsole--networkrinkeby>constBoxV2=awaitethers.getContractFactory("BoxV2")undefined>constboxV2=awaitBoxV2.attach("0xFF60fd044dDed0E40B813DC7CE11Bed2CCEa501F")undefined>(awaitboxV2.retrieve()).toString()'42'>awaitboxV2.increment(){hash:...>(awaitboxV2.retrieve()).toString()'43'

接下来

我们已经创建了一个可升级的合约,将升级的控制权转移到Gnosis多签,并升级了合约。同样的过程也可以在主网上进行。注意:我们应该首先在公共测试网中测试升级。

我们也可以使用OpenZeppelinDefender管理升级,参考:https://docs.openzeppelin.com/defender/admin#upgrades

本翻译由CellETF赞助支持。

来源:https://forum.openzeppelin.com/t/openzeppelin-upgrades-step-by-step-tutorial-for-hardhat/3580

参考资料

登链翻译计划:https://github.com/lbc-team/Pioneer

翻译小组:https://learnblockchain.cn/people/412

Tiny熊:https://learnblockchain.cn/people/15

GnosisSafe:https://learnblockchain.cn/article/2980

Hardhat:https://learnblockchain.cn/docs/hardhat/getting-started/

OpenZeppelin学习教程:https://docs.openzeppelin.com/learn/developing-smart-contracts#setting-up-a-solidity-project

initialize函数而不是构造函数:https://docs.openzeppelin.com/learn/upgrading-smart-contracts#initialization

连接到公共测试网络:https://docs.openzeppelin.com/learn/connecting-to-public-test-networks

Hardhat:部署到真实网络:https://learnblockchain.cn/docs/hardhat/tutorial/deploying-to-a-live-network.html

Rinkeby网络上为自己创建一个GnosisSafe:https://rinkeby.gnosis-safe.io/

CreateaSafeMultisig:https://help.gnosis-safe.io/en/articles/3876461-create-a-safe-multisig

升级技术的限制更多细节,可以看这里:https://docs.openzeppelin.com/learn/upgrading-smart-contracts#upgrading

https://docs.openzeppelin.com/defender/admin#upgrades:_https://docs.openzeppelin.com/defender/admin#upgrades_

CellETF:https://celletf.io/?utm_souce=learnblockchain

免责声明:作为区块链信息平台,本站所发布文章仅代表作者个人观点,与链闻ChainNews立场无关。文章内的信息、意见等均仅供参考,并非作为或被视为实际投资建议。

本文来源于非小号媒体平台:

登链社区

现已在非小号资讯平台发布105篇作品,

非小号开放平台欢迎币圈作者入驻

入驻指南:

/apply_guide/

本文网址:

/news/10404921.html

免责声明:

1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险

2.本文版权归属原作所有,仅代表作者本人观点,不代表非小号的观点或立场

上一篇:

每周编辑精选WeeklyEditors'Picks

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

大币网

[0:15ms0-5:391ms