天天看點

golang test說明解讀格式形如:參數解讀:

go test是go語言自帶的測試工具,其中包含的是兩類,單元測試和性能測試

通過go help test可以看到go test的使用說明:

go test [-c] [-i] [build flags] [packages] [flags for test binary]

-c : 編譯go test成為可執行的二進制檔案,但是不運作測試。

-i : 安裝測試包依賴的package,但是不運作測試。

關于build flags,調用go help build,這些是編譯運作過程中需要使用到的參數,一般設定為空

關于packages,調用go help packages,這些是關于包的管理,一般設定為空

關于flags for test binary,調用go help testflag,這些是go test過程中經常使用到的參數

-test.v : 是否輸出全部的單元測試用例(不管成功或者失敗),預設沒有加上,是以隻輸出失敗的單元測試用例。

-test.run pattern: 隻跑哪些單元測試用例

-test.bench patten: 隻跑那些性能測試用例

-test.benchmem : 是否在性能測試的時候輸出記憶體情況

-test.benchtime t : 性能測試運作的時間,預設是1s

-test.cpuprofile cpu.out : 是否輸出cpu性能分析檔案

-test.memprofile mem.out : 是否輸出記憶體性能分析檔案

-test.blockprofile block.out : 是否輸出内部goroutine阻塞的性能分析檔案

-test.memprofilerate n : 記憶體性能分析的時候有一個配置設定了多少的時候才打點記錄的問題。這個參數就是設定打點的記憶體配置設定間隔,也就是profile中一個sample代表的記憶體大小。預設是設定為512 * 1024的。如果你将它設定為1,則每配置設定一個記憶體塊就會在profile中有個打點,那麼生成的profile的sample就會非常多。如果你設定為0,那就是不做打點了。

你可以通過設定memprofilerate=1和gogc=off來關閉記憶體回收,并且對每個記憶體塊的配置設定進行觀察。

-test.blockprofilerate n: 基本同上,控制的是goroutine阻塞時候打點的納秒數。預設不設定就相當于-test.blockprofilerate=1,每一納秒都打點記錄一下

-test.parallel n : 性能測試的程式并行cpu數,預設等于gomaxprocs。

-test.timeout t : 如果測試用例運作時間超過t,則抛出panic

-test.cpu 1,2,4 : 程式運作在哪些cpu上面,使用二進制的1所在位代表,和nginx的nginx_worker_cpu_affinity是一個道理

-test.short : 将那些運作時間較長的測試用例運作時間縮短

繼續閱讀