以太幣交易所 以太幣交易所
Ctrl+D 以太幣交易所
ads

長文詳解PlatON測試Case全景圖_NBS

Author:

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

說PlatON測試之前,我們需要先了解下關于區塊鏈測試和傳統互聯網測試的區別,其主要體現在系統邊界模糊,對于區塊鏈的測試不僅僅是前端API與某個區塊鏈節點之間的測試,還涉及大量區塊鏈節點與節點之間的測試。

同時還要注意PlatON鏈本身包含公有鏈、私有鏈,不同類型在管理、用戶身份、最大節點數等平臺自身特征方面均有不同,測試需要考慮所有的模式,導致測試方案和場景也比常規的傳統測試更加復雜。

現在我們可以來認識下PlatON,首先它不屬于交易所類型的業務產品,而是于基于區塊鏈的技術以及鏈技術產生的價值的生態基礎服務,測試的重點也是不一樣的。我們的測試會更加關注底層,比如共識算法、網絡、存儲、經濟模型等。

PlatON測試范圍總覽

從Case全景圖可以看出,我們對PlatON的Case過程進行分類,主要是通過5個方面去驗證系統保證安全可靠。

主要是通過在鏈初始化時,搭建私鏈或者鏈接主網時對經濟模型中的合約賬號、信息以及參數進行合理性的驗證。

隱式初始化-不指定網絡時鏈接PlatON主網絡,這時候需要驗證網絡節點搭建成功之后鏈上信息和內置的信息保持一致。

顯式初始化-搭建私鏈則是通過創世文件初始化的方式加入到特定的私有網絡,成功加入鏈之后驗證鏈上信息和配置的信息保持一致初始化參數。

共識參數-經濟模型參數、治理參數、懲罰參數、獎勵參數、增發參數。

初始化參數是通用的系統參數,參數分主網參數和自定義參數兩類:

主網參數-通過在啟動節點時增加命令參數來實現鏈接PlatON主網絡,需要驗證的就是鏈上共識參數、經濟模型參數、治理參數等和主網參數保持一致。

Tether顧問:貝萊德的ETF可能會改變比特幣游戲規則:金色財經報道,Tether顧問Gabor Gurbacs表示,監管機構沒有足夠的理由不批準比特幣ETF。SEC提到了對潛在市場操縱、托管問題以及基礎市場整體成熟度的擔憂,現貨比特幣ETF代表了對比特幣等標的資產的直接所有權。當你購買現貨ETF的份額時,該基金實際上獲得了等量的資產,提供了近乎一對一的風險敞口,它可以通過為個人和機構提供一種熟悉且受到廣泛監管的方式來接觸比特幣,從而擴大比特幣的投資者基礎。它可能會增加流動性并改善價格發現。其次,它可能會導致機構采用率的增加,進而有助于提高市場穩定性和減少價格波動,現貨比特幣ETF何時熊市無從知曉,但情況與2018年略有不同。例如,薩爾瓦多在2021年將比特幣定為法定貨幣,一些公司已經在積累比特幣,或將其作為財務或投資管理的一部分。貝萊德的興趣只是這一新轉變的一部分,其申請獲得批準可能會永遠改變比特幣游戲規則。[2023/7/24 15:54:30]

自定義參數-在啟動節點時,通過調整初始化創世文件里的初始化參數來實現自定義參數,然后通過鏈初始化啟動節點,這時候鏈上的參數應該和創世文件中的參數保持一致。

但是這里需要注意的是自定義參數時,創世文件中數值閾值的調整需要合理,不同的參數組合最終會導致鏈啟動成功與否以及鏈上運行的規則發生變化,我們的測試過程正是驗證這些參數變動帶來的各種邊界值,以及參數是否給鏈的運行提供合理的標準。

啟動階段測試我們分為兩種模式進行驗證,分別是單節點和集群,因為不同的節點數量鏈運行方式也會有所不同,我們從簡單的結構出發,然后慢慢擴展數量,從而達到模擬真實環境。

啟動節點 

查看節點信息 

查看版本信息 

鏈上功能

快速參數集群 

主網集群 

Paypal:80%的元宇宙用戶目前使用加密貨幣:金色財經報道,Paypal對元宇宙的一項調查顯示,56% 的受訪者表示,他們對加密貨幣的使用將在未來五年內增加。 80%的元宇宙用戶目前使用加密貨幣,而 97% 的元宇宙用戶持有加密貨幣,其中BTC持有量最大,ETH、RBX分列第二和第三。[2023/6/7 21:20:46]

作為區塊鏈運轉的載體,所有的事情幾乎都要節點參與,網絡通信、邏輯運算、交易、數據驗證等,而區塊鏈一般是由多個節點組成協同工作,因此節點屬性及對節點的管理至關重要。在實際管理中,節點能由管理者操作加入或者退出區塊鏈網絡,而不影響業務的正常運行,以及擴容新增節點。

在節點相關驗證,主要包含了鏈部署時不同節點數量的情況下節點的運行情況檢查,創世文件啟動時不同的參數組合對鏈影響,如共識節點數量、治理參數配置、同步方式等,我們會根據不同的組合去驗證配置參數的合理性,同時節點本身具備了不同的啟動參數,在整個鏈運行的過程中需要對啟動參數的調整來驗證這些啟動命令的有效性以及對鏈的影響。

同時還需要分別在單節點和集群模式下進行鏈上功能的驗證,確保在不同模式下PlatON經濟模型業務表示是一致的。 

這個階段也是PlatON主要的測試內容,這個階段主要包含了對底層和業務層兩個方面。

底層

Giskard共識

正所謂「無共識,不區塊」,作為區塊鏈的核心屬性,「共識機制」決定了區塊鏈的安全性、 去中心化和可擴展性等重要性質,并且保證各共識節點對交易執行結果達成一致。

PlatON的Giskard共識協議由概率性權益證明PPoS(PlatON proof of stake)和Giskard拜占庭容錯協議-Giskard BFT(Giskard Byzantine Fault Tolerance) 組成。PPoS使用質押、委托、隨機選取的形式選出參與共識的驗證節點,Giskard BFT使用類BFT算法實現區塊的生產和驗證。

Round13 Capital旗下第三支基金已募資2億美元:金色財經報道,加拿大風投Round13 Capital旗下第三支基金完成2億美元募資,該風投公司聯合創始人Bruce Croxon 和 John Eckert 目前已移交了領導權,據悉新基金的融資目標是3億美元。Round13在加密行業較為活躍,旗下投資組合包括去中心化身份公司Qui Identity、區塊鏈基礎設施公司ChainSafe Systems,去年還推出了專屬數字資產基金,投資于區塊鏈和 Web3 基礎設施公司。[2023/4/12 13:59:59]

針對Giskard共識我們設計了相應的驗證場景來覆蓋PlatON共識模塊。

1. 從共識的不同階段我們來驗證每個階段共識

viewChange:對viewChange基本信息校驗同時包含viewChange發起、收到等場景組合來驗證正確性。 

prepareBlock:對prepareBlock消息基本校驗同時窗口期內viewChangeQC后發起的不同狀態下的prepareBlock進行驗證。 

prepareVote:對prepareVote消息基本校驗同時不同窗口期以及不同節點狀態下的prepareVote進行驗證。 

VerifyQC:包含了viewChangQC和prepareQC,主要檢測不同簽名數量下場景驗證。

2. 模擬拜占庭場景下共識模塊的驗證

Giskard-非拜占庭場景:模擬參與節點在非拜占庭場景下共識模塊各個階段的驗證。 

Giskard-拜占庭場景:模擬參與節點在拜占庭場景雙出、惡意等操作下共識模塊各個階段的驗證。 

3. 異常場景下共識模塊的驗證 

Giskard-節點啟停:通過啟停節點、間隔啟停、節點恢復等操作來驗證共識模塊的完整性和連續性。 

CZ指控FTX向新聞機構支付4300萬美元以發布Binance FUD:1月24日消息,Binance首席執行官CZ在Twitter空間談話中聲稱FTX向一家定期發布有關Binance負面文章的加密新聞媒體支付了4300萬美元。CZ表示,持有空頭頭寸的交易員希望“產生負面消息”以改善他們的交易。CZ同時承認關注了這家由FTX資助的負面新聞機構,并表示我不認為它會停止,但我不也認為它會在未來困擾我們那么多。(cryptoslate)[2023/1/24 11:28:41]

Giskard-消息丟失:模擬丟棄投票、prepareBlock等場景下驗證共識消息傳遞的有效性。 

Giskard-容錯:通過構建超時、惡劣環境的運行穩定性場景來驗證共識的容錯性。

通過以上場景我們測試需要驗證的是,這種共識機制能否按預期算法完成從交易觸發到數據落塊,以及在容錯和容災范圍內依然正常工作。區塊鏈平臺上線前,對其使用的共識算法需要做嚴格的測試驗證,涉及功能、安全、易用性等各方面。

P2P網絡驗證

涉及到連接的地方主要有節點間P2P連接、節點與客戶端的連接,以及鏈下機構間通過鏈上節點進行通信。通常在環境條件正常時,以上連接都能順利進行,并且通過網絡連接命令和日志信息能查詢對應結果。而真正考驗連接的健壯性是在異常環境下系統的應對能力,以及環境恢復正常之后,連接能否也恢復正常。

從而我們需要考慮從以下幾個方向來驗證p2p網絡的安全性:

1. 節點數

不同的節點數量組合,可以驗證網絡通信中消息傳遞所需要的時間是否滿足以及消息傳遞過程中是否出現遺漏和丟失。

2. 網絡流量

監控網絡流量,則是為了驗證在一個鏈運行過程中的各種業務功能和節點操作時,鏈上資源消耗情況是否能達到預期的要求,避免出現運行過程中異常流量的產生導致鏈出現無法共識的情況。

BendDAO目前共有31枚BAYC正在清算拍賣,平臺內37枚BAYC健康因子小于1.1:11月15日消息,NFT抵押借貸協議BendDAO目前共有31枚BAYC正在清算拍賣。據悉,出價需大于NFT地板價95%,如拍品最終未成交,平臺將承擔浮虧或借款人未來償還債務。當前BAYC地板價為49.92ETH,出價需大于47.42ETH。

目前BendDAO平臺有37枚BAYC健康因子小于1.1(當健康因子小于1時,將啟動NFT清算拍賣)。[2022/11/15 13:06:04]

3. 節點發現

通過配置種子節點數、靜態節點數來驗證節點在互聯過程中靜態節點連接數限制,主動鏈接數限制、被動鏈接數限制是否生效,模擬在不同級別的數量節點配置情況下鏈的運行是否穩定。

發送到節點的交易,應當能同步到網絡中其他節點。不同的區塊鏈平臺,根據節點的類型、組網模式,會采用不同的同步邏輯。區塊同步涉及場景較多,新入網節點、進程停止一段時間在重啟、節點遭遇故障導致數據丟失等,都會觸發區塊同步邏輯,以及在沒有交易處理時,節點間也會保持狀態的同步,以上都涉及到很多的同步場景,在測試中需對每一個場景設計詳細、全面的驗證過程,包括一些場景的交叉測試。

區塊存儲驗證

區塊存儲功能的驗證主要還是穩定性和正確性,在落塊成功的基礎上還要保證節點之間數據都一致。

每個節點根據不同節點啟動策略部署的數據存儲的信息能有效且準確的保留信息,一般我們會根據啟動參數以及同步模式的不同采取fast或者full模式進行驗證,這時候我們需要考慮的是多交易在發送過程中記錄在本地的區塊信息是否有遺漏,同時在進行功能驗證的時候可采用混沌模型測試,各業務場景進行組合,驗證每個節點存儲穩定且數據正確。

業務層

經濟模型驗證

PlatON的經濟模型就是在鏈上進行各種會產生經濟活動的場景組合,所有參與到經濟活動的主體在互動時,都將伴隨著Token的變化,針對不同的經濟活動我們可以運用測試理論中的測試手段,如邊界值、等價類、因果法、場景構建等方法進行驗證,主要是活動主體的Token的數量進行校驗。

鎖倉

鎖倉創建 

鎖倉質押委托 

鎖倉回退 

鎖倉結算 

處罰通知....

Staking

createStaking (質押) 

editCandidate (修改候選人信息) 

increaseStaking (增持質押) 

withdrewStaking (撤銷質押) 

delegate (委托) 

withdrewDelegate (撤銷委托) 

withdrawDelegateReward (領取獎勵)

getVerifierList (查詢當前結算周期的驗證人列表) 

ElectNextVerifierList (選舉下一個結算周期的驗證人列表)激勵 ……

激勵

發放質押獎勵 

發放出塊獎勵 

是否到達年末……

處罰

舉報雙簽 

舉報雙出 

查詢舉報信息 

處罰規則……

在這個過程中,我們也會對節點排名、狀態、節點的收益進行驗證,針對不同的經濟活動場景進行有效的組合,其中包括了節點的狀態以及鏈的結算周期和共識周期的變化,根據不同的組合我們可以通過自動化的方式檢查活動主體的Token數量和狀態變化情況是否滿足設計要求,從而驗證了經濟模型的合理性和正確性。

治理模型驗證

PlatON治理模型主要是驗證PlatON進行鏈上治理時,鏈上節點參與投票的進行更新或者修復的一個過程,在這個過程中節點的選擇行為會影響到鏈上發展方向和鏈的一個狀態,如果節點對治理的內容有分歧則會出現不同的結果,治理升級的驗證主要是驗證治理前后鏈上數據的一致性和區塊的連續性。

提交提案

提交升級提案 

提交文本提案 

提交參數提案 

提交取消提案 ……

投票

有效提案投票 

無效提案投票 

放棄投票 

投票統計……

版本聲明

有效的提案聲明 

無效提案聲明……

提案全流程

提交文本提案統計 

提交取消提案……

通過不同的結算周期、共識周期、投票節點狀態的變化來驗證治理機制的正確性。同時為了滿足實際場景中的復雜運行環境,需要增加經濟活動的場景來豐富可能出現的異常情況,從而驗證整個治理模型的可靠性。

對于區塊鏈底層的測試,不僅僅是前端API與某個區塊鏈節點之間的測試,還涉及大量區塊鏈節點與節點之間的測試。所以,如果只是單一地去做某個特性的測試,比如連接或者同步,同樣條件,這次成功,下次可能就會失敗,因為區塊鏈是個分布式的系統軟件,一個節點的正常不代表整個系統正常。

測試過程也需要融入分布式思想,而不能停留在中心化軟件上。某個節點在同步,其他節點可能在共識,包括節點所在機器環境也可能隨時發生變化,在場景模擬的過程,需要將軟件、硬件以及區塊鏈自身操作進行各種組合驗證,區塊鏈的邊界比較模糊,而各種組合測試正好通過模擬現實運行的場景,讓系統盡可能運行在邊界處,就比如共識算法,多節點的網絡,讓其中部分正常運行,剩下的部分節點在正常的閾值內進程啟停,進行場景模擬會更容易發現一些邊界問題。所有場景模擬過程,持續運行測試,觀察資源的消耗情況,從而找到系統的盲點。

作為一個底層平臺,性能是一個很關鍵的指標,它決定了上層應用在高峰期能跑多少的業務量。一個系統中每個接口,每個功能特性都會涉及到性能,但并非都需要壓出其性能。對于區塊鏈來說,重點關注的是它處理交易的性能,從客戶端發起交易、簽名,到節點打包、共識,最后數據落盤,這一完整過程系統的性能。

任何一個性能數據背后都對應著軟件和硬件配置組合的結果,包括CPU、內存、磁盤、帶寬等硬件條件,以及壓測的合約類型、交易大小,節點組網模式等因素都會影響性能結果。理論上,代碼自己沒有邏輯錯誤,只要配置跟上,性能是可以無限的。但實際生產條件肯定有個上限,因此壓測的性能數據可以提供兩份,生產常用的硬件及軟件配置條件下的,和實驗室里高配的硬件和軟件時的性能數據。后續會再出一篇專門的性能文章,來講解PlatON性能是如何提升上去的。

合約編譯及支持

合約的使用和管理對區塊鏈是一個重要的評測標準。包括合約的部署方式是否簡便,即能提供哪些語言支持的客戶端或者中間件工具部署合約,以及發送交易。合約是否支持升級,升級后如何管理版本。除了合約本身的升級,區塊鏈節點升級后,已經部署的老合約也應當能繼續調用,兼容性都沒問題。

PlatON提供對應的編譯工具,為此我們也要對合約編譯工具及本身合約版本進行驗證,確保鏈上支持不同版本的合約語法。拿solidity語言來說,需要驗證提供的各種變量類型、語法表達式、控制接口等合約結構,在鏈上是否都能跑通,包括能否跨合約調用鏈上的內置合約功能。

區塊鏈系統涉及的安全包括很多方面,從連接到共識、從算法到隱私保護,都和安全息息相關,安全措施覆蓋得越全面,系統被攻擊的概率越低,運行越穩健。區塊鏈是由節點組成,而對于非法節點的加入,平臺是否提供了證書網絡準入機制或者黑白名單特性,解決非法連接和入網問題。鏈上大量的數據或者各種類型的表,需要提供權限管理機制給不同用戶授予不同操作權限,包括部署合約及發送交易。

Tags:NBSBSP區塊鏈LATnbs幣未來價格BSPT價格什么叫做區塊鏈技術的概念LATX幣

歐易okex官網
靠游戲收入分成 能帶火新的NFT猿猴嗎?_MON

這兩天大熱的項目,除了文本類 NFT「First First NFTs」,還有菠菜猴「Monkey Bet DAO」.

1900/1/1 0:00:00
Aurory:Solana上的另一個明星鏈游_AUR

「拳皇97」在傳播的意義上很成功,這得益于特殊的時代背景。—— 知名創意機構 W 內部分享作為最近備受關注的公鏈Solana,其上的鏈游自然也開始吸引到更多的目光.

1900/1/1 0:00:00
風投Paradigm如何看待多鏈趨勢下的跨鏈橋的發展?_OSMO

隨著公鏈市場進入群雄并起的“多鏈時代”,市場對跨鏈的需求也變得越來越清晰。無論是新公鏈,還是以太坊Layer 2,用于跨鏈的資產橋似乎已變得不可或缺,而曾經的“跨鏈雙雄”Polkadot和Cos.

1900/1/1 0:00:00
DeFi風掀起NewB.Farm+ApeSwap機槍池 地表最牛_EFI

幣圈近來掀起了一陣DeFi風,DeFi流動性挖礦相當火爆,Yield Farming的年化收益,不管是單幣種或雙幣種質押,都是挺不錯的,同時引來了無數投資者蜂擁參與.

1900/1/1 0:00:00
最新GameFi教程:如何玩賺OEC首款爆火鏈游「角斗士」_BSP

準備階段:手機端玩家需要Tokenpocket錢包,創建OKExChain錢包(有的可以自行導入私鑰).

1900/1/1 0:00:00
區塊鏈、數據和代幣:構建所有權經濟的基石_區塊鏈

互聯網蓬勃發展幾十年,創作者和個人通過在各類應用平臺上創作內容或生產數據的方式,創造了很大的價值.

1900/1/1 0:00:00
ads