比特幣交易所 比特幣交易所
Ctrl+D 比特幣交易所
ads
首頁 > MEXC > Info

Rust智能合約養成日記(2)_ONT

Author:

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

智能合約養成日記合約狀態數據定義與方法實現

在上一期BlockSec針對Rust智能合約開發的文章中,我們介紹了如何為合約StatusMessage定義合約狀態,并為該合約實現了不同的方法。本期我們將繼續基于該合約展開敘述,詳細介紹編寫單元測試用例的方法,并在本地進行合約的測試。

1.準備單元測試環境

為編寫單元測試,首先我們需要在src/lib.rs中加入如下代碼,對單元測試進行環境設置:

1?#2?#3?mod?tests?{4????use?super::*;5????use?near_sdk::MockedBlockchain;6????use?near_sdk::{testing_env,?VMContext};78???...9}

在上述代碼的第1-3行中,我們為StatusMessage添加了tests子模塊(使用mod關鍵字聲明該新模塊),并在該模塊的代碼片段之前標注了cfg屬性宏#。此外,由于Rust的本地單元測試無需獲得Wasm代碼,因此可為該測試模塊配置Rust編譯條件#。

代碼第4-6行從near_sdk中導入了合約測試環境的相關依賴項。具體觀察代碼的每一行中,use關鍵詞的用法類似于python語言代碼在導入其他所依賴的模塊時所使用的import。use聲明可創建一個或多個與其他路徑同義的局部名稱綁定,即通常可使用use關鍵詞來聲明引用模塊項所需的路徑,且這些聲明通常可能出現在Rust模塊或代碼塊的頂部。

Prime Trust母公司在TerraUSD投資中損失800萬美元:金色財經報道,加密貨幣托管商Prime Trust的母公司目前正參與美國破產法第11章破產程序,該公司報告稱,通過TerraUSD投資損失了約800萬美元的資金。

在8月24日向特拉華州美國破產法院提交的文件中,Prime Core Technologies報告稱,在先前的管理下,該公司通過TerraUSD (USTC) 投資損失了600萬美元的客戶資金和200萬美元的財務資金,大概是在TerraUSD算法穩定幣于2022年5月崩盤時。該公司稱,這項投資以及2022年10月和11月支出的增加是其走向破產的原因之一。

6月份的一份文件顯示,Prime Trust欠其客戶超過8500萬美元的法定貨幣和6950萬美元的加密貨幣。據報道,該公司僅持有約290萬美元的法定貨幣和6860萬美元的加密貨幣。[2023/8/25 10:40:47]

在第4行中,super關鍵字可用于從當前模塊訪問父模塊StatusMessage,使得能夠訪問父模塊中所定義的功能與方法,如之前我們為StatusMessage合約所定義的方法函數set_status與get_status。第5行使用use關鍵詞引用了nearsdk所提供的模擬區塊鏈MockedBlockchain支持模塊,可用于智能合約的測試。第6行則從nearsdk引入了合約測試執行的環境,以及有關測試環境上下文信息格式的支持。

在導入支持NEAR智能合約單元測試所需的外部依賴模塊后,我們還需要在測試模塊中定義如下函數get_context(),用于配置并返回測試環境中所需使用的上下文信息:VMContext。

加密貨幣托管機構Aegis Trust推出NFT保險服務:金色財經報道,加密貨幣托管機構Aegis Trust推出 NFT 保險服務,將為機構投資者、對沖基金和交易所持有的代幣化資產提供高達 2500 萬美元的保險。Aegis Trust 首席執行官 Serra Wei 表示,Aegis Digital Vault 平臺為機構托管提供了符合監管要求的解決方案,其新的 NFT 保險則進一步提高了安全性。(coindesk)[2022/11/23 8:01:36]

1????fn?get_default_context(view_call:?bool)?->?VMContext?{2??????VMContext?{3????????current_account_id:?"alice_near".to_string(),4????????signer_account_id:?"bob_near".to_string(),5????????signer_account_pk:?vec!,6????????predecessor_account_id:?"carol_near".to_string(),7????????input:?vec!,8????????block_index:?0,9????????block_timestamp:?0,10???????account_balance:?0,11???????account_locked_balance:?0,12???????storage_usage:?0,13???????attached_deposit:?0,14???????prepaid_gas:?10u64.pow(18),15???????random_seed:?vec!,16???????is_view:?view_call,17???????output_data_receivers:?vec!,18???????epoch_height:?0,19????}20??}

加密基礎設施公司Prime Trust完成1.07億美元B輪融資:6月22日消息,加密基礎設施公司 Prime Trust 宣布完成 1.07 億美元 B 輪融資,具體融資信息暫未透露。本輪融資資金將用于擴大其產品類別,包括加密退休金產品和資產 Token 化產品。

此前消息,Prime Trust 于 2021 年 7 月宣布完成 6400 萬美元 A 輪融資,該輪融資由 Mercato Partners 的成長型股票基金 Traverse 領投,Samsung Next、Kraken Ventures,以及 Seven Peaks Ventures 等參投。[2022/6/22 1:24:33]

VMContext設定了多個模擬的,合約用戶賬戶信息,以及包括區塊高度,區塊時間戳,合約存儲用量等在內的區塊鏈底層相關的上下文配置信息。

下面首先對VMContext中幾處關鍵的屬性配置加以說明:

current_account_id:執行當前合約的帳戶。signer_account_id:觸發當前合約函數調用執行的交易簽名者。所有的合約調用都是某個交易的結果,且該交易由某個帳戶使用其訪問密鑰(AccessKey)簽署,該賬戶即為signer_account_id。signer_account_pk:交易簽名者所使用的AccessKey公鑰(PublicKey)。predecessor_account_id:當合約的執行屬于跨合約調用或回調時,該屬性指代了該調用的發起者帳戶。而當進行單一的合約內部函數調用時,該值將與signer_account_id一致。prepaid_gas:在區塊鏈中執行合約時存在一個特點,即用戶需要支付一定的交易執行費用(gasfee)。這里的prepaid_gas設定了可供當前交易合約函數調用時所能扣除的Gas最大值,并附加到當前的合約調用中。is_view:該參數is_view(類型為bool)可設置合約函數的調用能否對合約的狀態數據進行修改。若該值為ture,則合約函數執行時,合約的狀態數據是只讀的。反之如果該值為false,則合約的執行環境將允許對合約數據進行修改。VMContext中其余屬性的內容和用法將在后續的文章中詳細展開描述。

TrustBase爾爾:宏觀角度來說,牛市會持續很久,從微觀角度來講,做好生態永遠都是牛市:在4月12日舉辦的《佟掌柜的海外朋友們優質海外項目分享》會上,TrustBase中國區負責人爾爾表示,對長久的項目而言沒有牛熊市之分,做好產品,服務好客戶,做好生態,則是永遠的牛市。投機者看到牛市只是掙快錢,對于長期持有者或者共識者來講,他們看重的是底層技術和生態規劃,沒有技術就沒有生態,我們其實是基于原生元語言包建立起整個生態,不管技術生態還是開發者生態,或是社區生態,以及后期的模型生態,都是基于技術產生的,兩者相輔相成。

關于細分賽道的展望,第一是NFT,Trustbase平臺會推行大家第一批在實現NFT商業落地,因為開發周期足夠短,另外可以產生更多的流量,畢竟金融型用戶比應用型用戶少很多,所以能讓NFT創造更多商業價值,趁著波卡在NFT上發行是我們比較看好的賽道。第二是DeFi,這是不會衰退的賽道,金融本身是區塊鏈的核心根本,DeFi的發展是隨著區塊鏈在不斷地起伏,但永遠不會衰落,這是作為區塊鏈從業者的信仰。

Trustbase底層是波卡原生元,具有扎實底層技術的項目來講生態規劃比較長遠,相對來說不懼牛熊,主要是基于未來的生態和規劃。[2021/4/13 20:14:00]

當執行NEAR合約時,程序可配合一些NEARSDK所提供的相關API讀取這些已設置的上下文信息。例如:

near_sdk::env::current_account_id()near_sdk::env::predecessor_account_id()near_sdk::env::signer_account_pk()near_sdk::env::input()near_sdk::env::predecessor_account_id()

美國法官稱加密騙局經營者John Michael Caruso必須繼續被拘留:根據法官Michelle H Burns 4月8日簽署的命令,欺詐性加密貨幣計劃Zima Digital Assets運營者John Michael Caruso關于重啟拘留聽證會的緊急動議被駁回。法院認為,被告沒有提供新的資料可以改變先前關于他應被拘留候審的裁決。

根據5月13日簽署的命令,法官John Tuchi同意此前的裁決,即Caruso必須繼續被拘留。新提供的任何信息都與法院權衡第3142(f)條所要求的內容無關,也不影響任何釋放條件是否能合理地確保Caruso今后出庭。COVID-19的影響與這個問題毫無關系。換言之,如果Burns法官至少以壓倒性優勢認定被告存在無法解決的逃跑風險,則疾病的出現及其對被告的潛在影響不會改變該風險或解決該風險的能力。(Financefeeds)[2020/5/14]

上述API均可返回上下文具體屬性的值,這些API可以使用前文所述的use聲明導入。

在定義完函數get_context()后,我們便可以在test模塊中逐個地編寫單元測試的內容了。

2.單元測試一

如下是單元測試1的代碼片段:

1???#2???fn?set_get_message(){3?????let?context?=?get_default_context(false);4?????testing_env!(context);5?????letmut?contract?=?StatusMessage::default();6?????contract.set_status("hello".to_string());7?????assert_eq!(8???????"hello".to_string(),9???????contract.get_status("bob_near".to_string()).unwrap()10????);11??}

現在我們對測試用例的具體寫法展開描述:

上述代碼片段的第1行,我們為該單元測試函數標注了#宏,表明這是該單元測試的起點。緊接著第2行,便是該單元測試函數set_get_message()的聲明。

代碼的3-10行即該單元測試函數內部的主要測試邏輯,其中的代碼實現首先將調用前面所定義的get_context初始化一個測試環境中所使用的上下文context。此外值得一提的是,由于本單元測試需要向合約的狀態數據中寫入數據,因此需要為get_context設置參數,將前文所述VMContext中的is_view屬性設置為false,否則單元測試內部將引發panic導致測試無法通過。

在設置得到一個合理的合約執行上下文后,代碼的第4行將利用該上下文VMContext,使用testing_env!宏初始化一個用于智能合約交互的MockedBlockchain實例。代碼的第5行將調用父模塊中定義的StatusMessage::default()生成初始化后的合約對象contract。

在后續的代碼中,測試會首先調用父模塊StatusMessage所定義的set_status方法,在合約狀態數據中保存字符串"Hello"。隨后再利用get_status從合約狀態數據中讀取該條數據,并與期望所獲得內容進行對比。如果內容相互匹配,則通過該單元測試,若不匹配則會在該測試線程中觸發"assertionfailed"類型的panic。

有關單元測試中利用斷言assert進行校驗的寫法描述如下:

assert!(expression)宏可檢驗boolean值,當且僅當expression表達式所指代的內容為true時則通過檢驗;

assert_eq!(left,right)宏常用于校驗是否相等,當且僅當left和right表達式所指代的內容一致時通過校驗;

assert_ne!(left,right)宏常用于校驗是否不同,當且僅當left和right表達式所指代的內容不同時通過校驗;

3.單元測試二

如下是單元測試2的代碼片段:

1???#2???fn?get_nonexistent_message(){3?????let?context?=?get_default_context(true);4?????testing_env!(context);5?????let?contract?=?StatusMessage::default();6?????assert_eq!(None,?contract.get_status("francis.near".to_string()));7??}

在第6行的測試中,assert_eq右邊的表達式利用合約方法get_status嘗試從合約狀態數據中查詢StatusMessage合約用戶francis.near所對應的message信息。但是由于代碼的第5行僅僅初始化了整個合約的狀態,因此此時的合約數據整體為空,因此其返回值將是None。最終由于該結果符合預期,因此斷言正確,可以通過該單元測試。

4.執行測試用例

在編寫完上述單元測試后,我們還需要在該StatusMessageRust項目中配置該合約的Cargo.toml文件,即在該文件的小節中添加對near-sdk的依賴。

near-sdk?=?"3.1.0"

同時我們還需要在src/lib.rs文件的開頭處導入這些來自于near_sdk所提供的模塊或包:

use?near_sdk::borsh::{self,?BorshDeserialize,?BorshSerialize};use?near_sdk::collections::LookupMap;use?near_sdk::{env,?near_bindgen};

在配置完合約項目的依賴后,我們便可以利用cargo執行所有的單元測試用例。具體的命令如下:

$cargo?test?--package?status-message

測試將返回具體的測試結果:

testresult:ok.?2?passed;?0?failed;?0?ignored;?0?measured;?0?filteredout;finished?in0.00s

此外,我們還可以單獨指定單元測試的運行:

$cargo?test?--package?status-messageset_get_message

同樣地,我們可以獲得單獨測試的結果:

testresult:ok.?1?passed;?0?failed;?0?ignored;?0?measured;?1?filteredout;finished?in0.00s

本期總結和預告

這是BlockSec針對Rust合約開發的第二期blog,本期我們介紹了如何編寫單元測試用例,以及在本地進行測試的方法。下一期我們將進一步描述如何編譯合約代碼生成WASM目標代碼,并最終部署到NEAR測試鏈(testnet)上運行。

Tags:NEARCONTCONONTmnear幣smartcontractschemecoinucon幣最新消息Contents Protocol

MEXC
Rust智能合約養成日記(5)_ATT

相關文章: Rust智能合約養成日記合約狀態數據定義與方法實現Rust智能合約養成日記編寫Rust智能合約單元測試Rust智能合約養成日記Rust智能合約部署.

1900/1/1 0:00:00
從GameFi起源看元宇宙未來_EFI

一、傳統Game類型 1、角色扮演類 有完整的故事情節。 回合(半回合)制游戲 動作類的 2、動作類 控制人物,消滅怪物過關的 鬼泣,三國無雙 3、射擊類 第一人稱視角的射擊類游戲使命召喚,守望.

1900/1/1 0:00:00
USDT永續合約交易對將停盤維護,上線單向持倉功能_USDT

尊敬的中幣用戶: ???ZB合約的USDT永續合約交易對將于2022年3月25日00:30暫停交易,進行系統升級維護,并上線單向持倉功能.

1900/1/1 0:00:00
SupraOracles與HashBrownSwap達成合作_DEFI

SupraOracles很高興地宣布與開放的跨鏈DeFi平臺HashBrownSwap(HBS)建立合作伙伴關系。它是為所有人設計的次世代交易所和易于使用的錢包.

1900/1/1 0:00:00
幣安NFT市場將推出Toni Kroos\"冰人”盲盒系列_ONI

親愛的用戶: 幣安NFT市場將於2022年03月31日19:00推出ToniKroos"冰人”盲盒系列.

1900/1/1 0:00:00
頂峰課堂:經濟術語「敞口」_GOD

敞口是金融領域的一個重要概念,表示在金融活動中存在金融風險的部分,以及金融活動受金融風險影響的程度。簡單理解就是,從事什么金融活動,對應就有什么敞口.

1900/1/1 0:00:00
ads