這篇文章主要介紹了Go語言中的單元測試實例分析的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Go語言中的單元測試實例分析文章都會有所收獲,下面我們一起來看看吧。
前置條件
Go語言內置了單元測試執行的指令,由于尚未使用Go Modules方法,我們仍然要設置環境變量,才能正確進行測試
export GO111MODULE=off go test
代碼
假設我們對以下函數進行測試
package even func Even(i int) bool { return i % 2 == 0 }
單元測試建立步驟
創建一個單元測試,包括如下步驟:
在相同目錄下創建一個名為*_test.go的文件
執行go test進行測試,將自動識別這些文件
引入testing包
每一個Case的命名都是以func TestXxx(t *testing.T)
編寫單元測試
這里分別對兩種場景進行測試,一種是為偶數的情況,一種是為奇數的情況,來檢查我們的程序是否按照預期返回,如果不是則拋出異常信息
package even import "testing" func TestEven(t *testing.T) { if !Even(2) { t.Log("2 should be even!") t.Fail() } } func TestNotEven(t *testing.T) { if Even(3) { t.Log("3 should not be even!") t.Fail() } }
執行go test后
PASS
ok _/root/workspace/go/test_unittest 0.003s
func (t *T) Fail() 讓測試失敗,同一個測試用例中的測試繼續執行,后續的測試也會繼續執行
package even import "testing" func TestTestingFail(t *testing.T) { // Let create a fake case, we will call FailNow if Even(2) { t.Log("All test cases after Fail will still run") t.Fail() } if Even(2) { t.Log("The test after Fail will still run") t.Fail() } } func TestAfterFailCase(t *testing.T) { if Even(2) { t.Log("This test case after Fail will still run") t.Fail() } }
執行測試后,TestTestingFail中的第二部分也可以繼續執行。
--- FAIL: TestTestingFail (0.00s)
even_fail_test.go:8: All test cases after Fail will still run
even_fail_test.go:13: The test after Fail will still run
--- FAIL: TestAfterFailCase (0.00s)
even_fail_test.go:20: This test case after Fail will still run
FAIL
exit status 1
FAIL _/root/workspace/go/test_unittest 0.004s
func (t *T) FailNow() 讓測試失敗,同一個測試用例中的測試不再執行,后續的測試也會繼續執行
package even import "testing" func TestTestingFailNow(t *testing.T) { // Let create a fake case, we will call FailNow if Even(2) { t.Log("All test cases after FailNow will not run") t.FailNow() } if Even(2) { t.Log("The test after FailNow will be skipped") t.FailNow() } } func TestAfterFailNowCase(t *testing.T) { if Even(2) { t.Log("This test case after FailNow will still run") t.FailNow() } }
執行后TestTestingFailNow中的第二段測試不再執行,而后面的TestAfterFailNowCase繼續執行
--- FAIL: TestTestingFailNow (0.00s)
even_failnow_test.go:8: All test cases after FailNow will not run
--- FAIL: TestAfterFailNowCase (0.00s)
even_failnow_test.go:20: This test case after FailNow will still run
FAIL
exit status 1
FAIL _/root/workspace/go/test_unittest 0.003s
func (t *T) Log(args …interface{}) 使用默認格式記錄日志,等同于Print(),記錄錯誤日志
func (t *T) Fatal(args …interface{}) 與Log功能相似,但是輸出日志后會調用FailNow
package even import "testing" func TestTestingFatal(t *testing.T) { // Let create a fake case, we will call FailNow if Even(2) { t.Fatal("All test cases after FailNow will not run") } if Even(2) { t.Fatal("The test after Fatal will not run") } } func TestAfterFatalCase(t *testing.T) { if Even(2) { t.Fatal("This test case after Fatal will still run") } }
Fatal的執行過程與FailNow相似
--- FAIL: TestTestingFatal (0.00s)
even_fatal_test.go:8: All test cases after FailNow will not run
--- FAIL: TestAfterFatalCase (0.00s)
even_fatal_test.go:18: This test case after Fatal will still run
FAIL
exit status 1
FAIL _/root/workspace/go/test_unittest 0.005s
關于“Go語言中的單元測試實例分析”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Go語言中的單元測試實例分析”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。