AERGO SHIP:用於開發智能合約的包管理器

AERGO SHIP:用於開發智能合約的包管理器,用於構建、測試和部署分佈式應用程序的客戶端框架和開發環境

AERGO SHIP:用於開發智能合約的包管理器

用於構建、測試和部署分佈式應用程序的客戶端框架和開發環境

構建大型分佈式應用程序是很困難的,因爲對其進行測試,使其實現端到端工作,並進行部署是一個非常耗時的過程。通過AERGO,我們計劃讓一切變得與衆不同。

AERGO是一個爲在實現基於區塊鏈的系統和應用程序時面臨衆多獨特挑戰的企業提供解決方案的平臺。爲了提高開發、測試和部署智能合約的效率和易用性,我們創建了SHIP。SHIP是Lua智能合約包管理器。它將本地開發環境與Git和分佈式分類賬連接起來,從而大大減少了構建和管理智能合約所花費的時間。SHIP提供以下功能:

項目設置:在簡單的任務中完成開發準備。

從遠程存儲庫安裝軟件包:GitHub上的軟件包可以安裝在本地存儲庫中。

構建:結合(預處理)項目內部的資源來開發準備分發的產品。

單元測試:在上傳到網絡之前,您可以驗證新版本的功能是否符合要求。

部署到本地存儲庫:將已開發的項目安裝到本地存儲庫中,以供其他項目參考。

SHIP最基本的理念是簡潔;它輕巧而有效。目前版本的SHIP特意不包括廣泛的開發功能;但重要的是,SHIP是一個持續更新的項目。我們將從技術社區中獲取建議,並繼續添加被視爲有價值的功能。

我們爲什麼要創建包管理器?

我們經常回顧歷史,以便提出假設。本月早些時候,Phil發表了一篇文章,解釋了我們基於Linux和Red Hat所取得的歷史性成功的開源執行方法。在開發分佈式應用程序時,我們採用相同的方式創建了一個包管理器。

2009年至2014年,許多技術競相出現,形成了我們今天所知的現代網絡的年代。

需要注意的是,在創建JavaScript之後,1995年到2010年之間沒有引入構建或包管理工具。在開始使用JavaScript之後的15年裏,在推進Web狀態方面幾乎沒有取得任何進展。然而,隨着2009年Node.js的發佈,包管理器和捆綁包變得越來越普遍,從而可以創建新一代的動態網頁。Node.js的默認包管理器npm的創建實現了Web的快速發展。

2012年,Trello發佈了一篇文章概述Trello Tech Stack。這篇文章介紹了許多技術,這些技術將使Web作爲一個應用程序而不僅僅是一個頁面工作。它很好地概述了2012年之前網絡的進展及其在前幾年的快速發展。這種快速發展確實是由npm的創建引起的,減少了開發網頁所花費的時間。

就像npm之於Web一樣,SHIP旨在成爲開發基於區塊鏈的應用程序和智能合約的關鍵點。SHIP將實現智能合約的開發、測試和部署無縫且高效。最終,SHIP將爲AERGO提供吸引下一代dApp和企業區塊鏈開發人員所需的可用性,以創建一個蓬勃發展的開發者開源生態系統。

如何使用SHIP

要使用SHIP,您必須先下載並安裝以下程序:

Git
JDK 8+
Node.js
npm

構建SHIP

SHIP目前尚未正式發佈。如果您希望使用SHIP,必須先構建它。SHIP使用下方的GitHub地址作爲源存儲。

aergoio/ship

從GitHub獲取源代碼。(命令開頭的$顯示提示,如果系統root提示,則提示符爲#)。

$ git clone

現在運行構建。第一次嘗試運行時,命令很長。

$ cd ship

$ ./build.sh clean deps npm assemble

成功完成後,您可以看到ship- $ VERSION.tar文件已在程序集/構建/分發中創建。

解壓縮此文件以安裝SHIP。

接下來,使用ship命令在PATH路徑中包含bin目錄。您可將.bash_profile添加到最後一部分。它可能會根據您的shell而發生改變。

export PATH=$PATH:$SHIP_HOME/bin

SHOP_HOME指的是解壓縮ship - $ {VERSION}目錄。安裝現已完成。

建立項目

我們現在正在建立一個智能合約開發項目。在所需位置爲項目創建目錄。

$ mkdir my-first-project

在本文中,我將此位置稱爲$ {PROJECT_HOME}

ship命令假定當前工作目錄即爲項目目錄。讓我們將當前目錄移到項目中。

$ cd my-first-project

要將空目錄作爲項目,您需要運行以下命令。

$ ship init

如果運行正常,則將在項目目錄中創建名爲aergo.json的文件。aergo.json文件應如下所示:

{
“name” : “bylee/my-first-project”,
“source” : “src/main/lua/main.lua”,
“target” : “app.lua”
}

更改項目設置

有關該項目的信息存儲在aergo.json中。必要時,您可以編輯此文件。我們來看看這個文件的屬性。

name - 項目名稱:以$ {github_account} / $ {project_name}格式導入或將包放入存儲庫時使用此名稱。最初創建爲$ {username} / $ {project_name}。如果您的用戶名和GitHub帳戶不同,則需要對其進行更改。

source – 將開始構建的源文件的路徑視爲相對於項目文件夾的路徑。

target - 保存有構建結果的文件的路徑。編譯構建的文件,生成二進制文件和ABI並將其部署到AERGO服務器。

dependencies - 引用的包的名稱。包是指存儲庫中安裝的項目的類型。

tests - 測試源的路徑。顧名思義,這是一種數組類型。

endpoint - AERGO服務器部署和運行以進行集成測試的主機名和端口信息。 $ {hostname}:設置爲$ {port}。默認值爲“localhost:7845”。

由於當前狀態沒有變化,我們將繼續下一步。

編寫智能合約

現在,讓我們來編寫一段簡單的代碼。源是src / main / lua / main.lua。

function min(a, b)
if (a < b) then
return a
else
return b
end
end

我寫了一個min函數,該函數選取了兩個數字並返回其中較小的數字。目前,AERGO支持的智能合約基於語言lua。讓我們來構建當前的源代碼。

$ ship build

如果沒有問題,則創建app.lua文件。如果打開此文件,它與src / main / lua / main.lua完全相同,因爲您可能只有一個文件要創建。如果繼續修改源並查看其更改方式,則可以看到該構建如何組合文件。

此前,SHIP表示可以將多個文件合併爲一個。現在,讓我們重構main.lua文件。您可以使用import命令從一個源引用另一個源。將min函數移到src / main / lua / utils.lua,將現有的main.lua替換爲:

import “./utils.lua”

如果進行重新構建,則可以看到app.lua文件與之前相同。

創建單元測試

讓我們爲剛創建的utils.lua中的min函數編寫一個單元測試。我們將在src / test / lua / test-utils.lua中編寫測試代碼。下一次如果有機會,我會更詳細地討論用於測試的API,這次僅顯示示例。

import “aergoio/athena-343”
local suite = TestSuite(‘test suite for utils.lua')
suite:add(TestCase(‘test min', function()
assertEquals(3, min(3, 4))
end))
suite:run()

在aergo.json中添加一個測試條目,告知SHIP這是一個用於測試的文件。

{
“name” : “bylee/my-first-project”,
“source” : “src/main/lua/main.lua”,
“target” : “app.lua”,
“tests”: [ “src/test/lua/test-utils.lua” ]
}

要運行測試,請運行以下命令:

$ ship test
ERROR : "Package aergoio/athena-343 not found: /Users/bylee/.aergo_modules/aergoio/athena-343/aergo.json"
When you run the test, you get an error because the aergoio / athena-343 that you use as a test framework is not installed. Now, let's install the package in github.
$ ship install aergoio/athena-343

實驗部分

增量構建

SHIP具有強大的構建能力。此功能可檢測項目中文件的更改,並對其進行自動構建和測試。

運行該函數需要構建命令的其他參數。

$ ship build –watch

如果運行沒有問題,則可以看到以下結果。這個例子是我的第一個項目。

如果您更改了源,則可以看到實時反映的構建和測試。

WebUI

此外,我們還提供一個Web服務,允許瀏覽器訪問以下附加端口選項。

$ ship build --watch --port 8080

構建結果

除了提供比終端所提供的更多細節之外,它還提供了額外的部署功能。此部署用於測試,因此它將轉到localhost上的端口7845。要使用此功能,服務器必須正在運行,並且必須在PATH中設置aergoluac命令。

單元測試結果

您還可以查看每個構建的測試結果,並且構建記錄還保存有過去的五個測試結果。

當您選擇Runner菜單時,會出現一個屏幕,您可以在其中實際運行已部署的功能。

結論

SHIP提供支持項目開發每個階段的功能,從設置到部署。它可以幫助開發人員從現有的編程方法中獲得結構化編程,從而使開發智能合約的過程更加無縫和高效。雖然SHIP還沒有足夠的功能,並且開發的某些方面可能還不夠簡便,但我們計劃與dApp開發人員合作,以確定有價值的東西,並在將來通過更好的功能實現這些價值。我們正在等待您的反饋!

如果您還不知道,我們最近推出了AERGO預測試網,併發布了AERGO平臺的Alpha代碼庫。您可以隨意啓動本地測試網絡,貢獻代碼。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章