golang test說明解讀

來源:互聯網
上載者:User
這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。

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 : 將那些已耗用時間較長的測試案例已耗用時間縮短

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.