ホームページ > バックエンド開発 > Golang > VS Code でフラグを使用して単体テストを実行およびデバッグするにはどうすればよいですか?

VS Code でフラグを使用して単体テストを実行およびデバッグするにはどうすればよいですか?

Mary-Kate Olsen
リリース: 2024-10-27 17:37:31
オリジナル
626 人が閲覧しました

How to Run and Debug Unit Tests with Flags in VS Code?

VS Code でフラグを使用した単体テストの実行とデバッグ

VS Code でフラグを使用して単体テストを実行するには、go を変更できます。 vscode settings.json ファイルの testFlags 値。ただし、ここで発生する問題は、テストの実行とデバッグに必要な構成が異なることです。

テストの実行

必要なフラグを使用してテストを実行するには、次の構成を使用できます。使用:

<code class="json">"go.testFlags": [
    "-ldflags",
    "-X google.golang.org/protobuf/reflect/protoregistry.conflictPolicy=warn"
]</code>
ログイン後にコピー

デバッグ テスト

デバッグ テストの場合、構成にはフラグを一重引用符で囲む必要があります:

<code class="json">"go.testFlags": [
    "-ldflags",
    "'-X google.golang.org/protobuf/reflect/protoregistry.conflictPolicy=warn'"
]</code>
ログイン後にコピー

複合構成

構成間の切り替えを回避するには、次の複合構成を試すことができます:

<code class="json">"go.testFlags": [
    "-ldflags",
    "'-X google.golang.org/protobuf/reflect/protoregistry.conflictPolicy=warn'",
    "-ldflags",
    "-X google.golang.org/protobuf/reflect/protoregistry.conflictPolicy=warn&quot;"  
]</code>
ログイン後にコピー

デバッグに Dlv を使用する

あるいは、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
ログイン後にコピー

launch.json ファイルを作成して VS Code を dlv セッションに接続します:

<code class="json">{
    ...
    "configurations": [
        {
            "name": "Debug Test",
            "type": "go",
            "request": "attach",
            "mode": "remote",
            "port": 2345,
            "host": "127.0.0.1",
            "showLog": true,
            "trace": "log"
        }
    ]
}</code>
ログイン後にコピー

以上がVS Code でフラグを使用して単体テストを実行およびデバッグするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート