<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                ## go test工具 Go語言中的測試依賴go test命令 go test命令是一個按照一定約定和組織的測試代碼的驅動程序。在包目錄內,所有以\_test.go為后綴名的源代碼文件都是go test測試的一部分,不會被go build編譯到最終的可執行文件中。 在`*_test.go`文件中有三種類型的函數,單元測試函數、基準測試函數和示例函數。 | 類型 | 格式 | 作用 | | --- | --- | --- | | 測試函數 | 函數名前綴為Test | 測試程序的一些邏輯行為是否正確 | | 基準函數 | 函數名前綴為Benchmark | 測試函數的性能 | | 示例函數 | 函數名前綴為Example | 為文檔提供示例文檔 | go test命令會遍歷所有的`*_test.go`文件中符合上述命名規則的函數,然后生成一個臨時的main包用于調用相應的測試函數,然后構建并運行、報告測試結果,最后清理測試中生成的臨時文件。 Golang單元測試對文件名和方法名,參數都有很嚴格的要求。 ~~~ 1、文件名必須以xx_test.go命名 2、方法必須是Test[^a-z]開頭 3、方法參數必須 t *testing.T 4、使用go test執行單元測試 ~~~ ### go 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 : 將那些運行時間較長的測試用例運行時間縮短
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看