以太坊價格 以太坊價格
Ctrl+D 以太坊價格
ads
首頁 > Fil > Info

APP:DApp:開發一條龍 測試一條蟲?

Author:

Time:1900/1/1 0:00:00

2017年,這一年有點特別,許多先進的技術和新的概念集中在這一年迸發。小程序火了、新零售火了、區塊鏈火了、人工智能火了、物聯網也火了。

它們有的是首次面世,也有的是早已默默發展了很久,等待一個契機走向大眾。

而這當中出現過一個讓人印象深刻的小插曲:

這個回答曾經在網絡上紅極一時,在開懷大笑的同時也不禁發人深思:新的技術若無法落到具體的應用場景解決問題,終究還是紙上談兵。

區塊鏈技術更是如此。雖說目前區塊鏈的一些技術瓶頸還有待突破,但開發者們應該積極去探索、多嘗試,尤其是在應用方面。其中開發DApp就是一個很好的選擇。

不得不提的是,在開發DApp時,大部分開發者都會把重心放在開發的過程中,但實際上,還有同樣值得開發者們注意的重要一環:測試。

接下來,我們就以抽獎合約為例,從抽獎合約的整個測試流程代碼來講解如何對合約與接口進行測試。

做好準備,又要開始我們的干貨時間了。

由dappOS提供支持的去中心化衍生品交易所平臺GMX試點版本即將上線:金色財經報道,由 Web3 操作系統 dappOS 提供支持的去中心化衍生品交易所平臺 GMX 試點版本即將上線,旨在降低用戶在 Arbitrum 和 Avalanche 區塊鏈上訪問 GMX DeFi 功能的門檻,簡化跨鏈 GMX 訪問流程。(雅虎財經)[2023/2/1 11:40:47]

測試準備

首先我們來看一下項目中,test目錄中文件結構,lib目錄中存放了方便測試調用的封裝函數,以base命名,而test根目錄的cctime文件包含了主要的測試用例。編寫測試用例之前,我們先熟悉一下base文件中的函數,這些函數作為測試工具提供給測試用例調用,封裝了合約和訪問接口代碼。1、初始化函數編寫測試用例之前,需要將常用的方法抽離封裝,放入base文件中,這里我們使用了supertest和chai作為主要的測試框架,大家可以在源碼文件中找到測試文件中的聲明。以下是初始化相關的函數:

我們看init方法中,對DApp的id進行了查詢,根據應用的名稱從主鏈動態獲取當前側鏈應用的ID,為后續測試接口的調用初始化DappId數據。接下來我們看一下測試常用的工具函數。2、區塊等待在發起一筆交易之后,需要等待交易確認之后再執行下一步的操作,調用sleep函數進行等待,之后繼續執行。這個函數在測試流程中會多次使用,因為10秒一個區塊的特性,很多的操作需要在區塊確認之后獲得驗證,不僅是寫操作,讀取的接口依然需要在上一次寫操作之后等待區塊確認才能獲取到最新數據。區塊等待相關函數如下所示:

Fantom發布dApp gas貨幣化計劃提案:12月1日消息,作為Fantom持續推動對建設者實施可持續貨幣化激勵措施的一部分,Fantom發布了dApp gas貨幣化計劃提案,該提案旨在降低Fantom當前的消耗率,以便將更多網絡費用直接重定向到基于Fantom構建的dApp。

如果獲得通過,此實施將把Fantom的燃燒率從20%降低到5%,并將這15%的降低重定向到gas貨幣化。這種gas貨幣化將獎勵高質量的dApp,留住有才華的創作者,并支持Fantom的網絡基礎設施。[2022/12/1 21:16:15]

3、賬戶生成與轉賬生成隨機賬戶與轉賬接口也需要測試,我們留意到了在base文件頭部定義了創世賬戶的地址和秘鑰,創世賬戶可以通過asch-js中的合約接口向新生成的賬戶轉賬,隨機賬戶有了余額就能夠繼續調用應用中的自定義合約,進行合約相關的功能測試。賬戶及轉賬相關的函數如下:

a.隨機賬戶randomSecret調用randomSecret生成隨機字符串作為賬戶秘鑰,我們可以看到AschJS.crypto.getKeys函數能夠將字符串格式的秘鑰通過非對稱加密得出一個包含公鑰和私鑰的秘鑰對,AschJS.crypto.getAddress通過公鑰算出賬戶的地址。randomSecret返回的是一個隨機生成但被截取之后的字符串。通常情況下,Asch只支持符合BIP39規范的密鑰字符,也就是我們熟悉的“助記詞”格式的密碼,但這里為了測試方便,直接使用隨機的七位字符串,同樣可以算出符合規則的公鑰,也能計算出地址。當然,隨機賬戶也支持通過指定助記詞的方式獲取公鑰與地址。b.轉賬轉賬在DApp以類型2的合約實現,所以這里的轉賬就是在調用DApp內部的合約,我們可以在giveMoney函數中看到合約調用的格式。合約參數結構如下:

動態 | 跨ETH/EOS/TRON/IOST四大公鏈 DApp活躍度排行榜:據 DAppTotal 08月12日數據顯示,過去一周,綜合對比ETH、EOS、TRON、IOST四大公鏈的DApp生態情況發現:總用戶量(個): ETH(175,080) > EOS(161,470) > TRON(71,136) > IOST(20,635);總交易次數(筆):EOS(23,265,698) > TRON(8,709,841) > IOST(917,025) > ETH(864,987);總交易額(美元):ETH(92,754,257) > TRON(92,655,771) > EOS(88,722,497) > IOST(11,882,228)。[2019/8/12]

secret為合約調用者的秘鑰,String類型。

fee為合約調用手續費,bigNumber類型。

type為合約類型,Number類型,與自定義合約數據對應。

args為合約參數,Array類型。

聲音 | 孫宇晨:就DApp數量而言Tron已超過以太坊:據coincryptorama報道,TRON創始人孫宇晨表示,就DApp數量而言,Tron已超過ETH,Tronbet的交易量已超過4.22億條。[2018/11/18]

注意:

我們看到giveMoney調用合約時請求了/transactions/unsigned接口,這個接口可以接受未簽名的參數和密鑰執行合約,這樣做在測試環境雖然沒有問題,但是在正式的生產環境中會有很大的風險,我們的私鑰內容會有被網絡劫持的風險,所以在調用合約時,盡可能避免通過網絡傳輸自己的密鑰,而是用本地簽名的方式加密參數,然后請求/transactions/signed,這點一定要十分注意。

上面的代碼通過接收簽名參數調用合約的接口,這個函數發送了命名為transaction的參數,trs是用asch-js前端JavaScript工具庫進行簽名返回的transaction對象。我們來看一個例子:

使用AschJS.dapp.createInnerTransaction將合約參數通過秘鑰secret簽名之后傳入submitInnerTransaction函數,完成合約調用。與上面giveMoney函數不同的是,createInnerTransaction返回的是通過秘鑰簽名的內容,將簽名后的數據通過網絡發送,這樣提高了整個傳輸過程秘鑰的安全性。我們來看簽名后的transaction參數是什么樣子:

聲音 | Gnosis創始人:以太坊應用情況應通過DAPP應用落地來衡量:據CCN報道,Gnosis創始人Martin Koppelmann表示,以太坊的應用情況應通過DAPP的網絡效應來衡量,而不是通過區塊鏈網絡的用戶數來衡量。對于以太坊來說,最好衡量標準不是部署了多少DAPP或DAPP有多少交易,而是有多少DAPP被創建并應用落地。[2018/8/17]

與上面未簽名調用轉賬接口的參數對比,本地簽名后得出的參數中少了secret屬性,多了signature屬性,而這個屬性把通過sha256算法得出的私鑰與整個transaction參數經過哈希計算之后得出,用于后端接口對參數驗證。其他的合約調用基本上都按照發布文章合約的結構組織參數,完成合約調用的封裝。這樣,我們就可以著手編寫測試了。合約流程測試

我們現在開始以一個發布文章、用戶打賞、結算抽獎和用戶領獎整個應用的核心流程進行測試,相關代碼如下:

首先,在測試用例before函數中初始化測試變量、DApp數據和創始賬戶信息作為后續測試函數的基礎,然后執行獲取頻道列表的測試用例。我們使用awaitbase.dappApiGetAsync('/channels')請求一個API,獲取到頻道列表信息,并用斷言庫校驗結果。下面我們對核心的業務流程進行測試,測試的思路如下:1)創建頻道。2)初始化賬戶。3)在頻道里創建包含抽獎模式的文章。4)模擬三個用戶各打賞兩筆。5)文章結算。6)獲獎用戶領獎。7)檢查各自賬戶的余額。核心業務流程的代碼如下:

上面的代碼使用受托人創建了一個新頻道,并通過頻道查詢接口通過交易ID獲取到了頻道的ID,完成了基本的測試邏輯,同時保存了channelId作為后續創建文章的數據。

注意:awaitbase.onNewBlockAsync()是在等待區塊確認之后再繼續執行。我們看到最初先給賬戶轉入10500的Token,用于創建頻道和更新頻道的消耗。打賞文章測試代碼如下:

在上面代碼中,首先進行賬戶的初始化,生成了四個賬戶,一個賬戶負責創建文章和結算獎勵,另外三個作為打賞用戶。然后對創建的文章執行兩次打賞,為了驗證方便,新創建的賬戶兩次打賞的總額為5個Token,創建文章的賬戶擁有0.2個Token,操作之后扣掉手續費保證在結算之前賬戶余額都是零,方便驗證。另外,我們為了測試需要,將后端關于區塊高度的限制暫時去掉,并設置結算區塊高度為當前的高度加2,這樣,在用戶投票之后直接執行結算。提示:測試代碼中,創建頻道或文章之后,因為需要區塊確認,所以我們沒有辦法立即獲取到數據的ID,只能先拿到transactionId,待區塊打包之后,再通過查詢接口用tid獲取實際的數據ID,再進行下一步的操作,測試文件中,會出現很多這樣的處理,這也是區塊特性所決定的。用戶打賞測試代碼如下:

上面代碼中,用另外三個賬戶對文章進行了打賞,每個賬戶打賞兩次不同的金額,但總額是5XCT,所以最終文章的抽獎池中,應該是15個XCT,結算結果根據15XCT的總額進行驗證,然后驗證文章投票額與投票者的余額是否正確,代碼如下:

合約中對抽獎模式的結算規則是受托人10%,作者30%,獲獎者60%,因為受托人的獎勵是平均分給三個賬戶,所以驗證不是那么方便,不過我們只要驗證作者和獲獎者的獎勵額就能確定結算是否正確,那么最終的結果是作者獲得4.5個XCT,抽獎人獲得9個XCT。驗證獎勵測試代碼如下:

最終,在根目錄執行npmtest,等測試運行結束,就能看到應用測試執行的結果了。

總結

上述提及的測試代碼也只是完成了核心功能驗證,并沒有完全覆蓋到每一個合約和操作場景,如果讀者感興趣可以嘗試在此基礎上補充或重構,也歡迎對項目提出改進建議。

Tags:APPDAPDAPPRAN影子去中心化交易所app下載區塊鏈dapp開發費多少錢YFIDappRANTS

Fil
LIB:港交所高調入局,原生交易所危局——區塊鏈周報0915

導讀 港交所高調宣布收購倫交所,進軍數字資產交易,雖然收購受挫,但港交所區塊鏈野心已顯,原生交易所何去何從? 摘要 專題:港交所高調入局,原生交易所危局.

1900/1/1 0:00:00
KKT:“好學生”Bakkt過考 比特幣ETF們差在哪?

文|嚯嚯編輯|文刀 還有不到兩周時間,全球首個合規比特幣期貨交易所Bakkt將正式上線。經過將近一年的“跳票”,備受關注的Bakkt總算有了“出頭之日”.

1900/1/1 0:00:00
APE:曾經風靡一時的頭部項目 現在還有機會嗎

狂人本著負責,專注,誠懇的態度用心寫每一篇分析文章,特點鮮明,不做作,不浮夸!本內容中的信息及數據來源于公開可獲得資料,力求準確可靠,但對信息的準確性及完整性不做任何保證,本內容不構成投資建議.

1900/1/1 0:00:00
HTT:關于WBFex即將上線OT的公告

尊敬的WBFex用戶:WBFex即將在開放區上線OT/USDT交易對,具體上線時間請關注官方公告.

1900/1/1 0:00:00
ZZEX Global將于9月30日15:00首發上線Star block chain(STBC)

尊敬的用戶: ZZEX交易所將于2019年9月30日15:00首發上線Starblockchain(STBC),支持STBC/USDT交易對.

1900/1/1 0:00:00
API:視頻| 本體技術視點 | Python智能合約教程之原生合約調用

01導語 上一期我們介紹了本體Python智能合約的合約執行API,本期我們將討論如何通過NativeAPI來進行本體原生合約調用.

1900/1/1 0:00:00
ads