Truffle 是區(qū)塊鏈公司 ConsenSys 的一家子公司,它已經(jīng)為以太坊區(qū)塊鏈開(kāi)發(fā)了一個(gè)開(kāi)源區(qū)塊鏈開(kāi)發(fā)環(huán)境和測(cè)試框架。近日,微軟和Truffle宣布結(jié)為
Truffle 是區(qū)塊鏈公司 ConsenSys 的一家子公司,它已經(jīng)為以太坊區(qū)塊鏈開(kāi)發(fā)了一個(gè)開(kāi)源區(qū)塊鏈開(kāi)發(fā)環(huán)境和測(cè)試框架。近日,微軟和Truffle宣布結(jié)為伙伴關(guān)系,為微軟 Azure 生態(tài)系統(tǒng)引入?yún)^(qū)塊鏈開(kāi)發(fā)者工具。這兩家組織正在進(jìn)行的投資包括用于測(cè)試的本地區(qū)塊鏈節(jié)點(diǎn),并提供測(cè)試數(shù)據(jù)、智能合約的撰寫(xiě)和持續(xù)部署、調(diào)試及測(cè)試。
在使用Chainlink時(shí),強(qiáng)大的開(kāi)發(fā)工具可以幫助您的智能合約在鏈上安全地部署成功。Truffle旨在提供一個(gè)易于使用的dApp框架,以幫助開(kāi)發(fā)人員更好地開(kāi)展其dApp的開(kāi)發(fā)工作。
Truffle非常易于上手,Truffle Boxes的特點(diǎn)決定了您可以直接在終端下載dApp樣板。為了幫助您使用Chainlink,我們提供Chainlink Truffle Box樣板。其中包含了一個(gè)名為“MyContract”的的Chainlinked智能合約示例以及預(yù)制的測(cè)試套件。首先需要打開(kāi)終端并安裝Truffle。
npm install truffle -g
接下來(lái),創(chuàng)建一個(gè)新的目錄,并通過(guò)下面的命令從box中獲取Chainlinked示例合約:
mkdir Chainlink
cd Chainlink
truffle unbox smartcontractkit/chainlink
開(kāi)箱之后,您會(huì)發(fā)現(xiàn)有一些新目錄會(huì)自動(dòng)創(chuàng)建。其中包含了很多非常有用的示例代碼,可以幫助您快速開(kāi)始Chainlinked智能合約的開(kāi)發(fā)。
本文我們主要會(huì)介紹“MyContract”合約,代碼文件可以在*contracts*目錄下找到。其中包含了一些基本的Chainlink功能,可以幫助我們深入理解Chainlinked合約是如何工作的。
## 測(cè)試
首先,測(cè)試合約以確保其一切正常。您可以通過(guò)以下命令執(zhí)行此操作:
npm test
這將在樣本合約上運(yùn)行各種測(cè)試用例,例如創(chuàng)建帶有和不帶LINK代幣的請(qǐng)求,將這些請(qǐng)求發(fā)送到oracle合同地址以及測(cè)試合同所有權(quán)。
*注意:你可能會(huì)遇到一些LINK代幣合約的各種編譯警告,這是因?yàn)槲覀冇玫氖亲钚碌腟olidity編譯器版本,而不是合約創(chuàng)建時(shí)候的編譯器版本,因此我們可以忽略這些警告。LINK代幣合約已經(jīng)部署,我們只是想這些合約提供給本地測(cè)試。
*需要注意的是,每次運(yùn)行測(cè)試之后,我們都重新部署了每一個(gè)合約。這是為了我們可以進(jìn)行真正的單元測(cè)試, 我們不想我們的測(cè)試依賴(lài)于其他測(cè)試的輸出。另外,重新部署每個(gè)合約需要時(shí)間,但這僅用于測(cè)試目的,不會(huì)影響我們的實(shí)際性能運(yùn)行時(shí)間。
現(xiàn)在讓我們來(lái)看一下“MyContract”的這些測(cè)試用例的更多細(xì)節(jié),您可以在*test/MyContract_test.js*下找到。如果您之前使用過(guò)Mocha.js,您會(huì)發(fā)現(xiàn)語(yǔ)法很熟悉。Truffle基于Mocha測(cè)試框架,具有智能合約的特有功能。讓我們來(lái)看看其中的一些新功能。
定義MyContract合約所使用的變量。注意其中jobId值是演示所用的占位符,不是真正可用的JobId。您可以在這里找到真正可用的JobId。
contract()函數(shù)的功能和Mocha中describe()函數(shù)實(shí)現(xiàn)的功能類(lèi)似,但它結(jié)合了Truffle中的clean-room-feature。在Truffle的文檔中這樣解釋?zhuān)?/p>
- 在每個(gè)contract()函數(shù)運(yùn)行之前,您的合約將重新部署到以太坊網(wǎng)絡(luò),其中的測(cè)試以原始的合約狀態(tài)運(yùn)行。
- contract()函數(shù)提供了可以用來(lái)編寫(xiě)測(cè)試的可用帳戶(hù)列表。
此外,我們的示例“MyContract”需要來(lái)自其他智能合約的輸出。為此,我們將使用artifacts.require()方法,該方法實(shí)質(zhì)上將特定智能合約的輸出作為合同抽象導(dǎo)入。此數(shù)據(jù)存儲(chǔ)為T(mén)ruffle可以使用的JSON 二進(jìn)制對(duì)象查看到。閱讀更多有關(guān)artifacts.require()如何在這里工作的信息。
助手合約存儲(chǔ)為常量引用,現(xiàn)在我們可以開(kāi)始創(chuàng)建測(cè)試用例。為此,我們需要正確理解關(guān)鍵的測(cè)試方法,例如*describe(),beforeEach(),it()和context()*。
- *describe()* 允許我們將測(cè)試用例組合在一起。它需要兩個(gè)參數(shù),第一個(gè)是我們的測(cè)試組名稱(chēng)的字符串,第二個(gè)是回調(diào)函數(shù)。這個(gè)方法涉及的測(cè)試用例是創(chuàng)建請(qǐng)求,完成請(qǐng)求,取消請(qǐng)求以及取回LINK。
- *beforeEach()*在每個(gè)單獨(dú)的測(cè)試范圍之前運(yùn)行。對(duì)于許多測(cè)試來(lái)說(shuō),在運(yùn)行測(cè)試用例之前,必須首先執(zhí)行一些操作(例如等待鏈LINK的轉(zhuǎn)賬)。
- *it()*用于單個(gè)測(cè)試用例。這些用于測(cè)試我們?cè)诓煌瑺顟B(tài)下的合約以及明確他們想要完成的任務(wù)。你會(huì)注意到當(dāng)我們運(yùn)行npm test時(shí),每個(gè)*it()函數(shù)*的參數(shù)中的字符串都會(huì)輸出為日志,這有助于我們清楚地看到我們的測(cè)試時(shí)間線(xiàn)。
- *context()*是*describe()*的別名,但是用于合同執(zhí)行的更具體的狀態(tài)。換言之,它提供了另一種更容易閱讀和更有條理的測(cè)試方法。
## 寫(xiě)在最后
Truffle提供了一個(gè)功能強(qiáng)大的工具箱,可幫助您的Chainlinked智能合約正確的運(yùn)行。得益于Mocha.js這樣的流行的且文檔豐富的世界級(jí)測(cè)試框架,開(kāi)發(fā)人員會(huì)非常容易的實(shí)現(xiàn)相關(guān)的開(kāi)發(fā)工作。使用Truffle boxes,dApp公司能夠輕松地為其開(kāi)發(fā)人員提供有用的示例,幫助發(fā)展區(qū)塊鏈生態(tài)系統(tǒng)。(Chainlink)
關(guān)鍵詞: Truffle dApp框架 Chainlinked