使用標誌運行和調試單元測試:解決衝突的Protobuf 擴展
在VS Code 中調試單元測試時,可能需要通過用單元測試於解決Protobuf 擴充衝突的附加標誌。本指南提供了此問題的解決方案,允許無縫調試。
VS Code settings.json 中的原始配置嘗試新增所需的標誌 '-ldflags "-X google.golang.org/protobuf/reflect /protoregistry.conflictPolicy=警告"'。但是,當 VS Code 產生標記周圍帶有單引號的測試命令時,此配置會遇到問題。
要解決此問題,需要調整 settings.json 中的配置。修改應刪除標誌值周圍的單引號:
"go.testFlags": [ "-ldflags", "-X google.golang.org/protobuf/reflect/protoregistry.conflictPolicy=warn" ]
透過此修改,VS Code 將產生一個測試命令,該命令正確包含必要的標誌,而不會導致與proto 擴展衝突相關的錯誤。
對於偵錯,由於使用 VS Code 介面偵錯特定測試的複雜性,因此建議採用不同的方法。使用特定標誌編譯測試二進位檔案並利用 dlv 進行無頭偵錯可以實現更好的控制和高效調試。
要編譯測試二進位檔案:
go test -c -ldflags "-X google.golang.org/protobuf/reflect/protoregistry.conflictPolicy=warn" -gcflags="all=-N -l"
此命令產生具有所需的二進位檔案用於偵錯的標誌。要以無頭模式連接dlv 以進行編輯器連接:
dlv exec ./foo.test --headless --listen=:2345 --log --api-version=2 -- -count=1 -- $(pwd)/some/path
這裡,foo.test 是產生的二進位文件,-count=1 表示用於測試的自訂標誌,$(pwd) /some/path 可以是用於黃瓜式測試。將編輯器連接到 dlv 會話並開始偵錯。
其他資訊
Go 還提供了透過內嵌標誌啟動dlv 的便捷方法,對於Vim 用戶來說,vim -go 插件允許使用以下命令進行自定義斷點設定和dlv 連線:GoDebugConnect 127.0.0.1:2345。透過遵循上述步驟,開發人員可以有效地執行和調試帶有標誌的單元測試,確保測試和程式碼維護的順利進行。
以上是如何使用 VS Code 調試 Go 單元測試中衝突的 Protobuf 擴充功能?的詳細內容。更多資訊請關注PHP中文網其他相關文章!