一文帶你了解Go語(yǔ)言中的單元測(cè)試
基本概念
上一節(jié)提到,代碼完成的標(biāo)準(zhǔn)之一還包含了單元測(cè)試,這部分也是很多開發(fā)流程中不規(guī)范的地方。寫過(guò)單元測(cè)試的開發(fā)人員應(yīng)該理解,單元測(cè)試最核心的價(jià)值是為了證明:為什么我寫的代碼是正確的?也就是從邏輯角度幫你檢查你的代碼。但是另外一方面,如果從單元測(cè)試覆蓋率角度來(lái)看,單元測(cè)試也是非常耗時(shí)的,幾乎是三倍于你代碼的開發(fā)時(shí)間,所以在很多迭代速度非??斓捻?xiàng)目中,單元測(cè)試就幾乎沒人要求了。但是單元測(cè)試真的能夠從根本上提高代碼質(zhì)量,降低低級(jí)錯(cuò)誤出現(xiàn)的概率。
示例一:取整函數(shù)基本測(cè)試
前置條件
Go語(yǔ)言內(nèi)置了單元測(cè)試執(zhí)行的指令,由于尚未使用Go Modules方法,我們?nèi)匀灰O(shè)置環(huán)境變量,才能正確進(jìn)行測(cè)試
export GO111MODULE=off go test
代碼
假設(shè)我們對(duì)以下函數(shù)進(jìn)行測(cè)試
package even
func Even(i int) bool {
return i % 2 == 0
}
單元測(cè)試建立步驟
創(chuàng)建一個(gè)單元測(cè)試,包括如下步驟:
- 在相同目錄下創(chuàng)建一個(gè)名為*_test.go的文件
- 執(zhí)行g(shù)o test進(jìn)行測(cè)試,將自動(dòng)識(shí)別這些文件
- 引入testing包
- 每一個(gè)Case的命名都是以func TestXxx(t *testing.T)
編寫單元測(cè)試
這里分別對(duì)兩種場(chǎng)景進(jìn)行測(cè)試,一種是為偶數(shù)的情況,一種是為奇數(shù)的情況,來(lái)檢查我們的程序是否按照預(yù)期返回,如果不是則拋出異常信息
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()
}
}
執(zhí)行g(shù)o test后
PASS
ok _/root/workspace/go/test_unittest 0.003s
示例二:Fail()函數(shù)
func (t *T) Fail() 讓測(cè)試失敗,同一個(gè)測(cè)試用例中的測(cè)試?yán)^續(xù)執(zhí)行,后續(xù)的測(cè)試也會(huì)繼續(xù)執(zhí)行
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()
}
}
執(zhí)行測(cè)試后,TestTestingFail中的第二部分也可以繼續(xù)執(zhí)行。
--- 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
示例三:FailNow函數(shù)
func (t *T) FailNow() 讓測(cè)試失敗,同一個(gè)測(cè)試用例中的測(cè)試不再執(zhí)行,后續(xù)的測(cè)試也會(huì)繼續(xù)執(zhí)行
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()
}
}
執(zhí)行后TestTestingFailNow中的第二段測(cè)試不再執(zhí)行,而后面的TestAfterFailNowCase繼續(xù)執(zhí)行
--- 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
實(shí)例四:Log和Fetal函數(shù)
func (t *T) Log(args …interface{}) 使用默認(rèn)格式記錄日志,等同于Print(),記錄錯(cuò)誤日志
func (t *T) Fatal(args …interface{}) 與Log功能相似,但是輸出日志后會(huì)調(diào)用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的執(zhí)行過(guò)程與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
到此這篇關(guān)于一文帶你了解Go語(yǔ)言中的單元測(cè)試的文章就介紹到這了,更多相關(guān)Go單元測(cè)試內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
gin 獲取post請(qǐng)求的json body操作
這篇文章主要介紹了gin 獲取post請(qǐng)求的json body操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-03-03
優(yōu)雅使用GoFrame共享變量Context示例詳解
這篇文章主要為大家介紹了優(yōu)雅使用GoFrame共享變量Context示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06
Go語(yǔ)言實(shí)現(xiàn)23種設(shè)計(jì)模式的使用
設(shè)計(jì)模式是軟件工程中各種常見問題的經(jīng)典解決方案,,本文主要介紹了Go語(yǔ)言實(shí)現(xiàn)23種設(shè)計(jì)模式的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05
go語(yǔ)言import報(bào)錯(cuò)處理圖文詳解
今天本來(lái)想嘗試一下go語(yǔ)言中公有和私有的方法,結(jié)果import其他包的時(shí)候直接報(bào)錯(cuò)了,下面這篇文章主要給大家介紹了關(guān)于go語(yǔ)言import報(bào)錯(cuò)處理的相關(guān)資料,需要的朋友可以參考下2023-04-04
Golang 經(jīng)典校驗(yàn)庫(kù) validator 用法解析
這篇文章主要為大家介紹了Golang 經(jīng)典校驗(yàn)庫(kù) validator 用法解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
使用go連接clickhouse的實(shí)戰(zhàn)操作
這篇文章主要給大家介紹了關(guān)于使用go連接clickhouse的實(shí)戰(zhàn)操作,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用go具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-03-03
Golang中Bit數(shù)組的實(shí)現(xiàn)方式
這篇文章主要介紹了Golang中Bit數(shù)組的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-04-04
Go語(yǔ)言學(xué)習(xí)教程之聲明語(yǔ)法(譯)
Golang 就是類C的語(yǔ)法,下面這篇文章主要給大家介紹了關(guān)于Go語(yǔ)言學(xué)習(xí)教程之聲明語(yǔ)法的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-11-11
Golang高性能持久化解決方案BoltDB數(shù)據(jù)庫(kù)介紹
這篇文章主要為大家介紹了Golang高性能持久化解決方案BoltDB數(shù)據(jù)庫(kù)介紹,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2021-11-11

