關(guān)于Golang的那些事(十)-- Go測(cè)試

? ? ? ?在Go中,go test子命令是Go語言包的測(cè)試驅(qū)動(dòng)程序拥刻,這些包根據(jù)某些約定組織在一起怜瞒,在一個(gè)包目錄中,以_test.go結(jié)尾的文件不是go build命令編譯的目標(biāo),而是go test編譯的目標(biāo)吴汪。在*_test.go文件中惠窄,三種函數(shù)需要特殊對(duì)待,即功能測(cè)試函數(shù)漾橙、基準(zhǔn)測(cè)試函數(shù)和示例函數(shù)杆融。功能測(cè)試函數(shù)是以Test前綴命名的函數(shù),用來檢測(cè)一些程序邏輯的正確性霜运,go test運(yùn)行測(cè)試函數(shù)脾歇,并且報(bào)告結(jié)果是PASS還是FAIL√约瘢基準(zhǔn)測(cè)試函數(shù)的名稱以Benchmark開頭藕各,用來測(cè)試某些操作的性能,go test匯報(bào)操作的平均執(zhí)行時(shí)間焦除。go test工具掃描*_test.go文件來尋找特殊函數(shù)激况,并生成一個(gè)臨時(shí)的main包來調(diào)用它們,然后編譯和運(yùn)行膘魄,并匯報(bào)結(jié)果乌逐,最后清空臨時(shí)文件。

? ? ? 每一個(gè)測(cè)試文件都需要導(dǎo)入testing包创葡,這些函數(shù)的函數(shù)簽名格式是這樣的:func TestName (t *testing.T) { //... } 浙踢,比如sin函數(shù)就是func TestSin(t *testing.T) {/* ... */},cos函數(shù)就是func TestCos(t *testing.T) {/* ... */}蹈丸。測(cè)試可以讓我們順序地檢查內(nèi)容成黄,如果一個(gè)測(cè)試套件(test suite)里面有很多測(cè)試用例,我們可以選擇性地測(cè)試用例來加加測(cè)試過程逻杖。

? ? ? 命令-v可以輸出包中每個(gè)測(cè)試用例的名稱和執(zhí)行的時(shí)間奋岁,命令-run的參數(shù)是一個(gè)正則表達(dá)式,它可以使得go test只有運(yùn)行那些測(cè)試函數(shù)名稱匹配給定模式的函數(shù)荸百。當(dāng)然闻伶,一旦我們使得選擇的測(cè)試用例通過之后,在我們提交更改之前够话,我們必須重新使用不帶開關(guān)的go test來運(yùn)行一次整個(gè)測(cè)試套件蓝翰。當(dāng)調(diào)用t.Errorf輸出的失敗的調(diào)試用例信息沒有包含整個(gè)跟蹤棧信息,也不會(huì)導(dǎo)致程序宕機(jī)或者終止執(zhí)行女嘲,這和很多其他語言的測(cè)試框架中的斷言不同畜份。測(cè)試用例彼此都是獨(dú)立的,如果一個(gè)測(cè)試表中的一個(gè)條目造成測(cè)試失敗欣尼,那么其他條目的測(cè)試仍然會(huì)繼續(xù)測(cè)試爆雹,這樣我們就會(huì)在一次測(cè)試過程中發(fā)現(xiàn)多個(gè)失敗的情況停蕉,更方便我們進(jìn)行錯(cuò)誤的尋找。有的時(shí)候钙态,我們需要中止測(cè)試慧起,那么我們就可以使用t.Fatal或者t.Fatalf函數(shù)來終止測(cè)試。這些函數(shù)的調(diào)用必須和Test函數(shù)在同樣一個(gè)goroutine中册倒,而不能在測(cè)試用例創(chuàng)建的其他goroutine中蚓挤。

? ? ? ?測(cè)試錯(cuò)誤信息一般的格式是f(X)=Y, want z,這里f(x)表示需要執(zhí)行的操作和它的輸入驻子,y是實(shí)際的輸出結(jié)果灿意,z是期望得到的一個(gè)結(jié)果。處于方便拴孤,對(duì)于f(x)我們會(huì)使用Go的語法脾歧。在基于表的測(cè)試中,輸出x是很重要的演熟,因?yàn)橐粭l斷言語句會(huì)在不同的輸入情況下執(zhí)行多次鞭执,錯(cuò)誤消息要避免樣板文字和冗余信息。如果x芒粹、y兄纺、z都比較長(zhǎng),可以輸出準(zhǔn)確代表各部分的概要信息化漆。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末估脆,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子座云,更是在濱河造成了極大的恐慌疙赠,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,378評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件朦拖,死亡現(xiàn)場(chǎng)離奇詭異圃阳,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)璧帝,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門捍岳,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人睬隶,你說我怎么就攤上這事锣夹。” “怎么了苏潜?”我有些...
    開封第一講書人閱讀 152,702評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵银萍,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我恤左,道長(zhǎng)贴唇,這世上最難降的妖魔是什么贰锁? 我笑而不...
    開封第一講書人閱讀 55,259評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮滤蝠,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘授嘀。我一直安慰自己物咳,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,263評(píng)論 5 371
  • 文/花漫 我一把揭開白布蹄皱。 她就那樣靜靜地躺著览闰,像睡著了一般。 火紅的嫁衣襯著肌膚如雪巷折。 梳的紋絲不亂的頭發(fā)上压鉴,一...
    開封第一講書人閱讀 49,036評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音锻拘,去河邊找鬼油吭。 笑死,一個(gè)胖子當(dāng)著我的面吹牛署拟,可吹牛的內(nèi)容都是我干的婉宰。 我是一名探鬼主播,決...
    沈念sama閱讀 38,349評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼推穷,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼心包!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起馒铃,我...
    開封第一講書人閱讀 36,979評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤蟹腾,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后区宇,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體娃殖,經(jīng)...
    沈念sama閱讀 43,469評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,938評(píng)論 2 323
  • 正文 我和宋清朗相戀三年萧锉,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了珊随。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,059評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡柿隙,死狀恐怖叶洞,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情禀崖,我是刑警寧澤衩辟,帶...
    沈念sama閱讀 33,703評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站波附,受9級(jí)特大地震影響艺晴,放射性物質(zhì)發(fā)生泄漏昼钻。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,257評(píng)論 3 307
  • 文/蒙蒙 一封寞、第九天 我趴在偏房一處隱蔽的房頂上張望然评。 院中可真熱鬧,春花似錦狈究、人聲如沸碗淌。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽亿眠。三九已至,卻和暖如春磅废,著一層夾襖步出監(jiān)牢的瞬間纳像,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工拯勉, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留竟趾,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,501評(píng)論 2 354
  • 正文 我出身青樓谜喊,卻偏偏與公主長(zhǎng)得像潭兽,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子斗遏,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,792評(píng)論 2 345