以太坊交易所 以太坊交易所
Ctrl+D 以太坊交易所
ads
首頁 > OKB > Info

DApp:開發一條龍 測試一條蟲?_DAPP:DAP

Author:

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

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

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

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

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

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

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

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

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

Delphi Labs推出可將Cosmos錢包集成至多鏈DApp的開源軟件包:金色財經報道,Delphi Labs宣布推出可將Cosmos錢包集成至多鏈DApp的開源軟件包Shuttle。Delphi Labs表示,Shuttle可以讓開發者專注于核心DApp邏輯,而不是集成新的錢包或鏈。[2022/11/18 13:21:23]

測試準備

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

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

DappRader銷售額排行榜出現一筆價值2.28億美元的NFT交易:8月17日消息,DappRader銷售額排行榜出現一筆價值2.28億美元的NFT交易,根據數據顯示,這筆交易時間發生在六個月前,交易價格為13.9萬枚WETH,價值約合2.28673億美元,交易地址為:0xa7ddb62accf9db428ae4c095d8fdb5d721197a6e。不過,進入該地址信息頁面后顯示相關錢包中未檢測到NFT,因此有可能是DappRader平臺出現數據錯誤。此前DappRader平臺統計的最高交易額NFT是CryptoPunk #7804,該NFT的交易價格為756.1萬美元。[2021/8/17 22:19:57]

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

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

聲音 | 幣印創始人潘志彪:Dapp從來沒起過規模:2月22日19點,幣信圈內人第一期開啟。本次圈內人的主題為「每次減半都在的人聊減半」。對話中,幣印創始人潘志彪提到:“Dapp從來沒起過規模,似乎涼涼了;Defi有幾個優點:抵押式去中心化的穩定幣;并且抵押物相對安全,鎖在智能合約里;缺點:報價需要預言機輸入,你得相信預言機合約;金融類的合約代碼復雜,一旦出問題,可能風險也不小。”[2020/2/22]

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

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

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

args為合約參數,Array類型。

注意:

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

動態 | 以太坊上活躍DApp數量達1400個 超EOS兩倍有余:據DappCatlog統計,截止目前,在以太坊上活躍的DApp數量為1400個,超EOS兩倍有余。其24小時交易額為25423.2556個ETH,24小時交易比數為64603,DApp智能合約為4895個,在EOS上活躍的DApp數量為403個,其24小時交易額為2419802.3266個EOS,24小時交易筆數為3644727,DApp智能合約為697個。[2019/3/28]

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

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

動態 | DApp開發者Level K發現以太坊網絡中存在GasToken漏洞:2018年11月23日星期三,Level K在其官方媒體渠道上發布了關于Ethereum的新爆料。這份簡短的報告是警告說,以太坊網絡有一個潛在的協議漏洞,黑客很容易利用這個漏洞來傷害用戶。[2018/11/24]

與上面未簽名調用轉賬接口的參數對比,本地簽名后得出的參數中少了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:DAPAPPDAPPRANYFIDapp趣幣是什么陪聊app里的Dapper LabsCRANE幣

OKB
Bitfinex 比特幣多頭數量遠遠超過空頭數量_BIT:INE

今年夏天,Bitfinex上做空比特幣的金額大幅下降。但更有意思的是,從Bitfinex上保證金空頭總量看,幾個月來空頭持倉量仍未回到之前的水平.

1900/1/1 0:00:00
獨家現場| 確認公信寶被查封 李笑來疑似微博回應_TOK:NFT

9月11日,據傳,公信寶主體運營公司杭州存信數據科技有限公司被杭州市局西湖分局古蕩派出所查封.

1900/1/1 0:00:00
BiKi平臺關于首發上線SEL的公告(0916)_BIKI:TPS

尊敬的用戶:BiKi平臺即將開放SEL的充值、提現,并開放SEL/USDT交易對,具體時間如下:1、開放充值時間:9月19日12:00;2、開放提現時間:9月19日12:00;3、開放交易時間:.

1900/1/1 0:00:00
ChainUP:用兩年時間打造最強勁的區塊鏈交易系統_CHA:Blockchain Cuties Universe

2年,從0到服務全球300多家客戶,業務遍及20多個國家,市場占有率達20%,業務數據年平均100%增長。如果這是一個互聯網的創業公司,2年能交出這樣的成績單也實屬不易.

1900/1/1 0:00:00
Tagomi推出新交易工具 賣空加密貨幣更容易_BOOK:BitBook

據彭博社報道,加密經濟和交易平臺Tagomi推出新交易工具使賣空比特幣、以太坊等操作更加容易。據報道,想要賣空加密資產,交易者目前必須“召集大量經紀人和交易柜臺以找到最優惠的借款利率,并冒著在交.

1900/1/1 0:00:00
歐洲央行:Libra等穩定幣未經過大規模測試 將帶來嚴重風險_加密貨幣:LIBRA

據路透社報道,歐洲中央銀行的BenoitCoeure對Libra等“穩定幣”的風險提出了警告。作為歐洲央行的董事會成員,Coeure在巴塞爾國際清算銀行的活動中告訴來自全球的央行官員,這些新的虛.

1900/1/1 0:00:00
ads