通過實際項目中的單測編寫,總結如下幾點,幫助我更好的完成單元測試
為東興等地區用戶提供了全套網頁設計制作服務,及東興網站建設行業解決方案。主營業務為成都網站制作、做網站、東興網站設計,以傳統方式定制建設網站,并提供域名空間備案等一條龍服務,秉承以專業、用心的態度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!
本教程介紹了 Go 中模糊測試的基礎知識。通過模糊測試,隨機數據會針對您的測試運行,以嘗試找出漏洞或導致崩潰的輸入。可以通過模糊測試發現的一些漏洞示例包括 SQL 注入、緩沖區溢出、拒絕服務和跨站點腳本攻擊。
在本教程中,您將為一個簡單的函數編寫一個模糊測試,運行 go 命令,并調試和修復代碼中的問題。
首先,為您要編寫的代碼創建一個文件夾。
1、打開命令提示符并切換到您的主目錄。
在 Linux 或 Mac 上:
在 Windows 上:
2、在命令提示符下,為您的代碼創建一個名為 fuzz 的目錄。
3、創建一個模塊來保存您的代碼。
運行go mod init命令,為其提供新代碼的模塊路徑。
接下來,您將添加一些簡單的代碼來反轉字符串,稍后我們將對其進行模糊測試。
在此步驟中,您將添加一個函數來反轉字符串。
a.使用您的文本編輯器,在 fuzz 目錄中創建一個名為 main.go 的文件。
獨立程序(與庫相反)始終位于 package 中main。
此函數將接受string,使用byte進行循環 ,并在最后返回反轉的字符串。
此函數將運行一些Reverse操作,然后將輸出打印到命令行。這有助于查看運行中的代碼,并可能有助于調試。
e.該main函數使用 fmt 包,因此您需要導入它。
第一行代碼應如下所示:
從包含 main.go 的目錄中的命令行,運行代碼。
可以看到原來的字符串,反轉它的結果,然后再反轉它的結果,就相當于原來的了。
現在代碼正在運行,是時候測試它了。
在這一步中,您將為Reverse函數編寫一個基本的單元測試。
a.使用您的文本編輯器,在 fuzz 目錄中創建一個名為 reverse_test.go 的文件。
b.將以下代碼粘貼到 reverse_test.go 中。
這個簡單的測試將斷言列出的輸入字符串將被正確反轉。
使用運行單元測試go test
接下來,您將單元測試更改為模糊測試。
單元測試有局限性,即每個輸入都必須由開發人員添加到測試中。模糊測試的一個好處是它可以為您的代碼提供輸入,并且可以識別您提出的測試用例沒有達到的邊緣用例。
在本節中,您將單元測試轉換為模糊測試,這樣您就可以用更少的工作生成更多的輸入!
請注意,您可以將單元測試、基準測試和模糊測試保存在同一個 *_test.go 文件中,但對于本示例,您將單元測試轉換為模糊測試。
在您的文本編輯器中,將 reverse_test.go 中的單元測試替換為以下模糊測試。
Fuzzing 也有一些限制。在您的單元測試中,您可以預測Reverse函數的預期輸出,并驗證實際輸出是否滿足這些預期。
例如,在測試用例Reverse("Hello, world")中,單元測試將返回指定為"dlrow ,olleH".
模糊測試時,您無法預測預期輸出,因為您無法控制輸入。
但是,Reverse您可以在模糊測試中驗證函數的一些屬性。在這個模糊測試中檢查的兩個屬性是:
(1)將字符串反轉兩次保留原始值
(2)反轉的字符串將其狀態保留為有效的 UTF-8。
注意單元測試和模糊測試之間的語法差異:
(3)確保新包unicode/utf8已導入。
隨著單元測試轉換為模糊測試,是時候再次運行測試了。
a.在不進行模糊測試的情況下運行模糊測試,以確保種子輸入通過。
如果您在該文件中有其他測試,您也可以運行go test -run=FuzzReverse,并且您只想運行模糊測試。
b.運行FuzzReverse模糊測試,查看是否有任何隨機生成的字符串輸入會導致失敗。這是使用go test新標志-fuzz執行的。
模糊測試時發生故障,導致問題的輸入被寫入將在下次運行的種子語料庫文件中go test,即使沒有-fuzz標志也是如此。要查看導致失敗的輸入,請在文本編輯器中打開寫入 testdata/fuzz/FuzzReverse 目錄的語料庫文件。您的種子語料庫文件可能包含不同的字符串,但格式相同。
語料庫文件的第一行表示編碼版本。以下每一行代表構成語料庫條目的每種類型的值。由于 fuzz target 只需要 1 個輸入,因此版本之后只有 1 個值。
c.運行沒有-fuzz標志的go test; 新的失敗種子語料庫條目將被使用:
由于我們的測試失敗,是時候調試了。
語料庫文件以特殊格式編碼。這是種子語料庫和生成語料庫的相同格式。
下面是一個語料庫文件的例子:
第一行用于通知模糊引擎文件的編碼版本。雖然目前沒有計劃未來版本的編碼格式,但設計必須支持這種可能性。
下面的每一行都是構成語料庫條目的值,如果需要,可以直接復制到 Go 代碼中。
在上面的示例中,我們在 a []byte后跟一個int64。這些類型必須按順序與模糊測試參數完全匹配。這些類型的模糊目標如下所示:
指定您自己的種子語料庫值的最簡單方法是使用該 (*testing.F).Add方法。在上面的示例中,它看起來像這樣:
但是,您可能有較大的二進制文件,您不希望將其作為代碼復制到您的測試中,而是作為單獨的種子語料庫條目保留在 testdata/fuzz/{FuzzTestName} 目錄中。golang.org/x/tools/cmd/file2fuzz 上的file2fuzz工具可用于將這些二進制文件轉換為為[]byte.
要使用此工具:
語料庫條目:語料庫 中的一個輸入,可以在模糊測試時使用。這可以是特殊格式的文件,也可以是對 (*testing.F).Add。
覆蓋指導: 一種模糊測試方法,它使用代碼覆蓋范圍的擴展來確定哪些語料庫條目值得保留以備將來使用。
失敗的輸入:失敗的輸入是一個語料庫條目,當針對 模糊目標運行時會導致錯誤或恐慌。
fuzz target: 模糊測試的目標功能,在模糊測試時對語料庫條目和生成的值執行。它通過將函數傳遞給 (*testing.F).Fuzz實現。
fuzz test: 測試文件中的一個被命名為func FuzzXxx(*testing.F)的函數,可用于模糊測試。
fuzzing: 一種自動化測試,它不斷地操縱程序的輸入,以發現代碼可能容易受到的錯誤或漏洞等問題。
fuzzing arguments: 將傳遞給 模糊測試目標的參數,并由mutator進行變異。
fuzzing engine: 一個管理fuzzing的工具,包括維護語料庫、調用mutator、識別新的覆蓋率和報告失敗。
生成的語料庫: 由模糊引擎隨時間維護的語料庫,同時模糊測試以跟蹤進度。它存儲在$GOCACHE/fuzz 中。這些條目僅在模糊測試時使用。
mutator: 一種在模糊測試時使用的工具,它在將語料庫條目傳遞給模糊目標之前隨機操作它們。
package: 同一目錄下編譯在一起的源文件的集合。
種子語料庫: 用戶提供的用于模糊測試的語料庫,可用于指導模糊引擎。它由 f.Add 在模糊測試中調用提供的語料庫條目以及包內 testdata/fuzz/{FuzzTestName} 目錄中的文件組成。這些條目默認使用go test運行,無論是否進行模糊測試。
測試文件: 格式為 xxx_test.go 的文件,可能包含測試、基準、示例和模糊測試。
漏洞: 代碼中的安全敏感漏洞,可以被攻擊者利用。
在正常的測試中,當我們需要進行接口測試時,通常使用接口調試工具,如postman進行接口測試
目前我在嘗試使用Go語言進行接口測試,使用的庫均為Go自帶的庫。
注:當前采用的接口為時事新聞接口,每天可以請求100次,需要的同學,可以自行使用。
Reverse為了解決這個問題,如果輸入不是有效的 UTF-8 ,讓我們返回一個錯誤。
a.在您的文本編輯器中,將現有Reverse函數替換為以下內容。
如果輸入字符串包含無效的 UTF-8 字符,此更改將返回錯誤。
b.由于 Reverse 函數現在返回錯誤,因此修改main函數以丟棄額外的錯誤值。將現有main功能替換為以下內容。
這些調用Reverse應該返回一個 nil 錯誤,因為輸入字符串是有效的 UTF-8。
c.您將需要導入錯誤和 unicode/utf8 包。main.go 中的 import 語句應如下所示。
d.修改reverse_test.go文件檢查是否有錯誤,如果返回產生錯誤則跳過測試。
除了返回之外,您還可以調用t.Skip()以停止執行該模糊輸入。
a.使用 go test 運行測試
b.使用go test -fuzz=Fuzz進行模糊測試,幾秒鐘后,停止用ctrl-C模糊測試。
除非您通過-fuzztime標志進行限制,否則模糊測試將一直運行,直到遇到失敗的輸入。如果沒有發生故障,默認是永遠運行,并且可以使用 中斷該過程ctrl-C。
c. 使用go test -fuzz=Fuzz -fuzztime 30s。如果沒有30 秒發現失敗,它會在退出模糊測試。
模糊測試通過了!
做得很好!您剛剛學習了在 Go 中進行模糊測試。
— main.go —
— reverse_test.go —
當前標題:go語言測試怎么寫,go語言可以做測試嗎
瀏覽地址:http://vcdvsql.cn/article28/hsspjp.html
成都網站建設公司_創新互聯,為您提供微信公眾號、手機網站建設、軟件開發、網站改版、App開發、小程序開發
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯