2017年,這一年有點特別,許多先進的技術和新的概念集中在這一年迸發。小程序火了、新零售火了、區塊鏈火了、人工智能火了、物聯網也火了。
它們有的是首次面世,也有的是早已默默發展了很久,等待一個契機走向大眾。
而這當中出現過一個讓人印象深刻的小插曲:
這個回答曾經在網絡上紅極一時,在開懷大笑的同時也不禁發人深思:新的技術若無法落到具體的應用場景解決問題,終究還是紙上談兵。
區塊鏈技術更是如此。雖說目前區塊鏈的一些技術瓶頸還有待突破,但開發者們應該積極去探索、多嘗試,尤其是在應用方面。其中開發DApp就是一個很好的選擇。
不得不提的是,在開發DApp時,大部分開發者都會把重心放在開發的過程中,但實際上,還有同樣值得開發者們注意的重要一環:測試。
接下來,我們就以抽獎合約為例,從抽獎合約的整個測試流程代碼來講解如何對合約與接口進行測試。
做好準備,又要開始我們的干貨時間了。
Connext推出Chain Abstraction,用戶可在同一界面完成跨鏈DApp交互:5月26日消息,Layer2 互操作性協議 Connext 推出 Chain Abstraction,用戶無需切換網絡或在另一條鏈上支付 Gas 費,即可在同一界面上使用任意代幣從任何支持的鏈與 DApp 進行交互。該功能可以用于將資金存入資金池或金庫、參與 LBP 或空投、支付基礎設施費用、購買 NFT 或 POAP、在 LST 協議中質押 ETH。此外,Connext 還發布 Chain Abstraction Tookit,幫助開發者集成該功能,該工具包包括一套經過審計的智能合約模塊,以及即將推出的預構建的 UI 組件。[2023/5/26 9:44:40]
測試準備
首先我們來看一下項目中,test目錄中文件結構,lib目錄中存放了方便測試調用的封裝函數,以base命名,而test根目錄的cctime文件包含了主要的測試用例。編寫測試用例之前,我們先熟悉一下base文件中的函數,這些函數作為測試工具提供給測試用例調用,封裝了合約和訪問接口代碼。1、初始化函數編寫測試用例之前,需要將常用的方法抽離封裝,放入base文件中,這里我們使用了supertest和chai作為主要的測試框架,大家可以在源碼文件中找到測試文件中的聲明。以下是初始化相關的函數:
DFINITY基金會開源網絡神經系統前端Dapp:據官方消息,DFINITY基金會的研發團隊宣布,網絡神經系統(Network Nervous System,NNS)前端Dapp現已開源。據悉,NNS前端Dapp允許用戶發送和接收ICP代幣,參與NNS治理,創建canister智能合約。[2021/9/30 17:16:17]
我們看init方法中,對DApp的id進行了查詢,根據應用的名稱從主鏈動態獲取當前側鏈應用的ID,為后續測試接口的調用初始化DappId數據。接下來我們看一下測試常用的工具函數。2、區塊等待在發起一筆交易之后,需要等待交易確認之后再執行下一步的操作,調用sleep函數進行等待,之后繼續執行。這個函數在測試流程中會多次使用,因為10秒一個區塊的特性,很多的操作需要在區塊確認之后獲得驗證,不僅是寫操作,讀取的接口依然需要在上一次寫操作之后等待區塊確認才能獲取到最新數據。區塊等待相關函數如下所示:
3、賬戶生成與轉賬生成隨機賬戶與轉賬接口也需要測試,我們留意到了在base文件頭部定義了創世賬戶的地址和秘鑰,創世賬戶可以通過asch-js中的合約接口向新生成的賬戶轉賬,隨機賬戶有了余額就能夠繼續調用應用中的自定義合約,進行合約相關的功能測試。賬戶及轉賬相關的函數如下:
Plasm CEO創太:開發人員在Plasm網絡上構建Dapp不必考慮其可擴展性:據官方消息,幣贏CoinW《共識52》第十期《Polkadot的進化之路——解開波卡Dapp平臺Plasm的神秘代碼》AMA主題中Sota創太表示,Plasm Network是Polkadot上的一個可擴展的Dapp平臺,致力于為所有的layer2協議提供解決方案。Polkadot中繼鏈在設計上不支持智能合約功能, 但是所有DApp開發人員都必須選擇一個智能合約平行鏈。可擴展性是我們所面臨的最基本的問題。 這就是為什么我們專注于Layer2解決方案的原因。
我們已經獲得了Web3 基金的資助,并且Plasm正在實現Optimistic虛擬機OVM,為所有Layer2服務。最近,我們從Web3 Foundnation獲得了另一筆資助,并開始展開ZK Rollup的工作,并將于明年上線!波卡卡槽拍賣期間,可以通過將DOT鎖定在我們的平行鏈插槽上來獲取PLM。[2020/11/26 22:14:52]
a.隨機賬戶randomSecret調用randomSecret生成隨機字符串作為賬戶秘鑰,我們可以看到AschJS.crypto.getKeys函數能夠將字符串格式的秘鑰通過非對稱加密得出一個包含公鑰和私鑰的秘鑰對,AschJS.crypto.getAddress通過公鑰算出賬戶的地址。randomSecret返回的是一個隨機生成但被截取之后的字符串。通常情況下,Asch只支持符合BIP39規范的密鑰字符,也就是我們熟悉的“助記詞”格式的密碼,但這里為了測試方便,直接使用隨機的七位字符串,同樣可以算出符合規則的公鑰,也能計算出地址。當然,隨機賬戶也支持通過指定助記詞的方式獲取公鑰與地址。b.轉賬轉賬在DApp以類型2的合約實現,所以這里的轉賬就是在調用DApp內部的合約,我們可以在giveMoney函數中看到合約調用的格式。合約參數結構如下:
動態 | 好萊塢演員Danny Trejo開通BSV DApp Twetch頻道:好萊塢演員DannyTrejo在Twitter上宣布,他已經開通了鏈上“推特”——Twetch頻道,并擁有了一個官方MoneyButton錢包地址。注:Twetch是由BSV開發的DApp。DannyTrejo常于電影中飾演高度男性化、反派或反英雄類型的角色。較著名的作品如《亡命之徒》、《盜火線》和《空中監獄》。[2020/2/13]
secret為合約調用者的秘鑰,String類型。
fee為合約調用手續費,bigNumber類型。
type為合約類型,Number類型,與自定義合約數據對應。
args為合約參數,Array類型。
注意:
我們看到giveMoney調用合約時請求了/transactions/unsigned接口,這個接口可以接受未簽名的參數和密鑰執行合約,這樣做在測試環境雖然沒有問題,但是在正式的生產環境中會有很大的風險,我們的私鑰內容會有被網絡劫持的風險,所以在調用合約時,盡可能避免通過網絡傳輸自己的密鑰,而是用本地簽名的方式加密參數,然后請求/transactions/signed,這點一定要十分注意。
公告 | 昨日EOS/ETH/TRON?僅10款Dapp新增用戶大于100:據RatingDapp和RatingToken大數據監測顯示,昨日,EOS/ETH/TRON三大主流公鏈平臺Dapps交易筆數大于零的Dapp款數分別為ETH(252)>EOS(218)>TRON(151);交易筆數大于10000的Dapp總計51款,其中類占58.82%。從新增用戶來看,昨日三條公鏈Dapp新增用戶大于100共計10款,環比上周同期下降60%,新增用戶TOP3 Dapp分別為Proethers(2508)、IDEX(529)、LIMITLESS(503)。[2019/5/23]
上面的代碼通過接收簽名參數調用合約的接口,這個函數發送了命名為transaction的參數,trs是用asch-js前端JavaScript工具庫進行簽名返回的transaction對象。我們來看一個例子:
使用AschJS.dapp.createInnerTransaction將合約參數通過秘鑰secret簽名之后傳入submitInnerTransaction函數,完成合約調用。與上面giveMoney函數不同的是,createInnerTransaction返回的是通過秘鑰簽名的內容,將簽名后的數據通過網絡發送,這樣提高了整個傳輸過程秘鑰的安全性。我們來看簽名后的transaction參數是什么樣子:
與上面未簽名調用轉賬接口的參數對比,本地簽名后得出的參數中少了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,等測試運行結束,就能看到應用測試執行的結果了。
總結
上述提及的測試代碼也只是完成了核心功能驗證,并沒有完全覆蓋到每一個合約和操作場景,如果讀者感興趣可以嘗試在此基礎上補充或重構,也歡迎對項目提出改進建議。
尊敬的WBFex用戶:經與TEP項目方協商,將延遲提幣時間,具體提幣時間為:9月9日14:00TEP項目介紹:Tepleton,基于底層跨鏈技術的區塊鏈新金融解決方案.
1900/1/1 0:00:00?公告編號:2019091601各位關心ZBG.COM的項目方和投資者們:為了給用戶提供更加安全、穩定、快速的網絡訪問服務,ZBG平臺近期已完成對網絡環境的優化.
1900/1/1 0:00:00最近ETH接力EOS上漲,走勢強于其他主流幣,日線方面ETH前期下降三角突破后,這幾天一直處于緩步上升趨勢,上方受制于日線MA60均線壓制,4小時均線多頭排列,日線MACD快慢線向上發散.
1900/1/1 0:00:00打開我們日常使用的購物網站,比如某寶或京東,早教類的書的比重越來越大,這些早教類的書籍中,要么就是圖畫書,要么就是各種識字書.
1900/1/1 0:00:00人生復利的東西很多,讀書,金錢,能力,健康。有人認為人生就是一場馬拉松,一路上不斷有人因為各種原因掉隊,因為很多人沒有準備這么長的時間,這么長的距離.
1900/1/1 0:00:00幣圈大V趙東發布微博說,熊市可能將要接近尾聲了。在討論這個問題之前,先從不同方面進行一下8月回顧,從細節處體會行業發展,或可有助于做出更準確的判斷。這個夏天市場繼續走低.
1900/1/1 0:00:00